From 895c9a6cce9d1038bc69ec6bd1f7a86c36ca51c0 Mon Sep 17 00:00:00 2001 From: rtniveditait Date: Mon, 25 Apr 2016 15:45:34 +0530 Subject: Made some re-arrangements --- Doc/Creating-Ladders.rst | 2 +- Doc/Creating-Ladders.rst~ | 65 ++++++++++++++++++++++ Doc/Programmming-the-controller.rst~ | 101 +++++++++++++++++++++++++++++++++++ 3 files changed, 167 insertions(+), 1 deletion(-) create mode 100644 Doc/Creating-Ladders.rst~ create mode 100644 Doc/Programmming-the-controller.rst~ (limited to 'Doc') diff --git a/Doc/Creating-Ladders.rst b/Doc/Creating-Ladders.rst index 8107396..d04d9dc 100644 --- a/Doc/Creating-Ladders.rst +++ b/Doc/Creating-Ladders.rst @@ -3,7 +3,7 @@ Creating Ladders using Ld micro LD Micro’s simple user interface is really easy to use and is self explanatory.To get started working with LD Micro, just double click the LD Micro executable present in your system. Once opened, you shall get such a GUI. -.. image:: ../images/ld1.png +.. image:: /images/ld1.png :height: 540px :width: 750px :scale: 150 diff --git a/Doc/Creating-Ladders.rst~ b/Doc/Creating-Ladders.rst~ new file mode 100644 index 0000000..d04d9dc --- /dev/null +++ b/Doc/Creating-Ladders.rst~ @@ -0,0 +1,65 @@ +Creating Ladders using Ld micro +=============================== + +LD Micro’s simple user interface is really easy to use and is self explanatory.To get started working with LD Micro, just double click the LD Micro executable present in your system. Once opened, you shall get such a GUI. + +.. image:: /images/ld1.png + :height: 540px + :width: 750px + :scale: 150 + +Before starting to make the ladder, first make the necessary changes in +the default settings, so as to generate the HEX code for your microcontroller. + +Under Settings tab, select the MCU Parameters Option + +.. image:: /images/Setup.png + :height: 340px + :width: 450px + :scale: 150 + +Then after selecting, change the clock frequency to 16MHz and if using +UART change the baud rate to 9600. + +.. image:: /images/cont.png + :height: 540px + :width: 650px + :scale: 150 + +Now that the configurations are set, the next step can be followed to +design the ladder with the appropriate logic. + +Start off with having a look at the Instruction tab. It has a lot of +instructions that are in accordance with the Ladder logic followed for the PLCs and work in the same way and are similar to the ones described above under the ’Understanding the Instructions’ section. + +After selecting the appropriate instruction, just double click the instruction to edit the name of the variable and other parameters related to the particular instruction. + +.. image:: /images/change.png + :height: 540px + :width: 650px + :scale: 150 + +After making the appropriate ladder for the application, the digital input and outputs should be given an appropriate pin number of the controller and the connections should be done accordingly. This can be done by double clicking the appropriate pin to be configured in the consolidated table just below the ladder made. + +.. image:: /images/PIN.png + :height: 540px + :width: 600px + :scale: 150 + +Now that the logic is set, the ladder can be simulated to verify it’s working. This is done by clicking the Simulate tab and Simulation Mode option under it. This is then followed by a similar screen where Blue indicates LOW and Pink indicates HIGH. To start the simulation, under Simulate tab click Start Real-Time Simulation option. After this, to change the state, just double click the instruction. The appropriate changes and values pertaining to different variables can be seen in the consolidated instruction table under the State column. To come out of simulation mode, click the same Simulation Mode option. + +.. image:: /images/states.png + :height: 340px + :width: 450px + :scale: 150 + +After the ladder along with assigning the appropriate pin numbers, the +HEX code can be generated. This can be done by first saving the ladder +under the File tab with the Save As option. Save the file in the appropriate destination folder with a suitable name. Remember the final destination of the same for future. Now, to generate the HEX file, select the Compile tab and then the option Compile As. Then save this text file in the desired destination folder. The location shall be noted as it’d be needed to burn the code onto the controller using the command line arguments later. + + + + + + + diff --git a/Doc/Programmming-the-controller.rst~ b/Doc/Programmming-the-controller.rst~ new file mode 100644 index 0000000..d6ffc9d --- /dev/null +++ b/Doc/Programmming-the-controller.rst~ @@ -0,0 +1,101 @@ +Programming the Controller +========================== + +There are several programmers available to program any controller IC. They are called as ISPs. USBASP is one of them. Before programming the IC, we need to set the fuses. + +Setting up fuse bits +-------------------- + +Now that the programmer is installed on the system, we need to adjust the +properties of the controller IC such that it meets the necessary requirements along with the peripherals installed on the board. Essentially, fuse bits are the ones that decide how the controller responds, like which clock frequency it responds to or its programming availabilities. + +Setting up the fuse is a crucial task as the controller may not respond later if the fuse bits that are set are not in accordance with the attached peripherals. Before setting the fuses, the factory settings on the controller make sure it works on the internal oscillator of clock speed 1MHz. It’s mostly dependent on 2 fuses - lfuse and hfuse. Both of these have hex 8 bit values. When working on communication with the device, like UART, these fuse bits play a key role, if not defined, the +controller works on the internal clock that’s much slower than the externalcrystal. For the controller, 16MHz external crystal was selected. This meant the controller shall configure this external crystal and work on it. + +**WARNING:** Fuse bits control the way the controller responds. If +any mistake is made in setting up the fuse bits, then the controller +becomes isolated from the external circuit. This means that the +controller doesn’t respond and renders useless. Hence, always triple +check before entering the fuse bits. This is the best practice, +or else you may end up wasting one IC. + +Type the following command into the Terminal: + +**sudo avrdude -p m16 -c usbasp -U lfuse:w:0xFF:m -U hfuse:w:0xD9:m -B10** + +Screen like below will pop up after giving the command line + +.. image:: ../images/fuse1.png + :height: 540px + :width: 450px + :scale: 100 + +You can read fust bits after setting up, as shown below, + +.. image:: /images/fuse2.png + :height: 540px + :width: 450px + :scale: 100 + +Now the external crystal is working in sync with the controller. + +USBASP as ISP +------------- + +Step 1: We require a precompiled hex file to be burnt onto our microcontroller. In our case, we have generated it by doing simple ladder programming in LDMicro and then compiling it. Before that, ensure that the proper target controller from the drop-down menu is chosen. For input and output part, assign a certain pin no. of the controller to that of the desired application. Now, a certain name is given to the file(say, blink.hex) at the destination folder. + +Step 2: After being done with all the software part, one shall supply the power from 12V SMPS to the development board. Now check whether the +controller is powered up properly with 5 Volt or not from the appropriate Vcc and GND pins of the controller. + +Step 3: Now, just connect the FRC cable from USBASP to the 10 pin +shrouded header on the board. + +Step 4: Now, turn on Terminal and then change the directory to the one +in which you have the saved HEX file to be dumped onto the processor. + +Step 5: Now, in the terminal, enter the following command. + +**sudo avrdude -p atmega16 -P usb -c usbasp -B10 -U flash:w:Blink.hex** + +You shall see such a process going on in the terminal like the one shown +below, which means that the process of erasing and writing the internal +memory of the ATmega IC is in the process. On correct execution you shall +get such a result. Whilst it’s burning the code, the red light on the USBASP will be lit showing that it is communicating with the controller appropriately. + +Remember, after the fuses are set (covered in the following sections in +detail), then the -B10 flag is necessary and can be deleted. + +.. image:: /images/usb.png + :height: 540px + :width: 450px + :scale: 100 + +Trouble shooting +~~~~~~~~~~~~~~~~ + +- Check if the board is powered from the SMPS, if not, power it and try + it once powered. +- Check if all the essential flags in the command line are incorporated, + if not make the appropriate changes. +- Check if the FRC cable of the USBASP is not stranded in the midway, + if so, replace it. +- If all these fail, check if the appropriate MOSI, MISO, SCK, RST and + GND pins of the header are appropriately shorted with the ones of the + IC and also that the controller firmly sits on the base. + +These are the main errors you may get while programming the PLC. + + + + + + + + + + + + + + + -- cgit