| S.No | INSTRUCTION                         | OPERATION                                                                  | OPCODE           | Control Bits (Execute)                                                                                      |
|------|-------------------------------------|----------------------------------------------------------------------------|------------------|-------------------------------------------------------------------------------------------------------------|
|      |                                     |                                                                            |                  |                                                                                                             |
| A) I | Flags and Machine Control Instructi | ons                                                                        |                  |                                                                                                             |
| 1.   | CLR                                 | [ <rn>](n = 0, 1,7) <math>\leftarrow</math> 0 (all registers cleared)</rn> | 00000000         | WA <sub>RN</sub>                                                                                            |
| 2.   | CLF                                 | fl ← 0                                                                     | 00000011         | CL <sub>FR</sub>                                                                                            |
| В) І | Data Transfer Instructions          |                                                                            |                  |                                                                                                             |
| 3.   | LDI <od></od>                       | [A] ← <od></od>                                                            | 00000100         | Ror, Wa                                                                                                     |
| 4.   | STI                                 | [<br>  (<br>  (<br>  A]                                                    | 00000101         | R <sub>A</sub> , W <sub>OR</sub>                                                                            |
| C) I | Logical Instructions                |                                                                            |                  |                                                                                                             |
| 5.   | RTL <od></od>                       | Rotate [A] left by <od> bits</od>                                          | 00000110         | WA                                                                                                          |
| 6.   | RTR <od></od>                       | Rotate [A] Right by <od> bits</od>                                         | 00000111         | WA                                                                                                          |
| 7.   | CPI <od></od>                       | Compare [A] with <od></od>                                                 | 00001000         | WA                                                                                                          |
| 8.   | ANI <od></od>                       | [A]← [A] & <od></od>                                                       | 00001001         | WA                                                                                                          |
| 9.   | ORI <od></od>                       | [A]← [A]   <od></od>                                                       | 00001010         | WA                                                                                                          |
| 10.  | XRI <od></od>                       | [A]← [A] ^ <od></od>                                                       | <b>00001</b> 011 | W <sub>A</sub>                                                                                              |
| 11.  | CMA                                 | [A] ← ~[A]                                                                 | <b>00001</b> 100 | WA                                                                                                          |
| D) / | Arithmetic Instructions             |                                                                            |                  |                                                                                                             |
| 12.  | ADI <od></od>                       | [A]←[A] + <od> with carry</od>                                             | 00001101         | WA                                                                                                          |
| 13.  | SBI <od></od>                       | [A]←[A]- <od> with borrow</od>                                             | 00001110         | WA                                                                                                          |
| E) I | Branch Control Instructions         |                                                                            |                  |                                                                                                             |
| 14.  | JMP <ad></ad>                       | PC ← <ad></ad>                                                             | 00010000         | $I2_{PC}$ , $I_{SP}$ , $R_{PC}$ , $WR_S$ , $RD_{AB}$ , $W_{PC}$                                             |
| 15.  | JNC <ad></ad>                       | If Carry fl = 0, PC ← <ad></ad>                                            | 00010001         | I2 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WRs , RD <sub>AB</sub> , W <sub>PC</sub>             |
| 16.  | JNZ <ad></ad>                       | If zero fl = 0, PC ← <ad></ad>                                             | 00010010         | I2 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WRs , RD <sub>AB</sub> , W <sub>PC</sub>             |
| 17.  | JNS <ad></ad>                       | If sign fl = 0, PC ← <ad></ad>                                             | 00010011         | I2 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WRs , RD <sub>AB</sub> , W <sub>PC</sub>             |
| 18.  | JC <ad></ad>                        | If Carry fl= 1, PC ← <ad></ad>                                             | 00010100         | I2 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WR <sub>S</sub> , RD <sub>AB</sub> , W <sub>PC</sub> |

