# SIEMENS SIMATIC S5-101U Programmable Controller Programming Instructions Order No.: GWA 4NEB 810 2120-02 a Fig. 1 S5-101U programmable controller | CONTENT | rs | Page | | | Page | |-------------------|------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------| | 1.<br>1.1<br>1.2 | THE PROGRAMMING LANGUAGE<br>STEP 5 programming language<br>Program structure | 1.1 | 4.2.1<br>4.2.2<br>4.2.3 | Signal status display<br>Forcing of outputs and | 4.2 | | 2. | PRINCIPLE OF OPERATION OF THE PC | | 4.2.4 | flags<br>Forcing of timers and<br>counters | 4.2<br>4.3 | | 2.1<br>2.2<br>2.3 | Program processing<br>"RUN and "STOP" modes<br>Memories | 2.1<br>2.2<br>2.2 | 5.<br>5.1<br>5.1.1 | PROGRAMMING EXAMPLES Basic operations Binary logic operations | 5.1 | | 3.1<br>3.2<br>3.3 | NOTES ON PROGRAM DEVELOPMENT<br>Power-up<br>Battery monitoring<br>Rententive/non-rententive<br>flags<br>Interrupt processing | 3.1<br>3.2<br>3.2<br>3.2 | 5.1.2<br>5.1.3<br>5.1.4<br>5.1.5<br>5.1.6 | Setting/resetting operations<br>Load and transfer operations<br>Timer functions<br>Counter functions<br>Comparison (relational)<br>operations | 5.4<br>5.6<br>5.8<br>5.12<br>5.14 | | 3.5<br>3.6 | Intercompatibility between LAD, CSF and STL Operation in the SINEC L1 local area network | 3.4<br>3.7 | 5.1.7<br>5.1.8<br>5.2<br>5.2.1 | Other functions Supplementary operations Logic operations (word mode) | | | 4.<br>4.1 | PROGRAM START-UP<br>Loading and dumping a<br>program | 4.1<br>4.2 | 5.2.2<br>5.2.3<br>5.2.4<br>5.2.5 | Jump operations | 5.19<br>5.19<br>5.20<br>5.22 | | 4.2 | Program test | 7.4 | 6. | OPERATION SET | 6.1 | # 1. The programming language ## 1.1 STEP 5 programming language The user programs are written in the STEP 5 programming language. The statements of this language permit not only the programming of simple binary functions but also the programming of complex digital functions. Depending on the programmer used, all three methods of representation statement list (STL) ladder diagram (LAD) control system flowchart (CSF) are possible so that the method of programming can be adapted to the particular application. Only STL programming is possible with the handheld 605U programmer. The machine code generated by the 670/675 programmers is identical for all three methods of representation. | Statement list | Ladder diagram | Control system flowchart | | |-----------------------------------------------------------------|--------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | Programming with mnemo-<br>nics of the function<br>designations | Programming with gra-<br>phic symbols similar to<br>schematic circuit diagrams | Programming with gra-<br>phic symols | | | to<br>DIN 19 239 (draft) | to<br>DIN 19 239 (draft) | to<br>IEC 117-15<br>DIN 40 700<br>DIN 40 719<br>DIN 19 239 (draft) | | | STL A I AN I A I ON I O I = Q | HAD FT H | CSF Signature of the control | | Fig. 2: Methods of representation with the STEP 5 programming language ## 1.2 Program structure The user program consists of up to 1024 statements and can be written as a program block (PB) or function block (FB). Only PB1 or FB1 can be executed on the S5-101U programmable controller. #### Program block A program block can be programmed and documented in all three methods of representation (STL, LAD and CSF). A program block can be translated from one method of representation into the two other methods with the 670/675 programmers provided certain programming rules are observed (see Section 3.4). For users familiar with contactors and relays, the LAD method is recommended since the ladder diagram has very close similarities with schematic circuit diagrams. Program blocks are used especially when a CRT-based programmer is available and programming or documentation is to be made in graphic form. Note: Supplementary operations must not be used in PB1. #### Function block Function blocks can only be written and documented in STL form. Jump operations make it possible to enhance the structuring of the user program and thus also its capabilities. Short, constant response times to interrupts can be implemented with load and transfer operations in conjunction with jump operations (see Section 3.4). # 2. Principle of operation ## 2.1 Program processing The control functions of the 101U are defined by a user program. In order to be able to scan the user program cyclically statement by statement, the CPU has to perform the following functions: - In the case of a cold restart (power switch from "Off" to "On" or mode selector from "Stop" to "Run"), the process output image\* is erased, i.e. all outputs are set to zero. - 2. The process input image\* is updated, i.e. all signal statuses of the inputs are scanned and written into the process input image. - 3. The user program (PB1 or FB1) is scanned and processed statement by statement. When scanning the signal statuses of the inputs, the CPU accesses the process input image and not the actual inputs. When latching and unlatching the outputs (coils), only the process output image is overwritten to begin with. - 4. Once the user program has been processed, the process output image is transferred to the actual outputs. - 5. Points 2, 3 and 4 are handled cyclically. Fig. 3: Principle of operation of the S5-1010 A scanning operation from cycle checkpoint to cycle checkpoint takes approx. 70 ms for 1024 statements (binary). If a scanning cycle is not completed within 300 ms due to program errors or faults, an internal monitor responds, the PC enters the "Stop" status and all outputs (coils) are switched off. \* Process I/O image: Internal memory area in which the signal status ("O" or "1") of the inputs/outputs is stored. ## 2.2 The "Run" and "Stop" modes #### "RUN" mode In the "RUN" mode, the program is scanned cyclically from cycle checkpoint to cycle checkpoint. The PC is brought into the "RUN" mode by - switching the mode selector to "RUN" - selecting the "PC RUN" function of the programmer (mode selector in "RUN" position) - and on recovery of the power supply if the mode selector is at "RUN" and was in the "RUN" position prior to the power failure. #### "STOP" mode In the "STOP" mode, the program is not scanned and the outputs (coils) are disabled. While the PC is in the "STOP" state, all timers and counters and the process I/O image retain the values or states they had in the last scanning cycle prior to the PC entering the "STOP" state. If the PC is switched to "RUN", the timers and counters (0...7) are reset. The non-retentive flags and the process I/O image are erased. The PC is brought into the "STOP" mode by - switching the mode selector to "STOP" - selecting the "PC STOP" function on the programmer - faults or errors in program scanning, e.g. time-out or operations that can not be interpreted by the PC. The cause for the PC entering the "STOP" state can be traced with the aid of the "DISPLAY ISTACK" function of the programmer (see Section 4.2 of Operating Instructions). ## 2.3 Memories The PC has an internal program memory, the data of which can be supported for three years by a backup battery. There are also two different memory submodules (see Fig. 4). The memory submodules are used for program dumping or for copying the program should only one memory submodule be used for a number of PCs. On power-up or when the PC is switched to "RUN", the contents of the memory submodule are always copied into the internal memory and processed there. | Memory submodule | EPROM | EEPR OM | |---------------------------------------------|------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------| | Program<br>dump | PG 615 (with adapter 984-2UA11) PG 670 (with adapter 984-0UA11) PG 675 | PG 615<br>PG 670 (without 984<br>adapter)<br>PG 675 | | Program<br>erasure | Only with special UV lamp<br>(erasure time: 30 min) | Direct in the PC with<br>the above programmers<br>and the PG 605U pro-<br>grammer<br>(Programmer function:<br>PG PC) | | Program modi-<br>fication via<br>programmer | Only<br>erasure of entire<br>program possible | possible | Fig. 4: Differences between the EPROM and EEPROM submodules. # 3. Notes on program development ## 3.1 Power up When the power supply is switched on or on recovery of the power supply after a power failure, the PC assumes the following states without having to take any additional measures in the user program: | POWER OFF | Current position<br>of mode selec-<br>tor of the PC on<br>power-up | Operating mode<br>of PC prior to<br>power-up | Error<br>identi-<br>fier* set | Operating<br>mode follow-<br>ing power-up | |------------|--------------------------------------------------------------------|----------------------------------------------|-------------------------------|-------------------------------------------| | POWER ON — | STOP | STOP ———————————————————————————————————— | YES NO | STOP STOP STOP RUN | Fig. 5: Automatic mode setting following power-up # <u>Prevention of automatic restart in general</u> Flag\* F 63.7 can be used to prevent automatic restart on power-up. This flag is set by the operating system of the PC on power-up if the "RUN" mode is set and was set prior to power-down. In order to enable manual restart, flag F 63.7 is reset in the "STOP" mode. It can also be reset by the user program (e.g. in conjunction with an input signal). \* Internal relay equivalent #### Programming example \* A fault has occurred in program scanning and the reason for this is stored in the interrupt stack. # Preventing automatic restart on battery failure Flag F 63.6 can be used to prevent automatic restart on battery failure (retentive flags reset). Flag F 63.6 is set by the operating system of the PC on power-up if the backup battery fails or is not connected. The PC must be set to the "RUN" mode in this case. Flag F 63.6 is reset by the "ERASE PROGRAM" function or by the user program (e.g. in conjunction with an input signal). #### Programming example ## 3.2 Battery monitoring Flag F 63.6 is used for monitoring the battery. This flag is set by the operating system of the PC on power recovery and during the normal scanning cycle if failure of the battery backup voltage is detected. The PC must be in the "RUN" state. Flag F 63.6 is reset by the "ERASE PROGRAM" function of the programmer or by the user program. The user can therefore determine how the PC is to react to backup battery failure. ## 3.3 Rententive/non-rententive flags The S5-101U has a total of 512 flags. The flag area is subdivided as follows: #### Retentive flags (F 0.0...F 31.7) - retain their last state prior to power-down on power-up (with backup battery only) - retain their last state when the mode is changed from "STOP" to "RUN" (with and without backup battery) - are reset like the non-retentive flags on power-up (without backup battery) - can also be reset by the user program ("ERASE PROGRAM" function). By using retentive flags, the last status of the plant or machine prior to the PC leaving the "RUN" mode can be stored. On restart, the plant or machine can resume operations at the point at which it was stopped. #### Non-retentive flags (F 32.0...F 63.7) - are reset when the PC mode changes from "STOP" to "RUN" and on power-up. Flags F 61.0 - F 62.7 are reserved as coordinating flags for operation in the SINEC L1 local area network; flags F 63.0 - F 63.7 are reserved as system flags. Since they are affected by the PC operating system, they must not be used as flags in the normal sense. ## 3.4 Interrupt processing When an interrupt signal (e.g. emergency off) from the process is received by the PC, the latter interrupts cyclic scanning of the user program and inititates the processing of a specific interrupt routine. Interrupt processing with the S5-101U is defined exclusively by the user program so that each input and output can be used for interrupt processing. In order to achieve minimum response times, the inputs and outputs are referenced direct, i.e. outside cyclic program scanning. The load/transfer operations "LPB" (inputs) and "TPB" (outputs) are available for this purpose. A more or less constant response time is achieved if the scanning of the inputs programmed by the user as interrupt inputs is uniformly distributed over the entire user program. Fig. 6 shows a user program with interrupt processing. Task: When input I $\emptyset.\emptyset$ becomes "1", outputs Q $\emptyset.\emptyset...$ Q $\emptyset.7$ are to assume the state of flags F $3.\emptyset...$ F3.7. In order to keep the response time as short and constant as possible, ten interrupt scans should be written in the user program. Fig. 6: Example of a user program with interrupt scanning ## 3.5 Intercompatibility between LAD, CSF and STL #### General Each of the methods of representation in the STEP 5 programming languages has specific properties and limitations. Consequently, a program block written in STL cannot simply be displayed as an LAD or CSF and the graphic methods of representation, LAD and CSF, may not always be fully compatible. In other words, one form cannot always be translated back into the other form. If the program has been entered as an LAD or CSF, it can always be translated back into STL form. Fig. 7: Range and limitations of the methods of representation in the STEP 5 programming language The aim of this section is to establish a number of rules, which, if adhered to, will ensure complete compatibility between the three methods of representation. These rules are classified as follows: Rules for compatibility between the graphic methods of representation (LAD and CSF). If these rules are followed, input is possible in one graphic form and display in the others. Fig. 8: Graphic input - Rules for compatibility between the statement list and the graphic methods of representation. If these rules are observed, it is possible to enter a program in any if the three methods of representation, graphic or not, and to have it displayed in the other two forms. Fig. 9: Input in the form of a statement list #### Input as LAD and display as CSF (STL) Rule: Do not exceed the display boundaries for LAD. Excessive nesting may cause the LAD display boundary to be exceeded (8 levels) Fig. 10: Example of maximum LAD nesting for display as CSF #### Input as CSF and display as LAD (STL) Rule 1: Do not exceed the display boundaries for LAD. Too many inputs on a CSF box cause the ladder diagram display boundary to be exceeded. Fig. 11: Example of a maximum AND box in CSF form for display as an LAD Rule 2: The output of a complex element (memory, comparator, timer and counter) must not be ored. Fig. 12: Only AND boxes are allowed in CSFs after a complex element. #### Input as STL and display as LAD or CSF Rule 1: A complex element must not have a preceeding operation. Rule 2: The inputs and outputs of complex elements must be programmed in the order in which they are assigned parameters on the screen in graphic Times and counts are exceptions since the relevant value must first be stored in the accumulator with a load operation. In addition, every unused input or output must be assigned an NOP O operation. In the case of timers and counters, the set input and the input for loading the time (TW) or count (ZW) must be disabled together. Fig. 13: Example for assigning NOP operations to unused inputs and outputs mode. ## 3.6 Operation in the SINEC L1 local area network The SINEC L1 local area network is used for interconnecting programmable controllers of the low-end performance range and operates on the Master-Slave principle. The CP 530 communications processor is always the Master, and the slaves the CPUs of all small PCs. Each slave is assigned a slave number under which it is referenced. Data can be interchanged between the master and up to 30 slaves, as well as between the individual slaves. In the case of the S5-101U, the slave number, the coordinating flags and the send and receive mailboxes are defined as follows: In addition to the actual data, control and security information, which the STEP 5 user program can access through a coordinating flag word, is also transmitted. The actual data are deposited in a receive mailbox and a send mailbox which the user can access with load and transfer operations. #### Slave number The slave number is stored at the beginning of the user program (PB1/FB1) together with an indentifier. #### RECEIVE coordinating flag byte (KME) Flag byte FB 61 is used. ## SEND coordinating flag byte (KMS) Flag byte FB 62 is used. Bit for bus master The coordinating flags are affected by the operating system of the PC and can therefore not be used as flags in the normal sense. #### Receive mailbox The receive mailbox is in data block DB1 (DW 40...DW72) and has the following structure: | DL 40 | LENGTH of net<br>(064) | DR 40 | SOURCE-SLAVE No. (030) | DW 40 | | |-------|------------------------|-------|------------------------|-------|--------| | DL 41 | 1st item of data | DR 41 | 2nd item of data | DW 41 | 1 | | DL 42 | 3rd item of data | DR 42 | 4th item of data | DW 42 | 1) | | • | • | • | • | 1. | 1 1 | | 1 • | • | | • | • | Nett | | | • | | | | 🕨 data | | • | • | • | • | • | | | DL 71 | 61st item of data | DR 71 | 62nd item of data | DW 71 | | | DL 72 | 63rd item of data | DR 72 | 64th item of data | DW 72 | ] ノ | 1) Slave No. $\emptyset$ = Master #### Send mailbox The send mailbox is in data block DB 1 (DW88...DW 112) and has the following structure: | DL 80 | LENGTH of nett data (064) | DR 80 | DESTINATION SLAVE No. (030) | DW 80 | | |--------|---------------------------|--------|-----------------------------|--------|------| | DL 81 | 1st item of data | DR 81 | 2nd item of data | DW 81 | | | DL 82 | 3rd item of data | DR 82 | 4th item of data | DW 82 | | | • | • | • | • | • | | | • | • | • | • | • | Nett | | • | • | • | • | • | data | | • | • | • | • | • | | | DL 111 | 61st item of data | DR 111 | 62nd item of data | DW 111 | | | DL 112 | 63rd item of data | DR 112 | 64th item of data | DW 112 | ノ | 1) Slave No. Ø = Master For more detailed information on the SINEC L1 local area network, please refer to the Instructions (4NEB 811-0545) and Programming Instructions (4NEB 811-0546) of the SINEC L1 network. # Program Start-up The hand-held PG 605U/615 programmer and the CRT-based PG 670 and PG 675 programmers can be used for loading and testing programs. The following settings are necessary on the PG 670 and PG 675 programmers in conjunction with the S5-1101 U programmable controller: PG 670: S5-150 AK S5-130 W PG 675: S5-150 S NO #### Loading and dumping a program 4.1 Before loading the program, the "ERASE PROGRAM" function must be executed. This deletes - the internal program memory of the PC - the binary process I/O image - all flags - error identifiers and the causes of interrupts. When the program has been loaded, is transferred from the programmer memory to the internal memory of the PC. If an EEPROM submodule is plugged in, the program is automatically dumped. Once the program has been transferred to the PC memory, it is no longer in the programmer memory and must be brought back into the latter before program corrections can be made\* (output FB1/PB1). Dumping of the program in an EPROM submodule is possible on the PG 615 (with adapter), PG 670 (with 984 adapter) and PG 675 programmers. To dump the program in an EPROM sub- Fig. 14: Schematic of a program loading operation followed by the dumping of the program in an EEPROM submodule #### 4.2 **Program test** Faults causing the PC to enter the "STOP" status can be identified with the aid of the interrupt stack (see Instructions, Section 4.2) The following debugging functions are available for tracing logic errors in program scanning. #### 4.2.1 Search function The programmer "Search" function is available for locating points in the user program. In the test phase, for instance, all points in a program containing a definite operand can be displayed, e.g. an output not acting as expected. The following search keys can be used: - Statements, e.g. AI 1.0 - Operands, e.g. I 1.0 Labels (FB 1 only) - Addresses Search runs are important in conjunction with the following functions: - Input/correction - Display - Program-dependent signal status display For more details, please refer to the Operating Instructions of the programmers. #### 4.2.2 Signal status display The following programmer functions are available for displaying the signal statuses of binary and digital operands: #### Direct signal status display The status of any operands can be observed at the cycle checkpoint (Section 2.1) with the aid of this function. #### Program-dependent signal status display This test function enables the signal status of an operand and the result of the logic operation to be observed when the selected statement is processed. #### Forcing of outputs and flags 4.2.3 The "FORCE" function enables definite binary and digital operands to be influenced with the PC in the "RUN" mode. The desired statuses of the operands are entered from the programmer byte by byte and transferred to the PC. The following can be forced: - QB 0... QB 3 - FB 0...FB 63 In this way, it is possible to force definite outputs on system startup without the user program and check the correct wiring of actuators and indicators etc. When forcing while a user program is executing, the operand statuses entered are transferred once to the PC and program scanning resumed with these statuses entered may be modified by the current program. #### 4.2.4 Forcing of timers and counters Timers and counters can be forced in both operating modes of the PC, using the 605U, 615 and OP 393 programmer only. Programming (from version 1.1 onwards) Data words DW Ø to DE 15 in data block DB 1 are reserved for the preset values for timers and counters. In the user program, reference is made to the associated data word when timers and counters are started. $$\begin{bmatrix} \mathsf{T} & \emptyset \\ \mathsf{C} & \emptyset \end{bmatrix}$$ DW $\emptyset$ to $\begin{bmatrix} \mathsf{T} & 15 \\ \mathsf{C} & 15 \end{bmatrix}$ DW 15 If both timers <u>and</u> counters are to be forced, different numbers should be used, e.g. A maximum of 16 timers/counters in any combination can be forced. The following program is required in the PC: Make sure that there are meaningful time values in the data words used when changing from the "STOP" to the "RUN" mode. It is advisable to force the timers/counters (with the preset values) in the "STOP" status of the PC. #### Forcing with the programmer The data word assigned to a timer or counter is loaded with the preset value, using the "Direct signal status display" function of the programmer. The data block for the preset value can be selected on the programmer (but DB1 is mandatory for the S5-101U PC). Programming (from version 1.2 onwards) Data words DW Ø to DW 15 in data block DB 1 are reserved for the preset values for timers and counters. In the user program, reference is made to the associated data word when timers and counters are started. T $$\emptyset$$ DW 0 to T 15 DW 15 C $\emptyset$ DW 15 to C 16 DW 31 16 timers and 16 counters can be forced. The following program is required in the PC: $$\begin{array}{c|c} \mathsf{LDW} \ \emptyset \\ \mathsf{SPT} \ \emptyset \\ & \cdot \\ \mathsf{LDW} \\ \mathsf{16} \\ \mathsf{SC} \ 1 \end{array} \begin{array}{c} \mathsf{LKC} \ \mathsf{is} \ \mathsf{replaced} \ \mathsf{by} \\ \mathsf{LDW} \ (16...31) \\ \end{array}$$ For further information, please refer to the Programming Instructions of the 605U programmer in the Section entitled "PROGRAM TEST—Forcing of timers and counters." # 5. Programming examples ## 5.1 Basic operations ## 5.1.1 Binary logic operations ## **AND logic** | Original | | STEP 5 representation | | | | | | |--------------------|---------------------------------------|--------------------------------------|---------------------|------------------------------|--|--|--| | | | Statement<br>list | Ladder<br> diagram | Control system<br>flowchart | | | | | 1.3<br>I11 1.7<br> | \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ \ | A I 11<br>A I 13<br>A I 17<br>= Q 1Ø | I11 I13 I17 Q10 | I1.1 - & I1.3 - I1.7 - Q 1.0 | | | | | | | | | | | | | A "1" signal appears at output Q 1.0 when all the inputs have "1" signals simultaneously. A "O" signal appears at output Q $1.\emptyset$ if at least one of the inputs has a "O" signal. There are no restrictions imposed on the number of scans and the programming sequence. ## **OR logic** | Original | STEP 5 representation | | | | | | |-----------------------|------------------------------------------|-------------------|--------------------------------------|--|--|--| | | Statement<br>list | Ladder<br>diagram | Control system<br> flowchart | | | | | I 12 <sup>17</sup> .5 | O I 1.2<br>O I 1.7<br>O I 1.5<br>= Q 1.2 | I1.2 Q12 | I 1.2 - >=1<br>I 1.7 - I 1.5 - Q 1.2 | | | | A "1" signal appears at output Q 1.2 if at least one of the inputs has a "1" signal. A "O" signal appears at output Q 1.2 when all inputs have "O" signals simultaneously. There are no restrictions imposed on the number of scans and the programming sequence. ## **AND before OR logic** | Original | STEP 5 representation | | | | | |----------------------------------|----------------------------------------------------------|-------------------|--------------------------|--|--| | | Statement<br>list | Ladder<br>diagram | Control system flowchart | | | | I 15 I 16 I 1.4 I 1.3<br>↓ I 1.5 | A I 1.5<br>A I 1.6<br>O<br>A I 1.4<br>A I 1.3<br>= Q 1.1 | I15 I1.6 Q1.1<br> | I 1.5 | | | A "1" signal appears at output Q 1.1 when the output of at least one of the AND gates is "1". A "O" signal appears at output Q 1.1 when neither of the AND gates has "1" at its output. ## **OR before AND logic** | Original | STEP 5 representation | | | | | |-------------------------------------------------------------------|---------------------------------------------------------------------|-----------------------------------------------------------------|-------------|--------------------------------------------------------------|--| | | Statement<br>list | Ladder<br>diagram | | Control system flowchart | | | I 1.0 I1.1 I1.2 I1.3 I1.0 I1.3 I1.1 I1.1 I1.1 I1.1 I1.1 I1.1 I1.1 | O I 1.Ø<br>O<br>A I 11<br>A (<br>O I 1.2<br>O I 1.3<br>)<br>= Q 1.1 | I 1.0<br>I 1.2<br>I 1.2<br>I 1.3<br>E T 1.1<br>I 1.3<br>E T 1.1 | Q1.1<br>( ) | I 1.0 I 1.1 I 1.2 I 1.3 ——————————————————————————————————— | | A "1" signal appears at output Q 1.1 if input I 1.0 or I 1.1 and one of the inputs I 1.2 or I 1.3 have a "1" signal. A "O" signal appears at output Q 1.1 when input I 1.0 has a "O" signal and the AND gate has a "O" at its output. ## **OR before AND logic** | Original | STEP 5 repr | | | |---------------------|---------------------------------------------------------------|---------------------------------|-----------------------------| | | Statement<br>list | Ladder<br>diagram | Control system<br>flowchart | | I1.4 I1.5 I2.Ø I2.1 | A(<br>OI 1.4<br>OI 1.5)<br>A(<br>OI 2.0<br>OI 2.1)<br>= Q 2.0 | II.4 I2.0 Q.2.0<br> E-3 E- ( ) | I1.4 ->=1<br>I1.5 | A "1" signal appears at output Q 2. $\emptyset$ when both OR gates have "1" signals at their outputs. A "O" signal appears at output Q 2.0 when at least one of the OR gates has a "O" signal at this output. ## Scanning for "0" signal status | Original | STEP 5 repre | esentation | | |--------------------------|------------------------------|---------------------|------------------------------------------| | • | Statement<br>list | Ladder<br>diagram | Control system<br>flowchart | | I1.5 I1.6 I1.5 I1.5 Q2.0 | A I 1.5<br>ANI 1.6<br>= Q2.Ø | I 1.5 Q2 0<br>I 1.6 | I1.5———————————————————————————————————— | A "1" signal appears at output Q 2.0 only when input I 1.5 has a "1" signal and input I 1.6 a "0" signal. #### 5.1.2 Setting/resetting operations #### RS flip-flop for latched signal outputs | Original | STEP 5 repr | STEP 5 representation | | | | |-------------------------------|-----------------------------------------------------|-----------------------|-----------------------------|--|--| | | Statement<br>list | Ladder<br>diagram | Control system flowchart | | | | I1.4 I1.7 I1.4 I1.7 Q1.5 Q1.5 | A I 1.7<br>S Q 1.5<br>A I 1.4<br>R Q 1.5<br>NOP 6)* | I 1.7 Q 1.5 | Q 1.5 I 1.7 — S I 1.4 — R Q | | | | | | | | | | | | | | | | | A "1" at signal I 1.7 sets the flip-flop. If the signal at input I 1.7 changes to "O", this status is maintained, i.e. the signal is latched. A "1" at input I 1.4 resets the flip-flop. If the signal at input I 1.4 changes to "O", this status is maintained. If the set (input I 1.7) and reset (input I 1.4) signals are applied simultaneously, the scan operation last programmed (in this case AI 1.4) remains effective during processing of the remaining program. \*NOP 0 is only necessary if program is to be represented in LAD or CSF form on the 670/675 programmer. When programming with LAD or CSF, these NOP 0 operations are automatically included. ## RS flip-flop with flags | Original | STEP 5 representation | | | | |-----------------------------|----------------------------------------------------------------|-------------------|-------------------------------------|--| | | Statement<br>list | Ladder<br>diagram | Control system flowchart | | | I1.3 I1.6<br>F 1.7<br>F 1.7 | A I 1.3<br>R F 1.7<br>A I 1.6<br>S F 1.7<br>A F 1.7<br>= Q 1.4 | I 1.3 F 1.7 | F 1.7 I 1.3 — R I 1.6 — S Q — Q 1.4 | | A "1" at input I 1.6 sets the flip-flop. If the signal at input I 1.6 changes to "0", this status is maintained, i.e. the signal is latched. A "1" at input I 1.3 resets the flip-flop. If the signal at input I 1.3 changes to "O", this status is maintained. If the set (input I 1.6) and reset (input I 1.3) signals are applied simultaneously, the scanning operation last programmed (in this case AI 1.6) remains effective during processing of the remaining program, i.e. flag F 1.7 is set (setting signal has priority over the resetting signal). ## Implementation of a transition-sensitive pulse (pulse edge evaluation) | Original | STEP 5 representation | | | |------------------------|---------------------------------------------------------------------------|------------------------------|---------------------------------------| | | Statement<br>list | Ladder<br>diagram | Control system<br>flowchart | | 11.7<br>F 2.0<br>F 2.0 | A I 1.7<br>ANF 4.0<br>= F 2.0<br>A F 2.0<br>S F 4.0<br>ANI 1.7<br>R F 4.0 | I17F4.0 F 2.0 F 4.0 3 [-]/[ | F.2.0 F4.0 F4.0 F4.0 F4.0 I 1.7 - R 0 | The AND logic condition (AI 1.7 and AN F 4.0) is fulfilled at each positive-going edge of the signal at input I 1.7 and flags F 4.0 and F 2.0 ("Pulse edge flags") are set if the result of the logic operation (RLO) is "1". The AND logic condition AI 1.7 and AN F 4.0 is no longer fulfilled at the next program scan since flag F 4.0 has been set. Flag 2.0 is reset, i.e. it is only "1" during a single program pass or scan. ## Binary scaler (T or trigger flip-flop) | Original | STEP 5 repr | resentation | | |-------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------| | | Statement<br>list | Ladder<br>diagram | Control system flowchart | | I 1.0<br>I 1.0<br>Q 1.0 | A I 1.0<br>ANF 1.0<br>S Q 1.0<br>A I 1.0<br>A F 1.0<br>R Q 1.0<br>NOP 0<br>ANI 1.0<br>A Q 1.0<br>S F 1.0<br>ANI 1.0<br>ANI 1.0<br>ANI 1.0<br>ANI 1.0 | I 1.0 F 1.0 Q 1.0 I 1.0 F 1.0 R I 1.0 Q 1.0 F 1.0 I 1.0 Q 1.0 F 1.0 I 1.0 Q 1.0 R | I 1.0 — & Q 1.0 5 I 1.0 — & R F 1.0 — F 1.0 5 I 1.0 — & F 1.0 5 I 1.0 — & R I 1.0 — & R I 1.0 — R Q 1.0 — R | Output Q 1.0 changes its state on a positive-going transition at input 1.0. A negative-going change at the input has no effect on the output. If a defined frequency is applied to the input, therefore, half the input frequency appears at the output. #### 5.1.3 Load and transfer operations #### Load and transfer | Oper-<br>ation | Parameters | Function | |--------------------|-----------------------|-----------------------------| | L 00 | | Load | | <b></b> | | | | ΙB | 0 to 5 | an input byte | | • | | (from PII <sup>1</sup> ) | | I W | 0 to 4 | an input word<br>(from PII) | | QB | 0 to 3 . | an output byte | | Q D | 0 60 3 . | (from PIO <sup>2</sup> )) | | QW | 0 to 2 | an output word | | ٧ " | """ | (from PIO) | | FΒ | 0 to 63 | a flag byte | | FW | 0 to 62 | a flag word | | DR | 1 to 255 | data | | | | (right-hand byte) | | DL | 1 to 255 | data | | | | (left-hand byte) | | D W | 1 to 255 | data | | | | (word) | | PΒ | 0 to 5 | a peripheral byte | | | | of the digital I/O | | | | modules (bypassing | | | | the PIO) | | T | 0 to 15 | a time (binary) | | ÇT | 0 to 15 | (BCD) | | C | 0 to 15 | a count (binary) | | CC<br>KM3) | 0 to 15 | (BCD) | | KW2) | random bit | a constant as | | 31 | (16 bits) | bit pattern | | K H3) | 0 to FFFF | a constant in | | K F3) | | hexadecimal code | | K Fo | - 32768 to | a constant as | | <sub>Κ Υ</sub> 3) | + 32767 | fixed-point number | | K Yo | 0 to 255<br>for each | a constant, | | | | 2 bytes | | κ s <sup>3)</sup> | byte<br>2 random | a constant, 2 ASCII | | K 3 | | | | | alpha- | characters | | | numeric<br>characters | | | к т <sup>3)</sup> | 0.0 to | a time (constant) | | | 999.3 | a cime (constant) | | κ c <sup>3</sup> ) | 0 to 999 | a count (constant) | | | 1 0 00 333 | a count (constant) | Note The programmable controller has two accumulators (16 bits) for relational and arithmetic operations and for digital logic. Loading implies that the contents of accumulator 1 are relocated to accumulator 2 and that accumulator 1 is reloaded in keeping with the operand of the load operation. After two load operations, therefore, information can be obtained, for example, on the contents of the accumulators in connection with relational or comparison operations. The transfer operation always transfers the contents of accumulator 1 to the operand specified in the transfer operation. The contents are not changed. | Oper-<br>ation | Parameters | Function | |----------------|------------|------------------------------| | † 🗆 🗅 | | Transfer | | I B | 0 to 5 | an input byte (from PII 1) | | I W | 0 to 4 | an input word | | QB | 0 to 3 | an output byte (from PIO 2)) | | QW | 0 to 2 | an output word<br>(from PIO) | | FB | 0 to 63 | a flag byte | | FB | 0 to 62 | a flag word | | DR | 1 to 255 | data<br>(right-hand byte) | | DL | 1 to 255 | data (left-hand<br>byte) | | D₩ | 1 to 255 | data (word) | Load and transfer operations are absolute operations, i.e. they are carried out independently of the result of the previous logic operation. Graphics programming of load and transfer operations is only possible indirectly in connection with timer and counter operation, otherwise only in statement lists. When loading/transferring FW, IW and QW, the following relationship between the accumulator contents and the byte belonging to a particular word applies: When loading an FB, IB, QB or PB, the byte is always loaded in the low byte of the accumulator. O is written into the high byte of the accumulator. When transferring an FB, IB, QB or PB, it is always the low byte of the accumulator that is transferred. - 1) PII process image of inputs - PIO process image of outputs Four-byte instruction with the opcode in bytes 0/1 and the constant in bytes 2/3 # Loading and transferring a time (see also under timer and counter operations) During graphic input, FW 20 was assigned to output BI of the timer. The programmer automatically stores the corresponding load and transfer operation in the user program. In this way, the contents of the memory location addressed with T 10 are loaded into accumulator 1. The contents of accumulator 1 are then transferred to FW 20. The time T10 in binary code in this example can be traced at FW 20. Outputs BI and DI are digital outputs. The time appears in binary code (BCD with time base) at output BI (DE). #### 5.1.4 Timer functions #### **Pulse** Timers are restarted on power recovery following a powerfail condition. | Original | STEP 5 repre<br>Statement<br>list | sentation<br>Ladder<br>diagram | Control system<br>flowchart | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------------------------|------------------------------------------------| | $ \begin{array}{c} I2\emptyset \\ \downarrow I2\emptyset \\ \downarrow I2\emptyset \\ \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I2\emptyset \\ \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I2\emptyset \\ \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I20 \end{array} $ $ \begin{array}{c} \downarrow I20 \end{array} $ | A I 2.0<br>L KT10.2<br>SPT 1<br>NOP 0<br>NOP 0<br>NOP 0<br>A T 1<br>= Q 1.0 | I 2.0 T1 KT102- cv a1 DE - Q1.0 | T1 I 2.0 — 1.1. KT10.2 — CV BI — DE — R Q 1.0 | The timer is started during the first scanning cycle if the result of the logic operation is "1". The timer remains unaffected during subsequent scanning resulting in "1" signal. The timer is set to "0" (reset) if the result of the logic operation is "0". The AT and OT scans result in a "1" signal as long as the timer is running. The timer is loaded with the specified value (10). The number to the right of the point indicates the time base: 0 circle 0.01 circle s 2 circle 1 circle s 1 circle 0.1 circle s 3 circle 10 circle s BI and DE are digital outputs. The time appears at output BI (DE) in BCD. ## **Extended pulse** | Original | STEP 5 repres<br>Statement<br>list | sentation<br>Ladder<br>diagram | Control system<br>flowchart | |----------------|--------------------------------------------------------------------------|--------------------------------|------------------------------------------------------| | I 2.0. R S T1 | A I 2.0<br>L KT10.2<br>S ET1<br>NOP0<br>NOP0<br>NOP0<br>A T 1<br>= Q 1.0 | I 2.0 T1 | T1 I 2.0 — 1.1 V KT10.2 — CV BI — DE — R Q — Q1.0 | The timer is started during the first scanning cycle if the result of the logic operation is "1". The timer remains unaffected if the result of the logic operation is "0". The AT or OT scan results in a "1" signal as long as the timer is running. #### "ON" delay The timer is started during the first scanning cycle if the result of the logic operation is "1". The timer remains unaffected during subsequent processing if the result of the logic operation is "1". The timer is set to "0" (reset) if the result of the logic operation is "0". The AT or OT scan results in a "1" signal when the time has elapsed and the result of the logic operation is still present at the input. The timer is loaded with the specified value (9). The number to the right of the point indicates the time base: 0 circ 0.01 circ s 2 circ 1 circ s 2 circ 1 circ s 1 circ s 3 circ 10 circ s Outputs BI and DE are digital outputs. The time appears at output BI (DE) in BCD. ## Latching "ON" delay | Original | STEP 5 repres<br>Statement<br>list | entation<br> Ladder<br> diagram | Control system<br>flowchart | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------|-----------------------------------|--------------------------------------------------------| | I 1.6 I 1.5 T 4 I 1.6 | A I 1.5<br>L KT9.2<br>S ST4<br>A I 1.6<br>R T 4<br>NOP 0<br>NOP 0<br>A T 4<br>= Q 1.3 | I 1.5 | T4 I1.5 — T — s KT9.2 — CV BI — DE — I1.6 — R Q — Q1.3 | The timer is started during the first scanning cycle if the result of the logic operation is "1". The timer is unaffected if the result of the logic operation is "O". The AT or OT scans result in a "1" signal when the time has elapsed. The signal status only becomes "0" if the timer is reset with the RT operation. ## "OFF" delay The timer is started during the first scanning cycle if the result of the logic operation is "O". The timer remains unaffected during subsequent processing if the result of the logic operation is "O". The timer is set to "0" (reset) if the result of the logic operation is "1". The A T or OT scan results in a "1" signal if the timer is running or if the result of the logic operation is still present at the input. The timer is loaded with the specified value (9). The number to the right of the point indicates the time base: $0 \cong 0.01 \text{ s}$ $2 \cong 1 \text{ s}$ 0 = 0.01 s 2 = 1 s 1 = 0.1 s 3 = 10 s Outputs BI and DE are digital outputs. The time appears at output BI (DE) in BCD. #### Clock pulse generator A clock pulse generator can be constructed from a self-clocking timer with a T flip-flop (binary scaler) at its output. Timer T 7 is restarted with flag F 2.0 each time its time elapses, i.e. flag F 2.0 has a "1" signal for one cycle each time the time elapses. These pulses from flag F 2.0 act on the following T flip-flop with the result that a pulse train with a mark-space ratio of 1:1 appears at output 0.6. The period duration of this pulse train is twice as great as the time of the self-clocking timer. #### 5.1.5 Counter functions #### Set counter Counters 8 to 15 are restarted on power recovery following a powerfail condition | Original | STEP 5 representation | | | |-------------------------------|------------------------------|-------------------|-------------------------------------| | | Statement<br>list | Ladder<br>diagram | Control system flowchart | | I 21 KC1500 RS CZ Binary 16b | A I 2.1<br>L KC 15Ø<br>S C 1 | C 1 | I 2.1 — S KC 150 — CV BI — DE — R Q | The counter is set during the first scanning cycle if the result of the logic operation is "1". The counter remains unchanged during subsequent processing (irrespective of whether the result of the logic operation is "1" or "0"). The counter is set again (pulse edge evaluation) at the next first scanning cycle if the result of the logic operation is "1". In the above example, the starting value of the counter is 150. BI and DE are digital outputs. The count appears at output BI (DE) in BCD. #### **Reset counter** | Original | STEP 5 representation | | | |------------------------------|--------------------------------------|-------------------------------------|----------------------------------| | | Statement<br>list | Ladder<br>diagram | Control system<br>flowchart | | I 1.2 R S CI Binary 20 24 | A I 1.2<br>R C 1<br>A C 1<br>= Q Ø.4 | C 1 -CU -CP -S -CV BI -I12 -R Q-() | CU -CU -CD -S -CV BI -DE -R -QQ4 | The counter is reset when the result of the logic operation is "1". The counter remains unchanged if the logic operation becomes "O". ## **Counting up** | Original | STEP 5 representation | | | |------------------------------------------------------|---------------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------| | | Statement<br>list | Ladder<br> diagram | Control system flowchart | | I 1.1 KCØ18 R 5 CI Binary 16b Q1.0 | A I 2.1<br>CUC 1<br>LOP 0<br>A I 1.1<br>LKC 018<br>S C 1<br>LOP 0<br>A C 1<br>= Q 1.0 | I 2.1 C 1 | C 1 I 2.1 — CU CD I 1.1 — S KC \$18— CV & BI — DE — R -R & Q — Q 1.\$ | The value of the addressed counter is incremented by 1. The CU function is effective only on a positive-going pulse edge (from "O" to "1") of the result of the logic operation programmed before CU. A counter with two different inputs can be used as an up/down counter by means of the two separate pulse-edge flags for CU and CD. ## **Counting down** | Original | STEP 5 representation | | | |-----------------------------------------|---------------------------------------------------------------------------------------------------------------|---------------------------------------------------|--------------------------------------------------------------------------------| | | Statement | Ladder | Control system | | | list | diagram | flowchart | | I 2.0 KC 925 I 10 Binary 16 b F 10.0 | A I 1.00<br>CDC 1<br>NOP 0<br>A I 2.00<br>LKC 025<br>S C 1<br>A I 2.1<br>R C 1<br>NOP 0<br>A C 1<br>= F 10.00 | I 1.0 C 1 I 2.0 CU I 2.0 CV BI I 2.1 PE F10.0 | I 1.0 - CD<br>- CU<br>I 2.0 - S<br>KC 925 - CV BI - DE -<br>I 2.1 - R Q F 10.0 | The value of the addressed counter is decremented by 1. The CD function is effective only on a positive-going pulse edge (from "0" to "1") of the logic operation programmed before CD. A counter with two different inputs can be used as an up/down counter by means of the two separate pulse-edge flags for CU and CD. #### 5.1.6 Comparison (relational) operations #### Comparing for equal to | Original | STEP 5 repro<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | |----------------------------|-----------------------------------|-------------------------------------------|--------------------------------------| | IB 0 IB 1 C1 C2 = Q 1.0 | L IB0<br>L IB1<br>!=F<br>= Q1.0 | IB0 - C1 F<br>!= Q1.0<br>IB1 - C2 Q - (:) | IB 0 - C1 F<br>!=<br>IB1 - C2 Q-Q1.0 | The operand first specified is compared with the subsequent operation in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | cco | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 1 | | IB 0 < IB 1 | 0 | 1 | 0 | | IB 0 > IB 1 | 1 | 0 | 0 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpeted as being fixed-point numbers. After a comparison for equal to, a jump can be made to a label (+127 words) with the jump operation $JZ = \dots$ (if RLO = 1). ## Comparing for not equal to | Original | STEP 5 repr<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | | |----------|-----------------------------------------|-------------------------------------|---------------------------------|--| | IBØ IB1 | L IB0<br>L IB1<br>> <f<br>= Q1.1</f<br> | IB0 - C1 F >< Q1.1 | IB0 - C1 F >< IB1 - C2 Q - Q1.1 | | The operand first specified is compared with the subsequent operand in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | CC0 | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 0 | | IB 0 < IB 1 | 0 | 1 | 1 | | IB 0 > IB 1 | 1 | 0 | 1 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpreted as being fixed-point numbers. Following a comparison for not equal to, a jump can be made to a label $(\pm 127 \text{ words})$ with the jump operation JN = ... (if RLO = 1). #### Comparing for greater than | Original | STEP 5 repr<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | |----------------|----------------------------------|------------------------------------------|--------------------------------------| | IB0 IB1 C1 C2 | L IB0<br>L IB1<br>> F<br>= 0.1.2 | IB0 — C1 F<br>> Q1.2<br>IB1 — C2 Q — ()— | IB0 - C1 F<br>><br>IB1 - C2 Q - Q1.2 | The operand first specified is compared with the subsequent operand in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | CCO | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 0 | | IB 0 < IB 1 | 0 | 1 | 0 | | IB 0 > IB 1 | 1 | 0 | 1 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpreted as being fixed-point numbers. After a comparison for greater than, a jump can be made to a label ( $\pm$ 127 words) with the jump operation $\overline{JP}$ = ... (if RLO = 1). ## Comparing for less than | Original | STEP 5 repr<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | |--------------------------------|----------------------------------|-------------------------------------|--------------------------------| | IBØ IB1 C1 C2 ≥ > = < Q1.4 | L IB 0<br>L IB1<br>< F<br>= Q1.4 | IB0-C1 F < Q1.4 IB1-C2 Q-() | IB0 - C1 F < IB1 - C2 Q - Q1.4 | The operand first specified is compared with the subsequent operand in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | CCO | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 0 | | IB 0 < IB 1 | 0 | 1 | 1 | | IB 0 > IB 1 | 1 | 0 | 0 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpreted as being fixed-point numbers. After comparing for less than, a jump can be made to a label ( $\pm$ 127 words) with the jump operation $\overline{JM} = ...$ (if RLO = 1). #### Comparing for greater than or equal to | Original | STEP 5 repr<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | |-----------------------------|----------------------------------|-------------------------------------|---------------------------------| | IBO IB1 C1 C2 > = < Q1.3 | L IB0<br>L IB1<br>>=F<br>= Q1.3 | IB0-C1 F<br>>= Q1.3<br>IB1-C2 Q-()- | IB0-C1 F<br>>=<br>IB1-C2 Q-Q1.3 | The operand first specified is compared with the subsequent operand in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | CCO | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 1 | | IB 0 < IB 1 | 0 | 1 | 0 | | IB 0 > IB 1 | 1 | 0 | 1 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpreted as being fixed-point numbers. After comparison for greater than or equal to, a jump can be made to a label (+ 127 words) with the jump operation $J\overline{C}$ (if RLO = 1 ). #### Comparing for less than or equal to | Original | STEP 5 repr<br>Statement<br>list | esentation<br> Ladder<br> diagram | Control system<br>flowchart | |----------------|----------------------------------|------------------------------------------|-------------------------------------| | IBØ IB1 C1 C2 | L IB0<br>L IB1<br><=F<br>= Q1.5 | IB0 — C1 F<br><= Q1.5<br>IB1 — C2 Q — () | IB0 - C1 F<br><=<br>IB1 - C2 Q-Q1.5 | The operand first specified is compared with the subsequent operand in keeping with the comparison function. The result of the comparison is flagged by condition codes CCO and CC1. | for | CC1 | cco | RLO | |-------------|-----|-----|-----| | IB 0 = IB 1 | 0 | 0 | 1 | | IB 0 < IB 1 | 0 | 1 | 1 | | IB 0 > IB 1 | 1 | 0 | 0 | The numerical representation of the operands is taken into account, i.e. the contents of the accumulators are interpreted as being fixed-point numbers. After comparing for less than or equal to, a jump can be made to a label $(\pm 127 \text{ words})$ with the jump operation JC = ... (if RLO = 1). #### 5.1.7 Arithmetic operations Arithmetic operations can only be represented in statement list form. They add or subtract the contents of accumulators 1 and 2, using the corresponding load operations. | Operation | Parameters | Function | |-----------|------------|---------------------------------| | + F | | Add<br>(accu. 1 + accu.2) | | - F | | Subtract<br>(accu. 2 - accu. 1) | The two accumulators 1 and 2 can be loaded by two load operations in keeping with the operands of these load operations. The contents of the two accumulators can then be added to each other or one subtracted from the other. | Example: | L IW1 | Accu 1 → Accu 2<br>→ IW1 Accu 1 | |----------|-------|-----------------------------------------------------------------------------------------------------| | | L IW2 | $ \begin{array}{c} W1 \longrightarrow W1 \\ \longrightarrow W2 \longrightarrow W1 \end{array} $ | | | - F | IW1- IW2 = Result | | | | Accu 1 | | Example | STL | Explanation | |-------------------------------------------------------------------------------------------------------------------------------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | The right-hand byte of data word 85 is to be subtracted from the number +127 and the result stored in the left-hand byte of data word 85. | L KF +127 | The constant fixed-point number +127 is loaded into accumulator 1; at the same time, the old contents of accumulator 1 are shifted into accumulator 2. The right-hand byte of data word 85 is loaded into accumulator 1 and the fixed-point number +127 | | DR 85 74<br>Result F 53 | T DL 85 | shifted into accumulator 2. The contents of accumulator 1 are subtracted from those of accumulator 2 and the result stored in accumulator 1. The contents of accumulator 1 (result) are transferred to the left-hand byte of data word 85. | #### Note: If the number range (-32768 to + 32767) is exceeded, the result of the operation is undefined (OV = "1") #### 5.1.8 Other functions The following operations can only be represented in statement list form. | Operation | Parameter | Function | |-----------|-----------|------------------------------------------| | STP | | Stop | | NOP O | , | No operation<br>(all bits reset) | | N O P 1 | | No operation (all bits set) | | 3 L D | 0 to 255 | Display con-<br>struction state-<br>ment | The STOP operation is used if, for example, the programmable controller has to enter the Stop status in response to certain critical plant states or on the occurrence of a hardware fault. The display construction statement defines the subdivision of program sections into segments within a block. # 5.2 Supplementary operations Supplementary operations can only be programmed in FB 1. ## 5.2.1 Logic operations | Operation | Description | |-----------|---------------------------------------------| | AW | Digital ANDing of accumul-<br>ators 1 and 2 | | OW | Digital ORing of accumulators 1 and 2. | | X OW | Digital EXORing of accumulators 1 and 2. | Accumulators 1 and 2 can be loaded by two load operations in keeping with the operands of these load operations. The contents of both accumulators can then be digitally gated. | Example | STL | Explanation | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | The hexadecimal number 3F84 <sub>H</sub> is to be ANDed with input word 1 of inputs IW 1. The result is to appear in output word zero of the outputs (QW 0). 3F84 <sub>H</sub> IW 1 4793 <sub>H</sub> Result AW 0780 <sub>H</sub> | L KH 3F84 L IW 1 AW T QW 0 | The hexadecimal number 3F84 is loaded into accumulator 1; at the same time, the old contents of accumulator 1 are shifted into accumulator 2. Input word 1 (IW 1) is loaded into accumulator 1 and the hexadecimal number shifted into accumulator 2. The contents accumulator 1 are digitally ANDed with those of accumulator 2 and the result stored in accumulator 1. The contents of accumulator 1 (result) are transferred to output word QW 0. | | The two bit patterns 0101 1110 1000 1011 and 0111 0001 0111 1100 are to be ORed with each other. | L KM 0111 L KM 0100 | The first bit pattern is loaded into accumulator 1; at the same time, the old contents of accumulator 1 are shifted into accumulator 2. The second bit pattern is loaded into accumulator 1 and the first bit pattern shifted into accumulator 2. The contents of accumulator 1 are ORed with those of accumulator 2 and the result stored in accumulator 1. | | 0101 1110 1000 1011<br>0111 0001 0111 1100<br>Result 0111 1111 1111 1111<br>OW | T FW 13 | The contents of accumulator 1 (result) are transferred to flagword FW 13. | | Input word IW 0 is to be compared with data-word 12 for equality. The non-identical bits of the word are to appear in output | L DW 12 L IW 0 | Data word DW 12 is loaded into accumulator 1; at the same time, the old contents of accumulator 1 are shifted into accumulator 2. Input word IW 0 is loaded into accumulator 1 and data word L DW 12 shifted into accumulator 2. | | word QW 0. DW 12 EA83 IW 0 68C5 Result XOW 8246 | TQW 0 | The contents of accumulator 1 are EXORed with those of accumulator 2 and the result stored in accumulator 1. The contents of accumulator 1 (result) are transferred to output word QW 0. | ## 5.2.2 Conversion functions | Operation | Description | |-----------|------------------------------------------------------------------------------------------| | CFW | One's complement | | CSW | Two's complement | | | The value in accumulator 1 is converted. The result can be processed in the accumulator. | | Example | STL | Explanation | |-----------------------------------------------------------------------------------------|---------|---------------------------------------------------------------------------------------------| | The contents of data word DW 64 are to be inverted bit by bit and stored in | L DW 64 | Load data word DW 64 into accumulator 1. | | data word DW 78. DW 64 EA83 | CFW | Form the one's complement of the contents of accumula- tor 1. The result is in | | DW 64 EA83 <sub>H</sub><br>DW 78 157C <sub>H</sub> | T DW 78 | accumulator 1. Transfer the contents of accumulator 1 into data word DW 78. | | The contents of data word<br>DW 42 are to be interpreted<br>as a fixed-point number and | L DW 42 | Load data word DW 42 into accumulator 1. | | stored in data word DW 35 with inverted sign. | CSW | Form the two's complement of the contents of accumulator 1. The result is in accumulator 1. | | DW 42 +51<br>DW 35 -51 | T DW 35 | Transfer the contents of accumulator 1 into data word DW 35. | ## 5.2.3 Shift operations | Operation | Description | |-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | SLW 0 to 15 | Shift left | | SRW 0 to 15 | Shift right | | | The parameter of this statement specifies the number of bit positions by which the contents of accumulator 1 are shifted to the left (SLW) or to the right (SRW). Any bit positions that become free when shifting are padded with zeros. | | Example | STL | Explanation | |---------------------------------------------------------------------------------------------------|--------|----------------------------------------------------------------------------------------------------------------------------------| | The last four bits of the hexadecimal number 14AF, in data word DW 1 are to | L DW 1 | Load data word 1 into accu-<br>mulator 1. | | be truncated and the new hexadecimal number 014A <sub>H</sub> resulting stored in data word DW 3. | SR W 4 | Shift the contents of accumulator 1 four bit positions to the right. The bit positions that become free when shifting are padded | | | T DW 3 | with zeros. Transfer the contents of accumulator 1 to data word DW 3. | Note: Shift operations are unconditional operations. The last bit shifted out can be examined by means of a jump operation. A jump can be made with JZ if the bit is "0" and with JN or JP if the bit is "1". #### 5.2.4 Jump operations The jump destination for unconditional and conditional jumps is specified as a symbolic address (max. 4 characters). In the case of the PG 605U/ and PG 615U programmers, jump labels MO...M99 can be assigned. The symbolic parameter of the jump statement is identical to the symbolic address of the statement to which the jump is made. When programming, make sure that the absolute jump displacement does not exceed +127 words and note that a STEP 5 statement may consist of more than one word. Jumps over segment boundaries are not permissible. All jump operations (with the exception of JU) depend on the RLO and the condition codes in the processor of the programmable controller. | Operation | Doggination | |-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | Description | | JU = [] | Unconditional jump The unconditional jump | | | is executed independent-<br>ly of any conditions. | | JC = | Conditional jump | | | The conditional jump is executed if the RLO is "1". If the result of the logic operation is "0", the jump is not executed and the RLO is set to "1". | | JZ = | Jump if contents of accumulator zero. | | | This jump is executed if the contents of the accumulator are zero. If the contents are not zero, the jump is not executed. The RLO is not changed. | | JN [] | Jump if contents of accumulator not zero. | | | This jump is executed if the contents of the accumulator are not zero. If the contents are zero, the jump is not executed. The RLO is not changed. | | JP = | Jump if contents of accumulator positive. | | | The jump is executed if the contents of the accumulator are greater than zero. If the contents of the accumulator are zero or less than zero, the jump is not executed. The RLO is not changed. | | JM = | Jump if contents of accumulator negative. | | | This jump is executed if the contents of the accumulator are less than zero. If the contents are zero or greater than zero, the jump is not executed. The RLO is not changed. | | J0 = | Jump on overflow | | | This jump is executed when an overflow occurs. If there is no overflow, the jump is not executed. The RLO is not changed. | | | Enter symbolic address (max. 4 characters) | | Example | STL | Explanation | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | If none of the inputs of input word IW 1 is set, a jump is made to label "AN 1" If the input word IW 1 and output word QW 0 are not identical, a jump is made back to label "AN 0". If IW 1 and QW 3 are identical, IW 1 is compared with data word DW 12. If IW 1 is greater or smaller than DW 12, a | ANO : IW : JZ=AN1 : A IW . | Input word IW 1 is loaded into accumulator 1. If the contents of accumulator 1 are equal to zero, a jump is executed to label "AN 1", otherwise the next statement (AI 1.0) is executed. | | jump is made to the "Destination" label. | AN1.:L IW1 :L QW :XOW :JP=AN0 :L IW1 :L DW12 : F | Comparison of input word IW 1 and output word QW3. If the two words are not identical, individual bits are set in accumulator 1. If the contents of accumulator 1 are not zero, a jump is made back to the "AN 0" label, otherwise the next statements are executed. Input word IW 1 is compared with data word W 12 for greater or less than. If IW 1 is greater or less | | | :JB=Destina-<br>tion | than DW 12, the RLO is set to "1". If RLO = "1", a jump is made to the "Destination" label. If RLO = "0", the next statement is executed. | #### Condition codes 5.2.5 The processor of the SIMATIC S5-101U programmable controller has three condition codes: o CC 1 Value positive o CC O Value negative o OVF Overflow The condition codes are affected by comparison operations, arithmetic operations, shift operations and a number of conversion operations. Generating condition codes in connection with comparison operations The execution of comparison operations results in the setting of condition codes CC 0 and CC 1. The overflow bit is not affected. The two operands participating in a comparison are defined as follows: Example :L DW20 (1st operand) :L DW21 (2nd operand) :!=F (comparison operation) In this example, data word DW 20 is the 1st operand and data word DW 21 the 2nd operand. | | Condi<br>codes | | Jump<br>operations | |---------------------------------------------------------------|----------------|------|--------------------------------------------------| | Compared with<br>the 1st oper-<br>and, the 2nd<br>operand is: | CC 1 | сс о | The following jump oper-<br>ations are executed: | | Equal | 0 | 0 | JZ | | Less | 0 | 1 | JN, JM | | Greater | 1 | 0 | JN, JP | #### Note: Comparison operations affect the result of the logic operation. If the condition is satisfied, the RLO is "1". In this way, the conditional jump operation JB can be written after a comparison operation. Generating condition codes in connection with arithmetic operations. Arithmetic operations result in the setting of all condition codes. This depends in turn on the contents of the accumulator (the result of the arithmetic operation). Generating condition codes in connection with fixed-point arithmetic operation: | | Conc | litio | n | Jump<br>operations | |--------------------------------------------|------|-------|----|--------------------------------------------------| | The result of the arithmetic operation is: | CC1 | ссо | ov | The following jump oper-<br>ations are executed: | | < -32768 | 1 | 0 | 1 | JN, JP, JO | | -32768 to - 1 | 0 | 1 | 0 | JN, JM | | 0 | 0 | 0 | 0 | JZ | | +1 to +32767 | 1 | 0 | 0 | JN JP | | > +32767 | 0 | 1 | 1 | JN, JM, JO | | (-)65536*) | 0 | 0 | 1 | JZ, JO | <sup>\*)</sup> Result of the arithmetic operation: -32768 +32768 Generating condition codes in connection with digital logic. Digital logic operations result in the setting of condition codes CC 0 and CC 1. The overflow bit is not affected. Setting of the condition codes depends on the contents of the accumulator after the operation has been executed. | | Cond<br>code | ition<br>s | Jump<br>operations | |--------------------------------------|--------------|------------|--------------------------------------------------| | The contents of the accumulator are: | | | The following jump oper-<br>ations are executed: | | | CC1 | cco | | | Zero (0000) | 0 | 0 | JZ | | Not zero | 1 | 0 | JN, JP | Generating condition codes in connection with shift operations. The execution of shift operations results in the setting of CC O and CC 1. The overflow bit is not affected. Setting of the condition codes depends on the status of the last bit pushed | | Cond | iition<br>≘s | Jump<br>operations | |-------------------------------------------|------|--------------|---------------------------------------------| | The value of the last bit shifted out is: | CC1 | ссо | The following jump operations are executed: | | "0" | 0 | 0 | JZ | | "1" | 1 | 0 | JN, JP | Generating condition codes in connection with conversion functions. Formation of the two's complement (CSW) affects all condition codes. This depends on the result of the conversion operation: | | Conc | litio<br>es | n | Jump<br>operations | |-----------------------------------------------|------|-------------|----|---------------------------------------------| | The result after the conversion operation is: | CC1 | ссо | ov | The following jump operations are executed: | | < -32768 | 1 | 0 | 1 | JN, JP, JO | | -32768 to -1 | 0 | 1 | 0 | JN, JM | | +1 to +32767 | 1 | 0 | 0 | JN, JP | | >+32767 | 0 | 1 | 1 | JN, JM, JO | | (-)65536*) | 0 | 0 | 1 | JZ, JO | <sup>\*)</sup> Result of conversion of KH = 0000 #### Note: The jump statement and jump destination must be in the same segment. Only one symbolic address is permissible for branch destinations in each segment. # 6. Operation set Binary logic operations | 0per | ^a <b>-</b> | Parameter | Mac | hine | code | | Dep- | Aff- | Cond | ition | | e e | Function | |------|-------------|--------------------------|-----|----------------|----------------|-------|------|-------|-------|-------|-----|--------------------------------|-----------------------------------------------------------------------------------| | tion | ı | · | (he | xadec. | imal) | | ends | ec ts | codes | | | n ti | | | | | | Wor | d 0 | Word | 1 1 | on | RLO | affec | ted | | utic<br>s (m | | | | | | В0 | B1 | B2 | В3 | RLO | | CC1 | CCO | ٥٧ | Execution time<br>in µs (max.) | | | | | | | | | • | | | | • | | • | Scan the following and AND with<br>the result of the previous logic<br>operation: | | Α | I | 0.0 to 2.3<br>3.0 to 5.3 | CO | 00 | - | - | N | N | - | - | - | 65 | Input for "1" | | Α | Q | 0.0 to 1.3<br>2.0 to 3.3 | СО | 80 | - | - | N | N · | - | - | - | 65 | Output for "1" | | Α | F | 0.0 to 63.7 | 80 | 00 | - | - | N | N | - | - | - | 74 | Flag for "1" | | Α | T | 0 to 15 | F8 | 00 | - | - | N | N | - | - | - | 69 | Timer for "1" | | Α | С | 0 to 15 | B8 | 00 | - | _ | N | N | - | - | - | 64 | Counter for " > 0" | | AN | I | 0.0 to 2.3<br>3.0 to 5.3 | EO | 00 | - | - | N | N | - | - | - | 66 | Input for "O" | | AN | Q | 0.0 to 1.3<br>2.0 to 3.3 | E0 | 80 | - | - | N | N | - | - | - | 66 | Output for "O" | | AN | F | 0.0 to 63.7 | AG | 00 | - | - | N | N | - | - | - | 75 | Flag for "O" | | AN | Т | 0 to 15 | FC | 00 | - | - | N | N | - | - | T - | 70 | Timer for "O" | | AN | C | 0 to 15 | BC | 00 | - | - | N | N | - | - | - | 65 | Counter for "=0" | | | | | | | | | | | | | | | Scan the following and OR with<br>the result of the previous logic<br>operation: | | 0 | I | 0.0 to 2.3<br>3.0 to 5.3 | C8 | 00 | - | - | N | N | - | - | - | 65 | Input for "1" | | 0 | Q | 0.0 to 1.3<br>2.0 to 3.3 | C8 | 80 | - | - | N | N | - | - | - | 65 | Output for "1" | | 0 | F | 0.0 to 63.7 | 88 | 00 | - | - | N | N | - | - | - | 74 | Flag for "1" | | 0 | T | 0 to 15 | F9 | 00 | - | - | N | N | - | - | - | 71 | Timer for "1" | | 0 | С | 0 to 15 | В9 | 00 | - | - | N | N | - | - | - | 64 | Counter for " > 0" | | ON | I | 0.0 to 2.3<br>3.0 to 5.3 | E8 | 00 | - | - | N | N | - | - | - | 66 | Input for "0" | | ON | Q | 0.0 to 1.3<br>2.0 to 3.3 | E8 | 80 | - | - | N | N | - | - | - | 66 | Output for "O" | | ON | F | 0.0 to 63.7 | A8 | 00 | - | - | N | N | - | - | - | 76 | Flag for "O" | | ON | T | 0 to 15 | FD | 00 | - | - | N | N | - | - | - | 72 | Timer for "O" | | ON | С | 0 to 15 | BD | 00 | - | - | N | N | - | - | - | 67 | Counter for "=0" | | | | | | + Re | lativ | e add | ress | | | | | | | | | | | | | | | | | | | | | • | | | | | + B | it <b>a</b> do | lr <b>es</b> s | | | | | | | | | | | | | | | | | | | | | | | | | ) | | | BF | 00 | - | - | N - | Y | _ | | - | 63 | Right paranthesis | | A( | | | BA | 00 | - | - | N | Y | - | - | - | 66 | ANDing of bracketed expressions | | 0( | | | BB | 00 | - | - | N | Y | - | - | - | 69 | ORing of bracketed expressions | | 0 | | | FB | 00 | - | - | N | Υ | - | - | - | 48 | ORing of AND operations | Up to 6 bracketing levels can be programmed. #### Setting/resetting operations | | a- | Parameter | | ine c | | | Dep- | Aff- | Condi | tion | | Execution time<br>in µs (max.) | Function | |-------------------------------------------------|-----------|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|----------------------------------------|---------------------------|---------|----------------------------------------|--------------|-----------------------|------------|----|----------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------| | tion | | | | adeci | | | ends | ects | codes | | l | io<br>ma | | | | | | Word | | Word | | on | RLO | affec | | | rs ecut | | | | | | В0 | B1 | B2 | В3 | RLO | | CC1 | cco | OV | Ϋ́E | | | | | | | | | | | | | | | | | | S | I | 0.0 to 2.3<br>3.0 to 5.3 | DO | 00 | - | - | Υ | Υ | - | - | - | 70 | Set an input to "1"<br>(in the (PII) | | S | Q | 0.0 to 1.3<br>3.0 to 3.3 | DO | 80 | - | - | Υ | Y | - | - | - | 70 | Set an output to "1"<br>(in the PIO) | | S | F | 0.0 to 63.7 | 90 | 00 | - | - | Y | Υ | - | - | - | 74 | Set a flag | | R | I | 0.0 to 2.3<br>3.0 to 5.3 | F0 | 00 | - | - | Υ | Y | - | - | - | 70 | Reset an input to "O"<br>(in the PII) | | R | Q | 0.0 to 1.3<br>2.0 to 3.3 | F0 | 80 | - | - | Y | Y | - | - | - | 70 | Reset an output to "O"<br>(in the PIO) | | R | F | 0.0 to 63.7 | В0 | 00 | - | - | Y | Y | - | - | - | 74 | Reset a flag to "O" | | = | I | 0.0 to 2.3<br>3.0 to 5.3 | D8 | 00 | - | - | N | Y | - | - | - | 66 | Assign an input<br>(in the PII) | | = | Q | 0.0 to 1.3<br>2.0 to 3.3 | D8 | 80 | - | - | N | Ŷ | - | - | - | 66 | Assign an output<br>(in the PIO) | | = | F | 0.0 to 63.7 | 98 | 00 | - | - | N | Y | - | - | - | 72 | Assign a flag | | | | | | | | | | | | | | | | | | | | + E | Sit ac | ldress | ] | · | | | | | | | | Timer | and | d counter funct | | Bit ac | ldress | ] | · | | | | | | | | | | d counter funct | ions | sit ac | | ] | Dep- | Aff- | Condi | tion | | ime ) | Function | | Timer<br>Oper<br>tion | a- | | ions<br>Mach | | ode | ] | Dep-<br>ends | Aff-<br>ects | Condi<br>codes | | | on time<br>max.) | Function | | 0per | a- | | ions<br>Mach | ine c | ode | | 1 | i | i | | | cution time<br>ps (max.) | Function | | 0per | a- | | ions<br>Mach<br>(hex | ine c | ode | | ends | ec ts | codes | ted | ov | Execution time in µs (max.) | Function | | 0per | a- | | ions Mach (hex | ine c | ode<br>mal)<br>Word | 1 | ends<br>on | ec ts | codes<br>affec | ted | OV | Execution time in µs (max.) | Function | | 0per | a- | | ions Mach (hex | ine c | ode<br>mal)<br>Word | 1 | ends<br>on | ec ts | codes<br>affec | ted | ov | Execution time in µs (max.) | Function Start timer as pulse | | Oper<br>tion | a – | Parameter | ions Mach (hex Word | nine c<br>kadeci<br>I O<br>B1 | ode<br>mal)<br>Word<br>B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes<br>affec<br>CC1 | ted<br>CCO | OV | | | | Oper<br>tion<br>SP<br>SE<br>SR | a- | Parameter 0 to 15 0 to 15 0 to 15 | Mach<br>(hex<br>Word<br>BO | nine cadeci | ode<br>mal)<br>Word<br>B2 | 1<br>B3 | ends<br>on<br>RLO<br>Y<br>Y | ects<br>RLO | codes<br>affec<br>CC1 | ted<br>CCO | OV | 134 | Start timer as pulse | | Oper<br>tion<br>SP<br>SE | a-<br>T | Parameter 0 to 15 0 to 15 | Mach<br>(hex<br>Word<br>BO | aine cadeci | ode<br>mal)<br>Word<br>B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes<br>affec<br>CC1 | ted<br>CCO | OV | 134<br>120 | Start timer as pulse<br>Start timer as extended pulse | | Oper<br>tion<br>SP<br>SE<br>SR | a - | O to 15<br>O to 15<br>O to 15<br>O to 15<br>O to 15 | Mach (hex Worc BO 1 1 1 2 4 2 C 1 4 | 00 00 00 | ode<br>mal)<br>Word<br>B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes<br>affec<br>CC1 | ted<br>CCO | OV | 134<br>120<br>136 | Start timer as pulse Start timer as extended pulse Start timer as "ON" delay Start timer as latching "ON" | | Oper<br>tion<br>SP<br>SE<br>SR<br>SS | | Parameter 0 to 15 | ions Mach (hex Worc BO 34 10 24 20 14 30 | 00 00 00 00 00 00 00 0 | ode<br>mal)<br>Word<br>B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes<br>affec<br>CC1 | ted<br>CCO | OV | 134<br>120<br>136<br>120 | Start timer as pulse Start timer as extended pulse Start timer as "ON" delay Start timer as latching "ON" delay Start timer as "OFF" delay Reset timer | | Oper<br>tion<br>SP<br>SE<br>SR<br>SS<br>SF<br>R | T T T T C | Parameter 0 to 15 | Mach<br> (hex<br> Worce<br> BO <br> 34<br> 1C<br> 24<br> 2C<br> 14<br> 3C<br> 5C | 00 00 00 00 00 00 00 00 00 00 00 00 00 | worde mal) Word B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes affec CC1 | | | 134<br>120<br>136<br>120 | Start timer as pulse Start timer as extended pulse Start timer as "ON" delay Start timer as latching "ON" delay Start timer as "OFF" delay | | Oper<br>tion<br>SP<br>SE<br>SR<br>SS<br>SF<br>R | a - | Parameter 0 to 15 | Mach<br> (hex<br> Word<br> BO | 00 00 00 00 00 00 00 00 00 00 00 00 00 | worde mal) Word B2 | 1<br>B3 | ends on RLO Y Y Y Y Y Y Y Y Y Y Y Y Y | ects<br>RLO | codes affec CC1 | cco | OV | 134<br>120<br>136<br>120<br>136<br>64<br>114<br>66 | Start timer as pulse Start timer as extended pulse Start timer as "ON" delay Start timer as latching "ON" delay Start timer as "OFF" delay Reset timer | | Oper<br>tion<br>SP<br>SE<br>SR<br>SS<br>SF<br>R | T T T T C | Parameter 0 to 15 | Mach<br> (hex<br> Worce<br> BO <br> 34<br> 1C<br> 24<br> 2C<br> 14<br> 3C<br> 5C | 00 00 00 00 00 00 00 00 00 00 00 00 00 | worde mal) Word B2 | 1<br>B3 | ends<br>on<br>RLO | ects<br>RLO | codes affec CC1 | cco | | 134<br>120<br>136<br>120<br>136<br>64<br>114 | Start timer as pulse Start timer as extended pulse Start timer as "ON" delay Start timer as latching "ON" delay Start timer as "OFF" delay Reset timer Set counter | + Relative address #### Load and transfer operations | Ope<br>tio | ra-<br>n | Parameter | | chine<br>xadec | | | Dep-<br>ends | Aff-<br>ects | Condi | | | Execution time<br>in µs (max.) | Function | |------------|----------|------------------------------|-----|----------------|-------|-------|--------------|--------------|-------|-----|----|--------------------------------|--------------------------------------| | | | | Wor | d 0 | Word | 1 | on | RLO | affec | ted | | cuti<br>ps ( | | | | | | В0 | B1 | B2 | В3 | RLO | | CC1 | CCO | 00 | in i | | | | | | | | | | | | | | | | | | L | IB . | 0 to 5 | 4A | 00 | - | - | N | Ņ | - | - | - | 61 | Load an input byte (from the PII) | | L | IW | 0 to 4 | 52 | 00 | - | - | N | N | - | - | - | 65 | Load an input word (from the PIO) | | L | QB | 0 to 3 | 4A | 80 | - | - | N | N | - | - | - | 61 | Load an output byte (from the PIO) | | L | QW | 0 to 2 | 52 | 80 | - | - | N | N | - | - | - | 65 | Load an output word (from the PIO) | | L | FB | 0 to 63 | OA | 00 | - | - | N | N | - | - | - | 61 | Load a flag byte | | L | FW | 0 to 62 | 12 | 00 | - | - | N | N | - | - | - | 67 | Load a flag word | | L | DL | 0 to 255 | 22 | 00 | - | - | N | N | - | - | - | 65 | Load data (left-hand byte) | | L | DR | 0 to 255 | 2A | 00 | - | - | N | N | - | - | - | 66 | Load data (right-hand byte) | | L | DW | 0 to 255 | 32 | 00 | - | - | N | N | - | - | - | 78 | Load data (word) | | L | T | 0 to 15 | 02 | 00 | - | - | N | N | - | - | - | 67 | Load a time | | L | С | 0 to 15 | 42 | 00 | - | - | N | N | - | - | - | 68 | Load a count | | L | PB | 0 to 5 | 72 | 00 | - | - | N | N | - | - | - | 116 | Load a peripheral byte of the inputs | | L | DT | 0 to 15 | 00 | 00 | - | - | N | N | - | - | - | 124 | Load a time (BCD) | | L | DC | 0 to 15 | 4C | 00 | - | - | N | N | - | - | - | 122 | Load a count (BCD) | | | | | | + Re | lativ | e add | ress | | | | | | | | L | KC | 2 alphanumeric<br>characters | 30 | 10 | 00 | 00 | N | N | - | - | - | 63 | 2 ASCII characters | | L | KM | Bit pattern<br>(16 bits) | 30 | 80 | 00 | 00 | N | N | - | - | - | 63 | as bit pattern | | L | KH | 0 to FFFF | 30 | 40 | 00 | 00 | N | N | | - | | 63 | in hexadecimal code | | L | KF | 0 to (2 <sup>16</sup> -1) | 30 | 04 | 00 | 00 | N | N | | | - | 63 | as a fixed-point number | | L | KY | O to 255,<br>each byte | 30 | 20 | 00 | 00 | N | N | - | - | - | 63 | 2 bytes | | L | KT | 0.0 to 999.3 | 30 | 02 | 00 | 00 | N | N | - | - | - | 63 | as time | | L | KC | 0 to 999 | 30 | 01 | 00 | 00 | N | N | - | - | - | 63 | as count | + Constant (1 word) | | | I | | | | | | | | | | | |---------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------|--------------------|--------------|-------|-------------------|---------------------------------------|---------------------|---------------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------| | Opera- | Parameter | Maso | chine | code | | Dep- | Aff- | Condi | tion | | ‡. | Function | | tion | | (he> | adeci | mal) | | ends | ects | codes | | l | Execution time<br>in µs (max.) | | | | | Word | 1 0 | Word | 1 | on | RLO | affec | ted | | ps ( | | | | | В0 | B1 | B2 | В3 | RLO | | CC1 | CCO | ٥٧ | i Exe | | | T IB | 0 to 5 | 4B | 00 | - | - | N | N | - | - | - | 55 | Transfer to an input byte (in the PII) | | T IW | 0 to 4 | 53 | 00 | - | - | N | N | , | - | - | 58 | Transfer to an input word (in the PII) | | T QB | 0 to 3 | 4B | 80 | - | - | N | N | - | - | - | 55 | Transfer to an output<br>(in the PIO) | | T QW | 0 to 2 | 53 | 80 | - | - | N | N | - | - | - | 58 | Transfer to an output word (in the PIO) | | T FB | 0 to 63 | OB | 00 | - | - | N | N | - | - | - | 52 | Transfer to a flag byte | | T FW | 0 to 62 | 13 | 00 | - | - | N | N | - | - | - | 61 | Transfer to a flag word | | T DR | 0 to 255 | 2B | 00 | - | - | N | N | - | - | - | 57 | Transfer to data<br>(right-hand byte) | | T DL | 0 to 255 | 23 | 00 | - | - | N | N | - | - | - | 54 | Transfer to data<br>(left-hand byte) | | T DW | 0 to 255 | 33 | 00 | - | - | N | N | - | - | - | 61 | Transfer to data (word) | | T PB | 0 to 3 | 73 | 00 | - | - | N | N | - | - | - | 90 | Transfer to peripheral<br>byte of outputs with updating<br>of the PIO | | | | | + Re | elativ | e ado | dress | | | | | | | | | | | | - | | | | | | | | | | Comparis | son operations | | | | | <b></b> | | | | | · · · · · · · · · · · · · · · · · · · | _ | | Opera- | Parameter | Mas | chine | code | | Dep- | Aff- | Cond | ition | | ine ( | Function | | tion | | (he | xadec | imal) | | ends | ects | code | 5 | | aax. | | | | | Wor | d 0 | Word | 1 1 | on | RLO | affe | cted | | cuti<br>us ( | | | | | В0 | B1 | B2 | B3 | RLO | | CC1 | CCO | ٥٧ | Execution time<br>in µs (max.) | | | | | | | | | | | | | | | Compara fixed-point numbers for | | I =F | | 21 | 80 | - | T - | N | N | Y | Y | - | 87 | Equal to | | >< F | | 21 | 60 | - | I - | N | N | Υ | Y | T - | 87 | Not equal to | | >F | | 21 | 20 | - | - | N | N | Υ | Υ | - | 87 | Greater than | | >=F | | 21 | AO | - | - | N | N | Υ | Y | - | 87 | Greater than or equal to | | <f< td=""><td></td><td>21</td><td>40</td><td>-</td><td>-</td><td>N</td><td>N</td><td>Υ</td><td>Y</td><td>-</td><td>87</td><td>Less than</td></f<> | | 21 | 40 | - | - | N | N | Υ | Y | - | 87 | Less than | | <=F | | 21 | CO | - | - | N | N | Υ | Y | - | 87 | Less than or equal to | | Arithme | tic operations | | | | | | · · · · · · · · · · · · · · · · · · · | <u> </u> | · · · · · · · · · · · · · · · · · · · | | <b></b> | | | Opera- | Parameter | Mas | chine | code | | Dep- | Aff- | Cond | ition | | ime ( | Function | | tion | | (he | xadec | imal) | | ends | ects | code | s | | on t | | | | | Wor | d 0 | Word | d 1 | on | RLO | affe | cted | | utio | | | | | B0 | В1 | B2 | В3 | RLO | | CC1 | CCO | ٥٧ | Execution time<br>in µs (max.) | | | +F | | 79 | 00 | - | - | N | N | Υ | Υ | Υ | 58 | Fixed-point addition | | -F | | 59 | 00 | - | - | N | N | Y | Y | Y | 54 | Fixed-point subtraction | | | i | 1 | i | 1 | .1 | 1 | 1 | | | 1 | | <u> </u> | | Block ca | alls | | | | | | | | | | | | | | T | Mas | chine | code | | Den- | Aff- | Cond | ition | | ag . | Function | | Opera- | alls<br>Parameter | 1 | chine | | | Dep- | Aff- | | ition<br>s | | n time<br>ax.) | Function | | | T | (he | xadec | imal) | | ends | ects | code | s | ······ | ution time<br>s (max.) | Function | | Opera- | T | (he | | | | 1 ' | | | s | ov | Execution time in µs (max.) | Function | | Opera- | T | (he | xadec<br>d O | imal)<br>Wor | d 1 | ends<br>on | ects | code<br>affe | s<br>cted | OV - | Execution time on the property of | Function Block end | | Opera-<br>tion | T | (he | xadec<br>d 0<br>B1 | imal)<br>Wor | d 1 | ends<br>on<br>RLO | ects<br>RLO | code<br>affe<br>CC1 | s<br>c ted<br>CCO | 00 | 1 | | | Opera-<br>tion | Parameter | | hine d<br>xadeci | | | Dep-<br>ends | Aff-<br>ects | Condi<br>codes | tion | | Execution time<br>in µs (max.) | Function | |--------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|---------------------------------------------------|-------------------------------------------------|------------------------------------------------|--------------------------------------------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | Word<br>BO | d 0<br>B1 | Word<br>B2 | 1<br>B3 | on<br>RLO | RLO | affec<br>CC1 | ted<br>CCO | OV | Execut<br>in µs | | | NOP 0 | | 00 | 00 | | | N | N | - | - | - | 40 | No operation<br>(all bits reset) | | NOP 1 | | FF | FF | | | N | N | - | - | - | 40 | No operation<br>(all bits set) | | STP | | 70 | 03 | | | N | N | - | - | - | 44 | ST0P | | | | | | | | | | | | | | Segment end for programming in statement list | | BLD | | 10 | 00 | | | N | N | - | - | - | 40 | Statement for constructing displays in LAD form on the programmer | | Logic o | perations (word | mode) | (sup | plemer | ntary | operat | ions) | | | | | | | AW | | 41 | 00 | | | N | N | Х | х | - | 55 | ANDing of accumulators 1 and 2 | | OM: | | 49 | 00 | | | N | N | Х | Х | - | 55 | ORing of accumulators 1 and 2 | | X OW | | 51 | 00 | | | | | Х | Х | - | 55 | Exclusive-ORing of accumulators 1 and 2 | | Convers | ion operations | (suppl | ement | ary op | perat | ions) | | | | | | | | Opera- | Parameter | Mac | hine | code | | Dep- | Aff- | Condi | tion | | Execution time<br>in µs (max.) | Function | | tion | | (he | x adec f | imal) | | ends | ects | codes | | | on t<br>max. | | | | | Wor | d 0 | Word | 1 | on | RL O | affec | ted | | cuti<br>µs ( | | | | | В0 | B1 | B2 | В3 | RLO | | CC1 | CC0 | 0V | Exe | | | CFW | | 01 | 00 | - | - | N | N . | - | - | - | 42 | Formation of one's complement (fixed point) | | CFW | | | | | | | | | | | | | | CSW | | 09 | 00 | - | - | · N | N | Υ | Υ | Υ | 62 | Formation of two's complement (fixed point) | | CSW | perations (supp | | | | | · N | N | Υ | Υ | Υ | 62 | | | CSW | perations (supp | lement | | perat | | N<br>Dep- | N<br>Aff- | Y | | Υ | | | | CSW<br>Shift o | | lement<br>Mac | tary o | perat<br>ode | | | | | tion | Y | | (fixed point) | | CSW<br>Shift o<br>Opera- | | lement<br>Mac | tary o | perat<br>ode | ions) | Dep- | Aff- | Condi | tion | Υ | | (fixed point) | | CSW<br>Shift o<br>Opera- | | lement<br>Macl | tary o | perat<br>code<br>imal) | ions) | Dep-<br>ends | Aff-<br>ects | Condi<br>codes | tion | Y | Execution time in µs (max.) | (fixed point) | | CSW<br>Shift o<br>Opera- | | lement<br>Mack<br>(hex | tary o<br>hine c<br>xadeci | perat<br>ode<br>imal)<br>Word | ions) | Dep-<br>ends<br>on | Aff-<br>ects | Condi<br>codes<br>affec | tion<br>ted | | | (fixed point) | | CSW Shift o Operation | Parameter | Mack<br>(hex<br>Word | tary o | perat<br>ode<br>imal)<br>Word | ions) | Dep-<br>ends<br>on<br>RLO | Aff-<br>ects<br>RLO | Condi<br>codes<br>affec | tion<br>ted<br>CCO | | Execution time in µs (max.) | (fixed point) Function | | CSW Shift o Operation | Parameter 0 to 15 | Macl<br>(he:<br>Word<br>BO | tary on thine contains the cont | perat<br>code<br>imal)<br>Word<br>B2 | 1<br>B3<br>- | Dep-<br>ends<br>on<br>RLO<br>N | Aff-<br>ects<br>RLO | Condi<br>codes<br>affec<br>CC1 | tion ted CCO | | Execution time 6 in ps (max.) | (fixed point) Function Shift left (16 bits) | | CSW Shift o Operation SLW SIW | Parameter 0 to 15 | Mack<br>(he:<br>Word<br>BO<br>61 | tary of hine of target of the control contro | perat<br>code<br>imal)<br>Word<br>B2<br>-<br>-<br>umber | 1<br>B3<br>-<br>of si | Dep-<br>ends<br>on<br>RLO<br>N | Aff-<br>ects<br>RLO | Condi<br>codes<br>affec<br>CC1 | tion ted CCO | | Execution time 6 in ps (max.) | (fixed point) Function Shift left (16 bits) Shift right (16 bits) | | Shift o Operation SLW SIW | Parameter 0 to 15 0 to 15 | Macl<br>(hez<br>Word<br>BO<br>61<br>69 | tary of hine of target of the control contro | peration | 1<br>B3<br>-<br>of si | Dep-<br>ends<br>on<br>RLO<br>N | Aff-<br>ects<br>RLO | Condi<br>codes<br>affec<br>CC1<br>Y | tion ted CCO | | Execution time to the time time to the tim | (fixed point) Function Shift left (16 bits) Shift right (16 bits) | | CSW Shift o Operation SLW SIW | Parameter 0 to 15 0 to 15 erations (supple | MacI<br>(he:<br>Word<br>BO<br>61<br>69<br>ementa | tary of hine coxadecide 0 B1 00 00 + N ary open chine exadecide of the coxadecide | peraticode imal) Word B2 umber eratic | 1<br>B3<br>-<br>of si | Dep-<br>ends<br>on<br>RLO<br>N | Aff-<br>ects<br>RLO<br>N | Condi<br>codes<br>affec<br>CC1<br>Y | tion ted CCO Y Y | | Execution time to the time time to the tim | (fixed point) Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts | | CSW Shift o Operation SLW SIW Jump op | Parameter 0 to 15 0 to 15 erations (supple | MacI<br>(he:<br>Word<br>BO<br>61<br>69<br>Ma<br>(he:<br>Word | tary of hine contains of the c | peration of the code co | 1<br>B3<br><br>of s | Dep-<br>ends<br>on<br>RLO<br>N<br>N<br>nifts | Aff- ects RLO N N Aff- | Condicodes affec CC1 Y Y Cond code affer | tion ted CCO Y Y ition s cted | OV -<br>- | Execution time to the time time to the tim | (fixed point) Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts | | CSW Shift o Operation SLW SIW Jump op | Parameter 0 to 15 0 to 15 erations (supple Parameter | Macl<br>(hex<br>Word<br>BO<br>61<br>69<br>ementa<br>Ma<br>(he<br>Wor | tary of hine coxadecide 0 B1 00 00 + N ary open chine exadecide of the coxadecide | peration of the th | ions) 1 B3 - of s | Dep-<br>ends<br>on<br>RLO<br>N<br>N<br>hifts | Aff- ects RLO N N Aff- ects | Condicodes affec CC1 Y | tion ted CCO Y Y | | Execution time + b b tin µs (max.) | (fixed point) Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts | | Shift o Operation SLW SIW Jump op Operation JU = | Parameter 0 to 15 0 to 15 erations (supple Parameter Symbolic address | Macl<br>(hex<br>Word<br>BO<br>61<br>69<br>ementa<br>(hex<br>Word<br>BO | tary of hine of tary of the control | peration of the code co | 1 B3 - of si | Dep-<br>ends<br>on<br>RLO<br>N<br>hifts | Aff- ects RLO N N Aff- ects RLO | Condicodes affec CC1 Y Y Cond code affer | tion ted CCO Y Y ition s cted | OV -<br>- | Execution time + b b in ps (max.) | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function Unconditional jump | | CSW Shift o Operation SLW SIW Jump op Operation | Parameter 0 to 15 0 to 15 Parameter Parameter Symbolic address | Macl<br>(hex<br>Word<br>BO<br>61<br>69<br>ementa<br>Ma<br>(he<br>Wor<br>BO<br>ss 2D | tary of thine of the control | peration of the second | 1 B3 - of s of s B3 | Dep-<br>ends<br>on<br>RLO<br>N<br>hifts | Aff- ects RLO N N Aff- ects RLO | Condicodes affec CC1 Y Y Cond code affec CC1 | tion ted CCO Y Y ition s cted CCO | OV OV | Execution time + b b tin µs (max.) | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function | | Shift o Operation SLW SIW Jump op Operation JU = | Parameter 0 to 15 0 to 15 Parameter Parameter Symbolic addres Symbolic addres | Macle (hexador) Macle (hexador) BO 61 69 Macle (hexador) Macle (hexador) BO SSS 2D SSS FA SSS 45 | tary of hine of tary of the control | peration word B2 | 1 B3 - of si | Dep-<br>ends<br>on<br>RLO<br>N<br>hifts | Aff- ects RLO N N Aff- ects RLO | Condicodes affec CC1 Y Y Cond code affec CC1 - | tion ted CCO Y Y ition s cted CCO | OV OV | Execution time + b b in ps (max.) | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function Unconditional jump Conditional jump | | Shift o Operation SLW SIW Jump op Operation JU = JC = | Parameter 0 to 15 0 to 15 Parameter Parameter Symbolic address | Macle (hexador) Macle (hexador) BO 61 69 Macle (hexador) Macle (hexador) BO SSS 2D SSS FA SSS 45 | tary of hine of tary of the control of the control of the control of tary of the control of tary of the control of tary tar | peraticode imal) Word B2 umber eratic code imal) Word B2 | 1 B3 - of s s s s s s s s s s s s s s s s s s | Dep-ends on RLO N Nifts Dep-ends on RLO N Y | Aff- ects RLO N N Aff- ects RLO | Condicodes affec CC1 Y Y Condicode affec CC1 | tion ted CCO Y Y ition s cted CCO - | OV | Execution time + b 6 in ps (max.) 1 b 6 in ps (max.) | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function Unconditional jump Conditional jump (Jump condition: RLO) Conditional jump | | Shift o Operation SLW SIW Jump op Operation JU = JC = JZ = | Parameter 0 to 15 0 to 15 Parameter Parameter Symbolic addres Symbolic addres | Macle (hexador) Macle (hexador) BO 61 69 Macle (hexador) Macle (hexador) BO SS 2D SS FA SS 45 SS 35 | tary of hine of tary of the control | peraticode imal) Word B2 - umber eratic code imal) Word B2 | 1 B3 - of s B3 | Dep-ends on RLO N hifts Dep-ends on RLO N N h | Aff- ects RLO N N N Aff- ects RLO N N N | Condicodes affect Y Y Condicode affect CC1 | tion ted CCO Y Y ition s cted CCO | OV | Execution time + 6 in µs (max.) 1 | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function Unconditional jump Conditional jump (Jump condition: RLO) Conditional jump (Jump condition: CC 1, CC 0) Conditional jump | | Shift o Operation SLW Jump op Operation JU = JC = JC = JZ = JN = | Parameter 0 to 15 0 to 15 Parameter Parameter Symbolic addres Symbolic addres Symbolic addres Symbolic addres | Macl (hex Word BO 61 69 BO SS 2D SS FA SS 35 SS 15 | cary of hine of added hine of the | peraticode imal) Word B2 - umber eratic code imal) Word B2 | 1 B3 - of s B3 | Dep-ends on RLO N Nifts Dep-ends on RLO N N N N N | Aff- ects RLO N N N Aff- ects RLO N N N N N | Condicodes affec CC1 Y Y Condicode affec CC1 | tion ted CCO Y Y ition s cted CCO | OV | Execution time + C | Function Shift left (16 bits) Shift right (16 bits) 0 x Number of shifts Function Unconditional jump (Jump condition: RLO) Conditional jump (Jump condition: CC 1, CC 0) Conditional jump (Jump condition: CC 1, CC 0) Conditional jump (Jump condition: CC 1, CC 0) Conditional jump (Jump condition: CC 1, CC 0) Conditional jump |