| 19. | JZ <ad></ad>               | If zero fl = 1, PC ← <ad></ad>         | 00010101                | I2 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WRs,              |
|-----|----------------------------|----------------------------------------|-------------------------|--------------------------------------------------------------------------|
|     |                            |                                        |                         | RDAB, WPC                                                                |
| 20. | JS <ad></ad>               | If sign fl = 1, PC ← <ad></ad>         | 00010110                | 12 <sub>PC</sub> , I <sub>SP</sub> , R <sub>PC</sub> , WR <sub>S</sub> , |
|     |                            |                                        |                         | RD <sub>AB</sub> , W <sub>PC</sub>                                       |
| 21. | RET                        | PC ← <stack></stack>                   | 00011000                | RDs, W <sub>PC</sub> , D <sub>SP</sub>                                   |
|     |                            | One Register Instructions              |                         |                                                                          |
| A)  | Logical Instructions       |                                        |                         |                                                                          |
| 22. | CPR <rn></rn>              | if [A] < [ <rn>]: carry flag is</rn>   | <b>01</b> 000 <rn></rn> | R <sub>RN</sub>                                                          |
|     |                            | set.                                   |                         |                                                                          |
|     |                            | if [A] = [ <rn>]: Sign flag is</rn>    |                         |                                                                          |
|     |                            | set if [A] > [ <rn>]: carry</rn>       |                         |                                                                          |
|     |                            | and Sign flags are reset               |                         |                                                                          |
| 23. | AND <rn></rn>              | [ <rn>] ← [<rn>] &amp; [A]</rn></rn>   | <b>01</b> 001 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 24. | OR <rn></rn>               | [ <rn>] ← [<rn>]   [A]</rn></rn>       | <b>01</b> 010 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 25. | XOR <rn></rn>              | [ <rn>] ← [<rn>] ^ [A]</rn></rn>       | <b>01</b> 011 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 26. | CMR <rn></rn>              | [ <rn>] ← ~[<rn>]</rn></rn>            | <b>01</b> 100 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| В)  | Arithmetic Instructions    |                                        |                         |                                                                          |
| 27. | ADIR <rn> <od></od></rn>   | [ <rn>] ← [<rn>] + <od></od></rn></rn> | <b>01</b> 101 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 28. | SBIR <rn> <od></od></rn>   | [ <rn>] ← [<rn>] - <od></od></rn></rn> | <b>01</b> 110 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 29. | ADD <rn></rn>              | [ <rn>] ← [<rn>] + [A]</rn></rn>       | <b>01</b> 111 <rn></rn> | R <sub>RN</sub> , W <sub>RN</sub>                                        |
| 29. | ADD (III)                  | [ <m>) ← [<m>) + [A]</m></m>           | <b>U</b> IIII<          | TRN, VVRN                                                                |
| C)  | Data Transfer Instructions | f 1                                    | 10000 (77)              | D W                                                                      |
| 30. | MVI <rn> <od></od></rn>    | [ <rn>] ← <od></od></rn>               | 10000 <rn></rn>         | Ror, W <sub>RN</sub>                                                     |
| 31. | MOVD <rn></rn>             | [ <rn>] ← [A]</rn>                     | 10001 <rn></rn>         | R <sub>A</sub> , W <sub>RN</sub>                                         |
| 32. | MOVS <rn></rn>             | [A] ←[ <rn>]</rn>                      | 10010 <rn></rn>         | R <sub>RN</sub> , W <sub>A</sub>                                         |
|     |                            | Two Register Instructions              | 1                       |                                                                          |
| 33. | STAR <rnp></rnp>           | [[ <rnp>]] ← [A]</rnp>                 | 110 <rnp></rnp>         | R <sub>RP</sub> , A <sub>AR</sub> , R <sub>A</sub> , WR                  |
| 34. | LDAR <rnp></rnp>           | [A] ← [[ <rnp>]]</rnp>                 | 111 <rnp></rnp>         | R <sub>RP</sub> , A <sub>AR</sub> , RD, W <sub>A</sub>                   |
|     |                            |                                        |                         |                                                                          |

**Table : Instruction Set**