

## UNIT - II

### Machine Instruction and Programs

Instruction and Instruction sequencing : Register Transfer  
Instruction and Instruction sequencing, Basic Instruction Types,  
Notation, Assembly language Notation, Basic Input / output operations, The role of  
Addressing modes, Basic Input / output operations, The role of  
stacks and queues in computer program execution, component  
of Instructions : Logic Instructions shift and rotate Instructions.

### Instruction and Instruction sequencing :

- The tasks carried out by a computer program consists of a sequence of small steps called instructions.  
→ A computer must have instructions capable of performing four types of operations:
- ① Data transfers between memory and the processor registers.
  - ② Arithmetic and logic operations on data
  - ③ Program sequencing and control.
  - ④ I/O transfers.

### Register Transfer Notation :

- we need to describe the transfer of information from one location in the computer to another. Possible locations that may be involved in such transfers are memory locations, processor registers, (8) registers in the I/O subsystem.
- Generally memory location names identified by symbolic names for its hardware binary address.

Example:

memory locations  $\rightarrow$  LOC, PLACE, A, VAR2

processor registers  $\rightarrow$  R0, R3, R5

I/O registers  $\rightarrow$  DATAIN, OUTSTATUS.

$\rightarrow$  the contents of a location are denoted by placing square brackets around the name of the location. thus, the expression

$$R1 \leftarrow [LOC]$$

means that the contents of memory location LOC are transferred into processor register R1.

$\rightarrow$  consider the operation that adds the contents of registers R1 & R2 and then places their sum into register R3.

$$R3 \leftarrow [R1] + [R2]$$

$\rightarrow$  this type of notation is known as Register Transfer Notation (RTN).

Assembly language Notation:

$\rightarrow$  ALN represents machine instructions and programs.

① Move LOC, R1

An instruction that causes transfer data from memory location LOC to processor register R1.

② Add R1, R2, R3

Adding two numbers contained in processor registers R1 & R2 and placing their sum in R3.

## Basic Instruction Types / Instruction Formats :

(2)

- ① three address Instructions
- ② two address Instructions
- ③ one address Instructions
- ④ zero address Instructions
- ⑤ RISC Instructions.

### ① three - Address Instructions:

→ Each instruction have three operand addresses.

→ A General Instruction format is

[operation source<sub>1</sub>, source<sub>2</sub>, destination]

Here A, B and C are memory addresses

Ex: Add A, B, C ; C ← [A] + [B]

→ operands A & B are called source operands, C is called destination operand.

### ② two - address Instructions:

→ Each instruction have only two operand addresses.

→ Instruction format is

[operation source, destination]

Ex: ① Add A, B ; B ← [A] + [B]

which performs the operation  $B \leftarrow [A] + [B]$ . When sum is calculated, the result is sent to the memory and stored in location B, replacing the previous data of this location. This means that operand B is both source and destination.

② Move B, C ; C  $\leftarrow$  [B]

This instruction copy contents of B to C leaving the contents of location B unchanged.

③ One-address Instruction:

- Each instruction have only one memory operand.
- when a second operand is needed, it is understood implicitly to be in accumulator (a processor register)
- operand specified in the instruction may be a source or destination depending on the instruction.

Ex: ① Add A ; AC  $\leftarrow$  [A] + [AC]

Add the contents of memory location A to the contents of accumulator [AC] register and place the sum back into the accumulator.

② Load A ; AC  $\leftarrow$  [A]

copies the contents of memory location A into the accumulator.

③ Store A ; A  $\leftarrow$  [AC]

copies the contents of accumulator into memory location A.

④ Zero-Address Instruction:

→ This type of instructions are found in machine that store operands in stack.

→ Push and Pop instructions require one address field.

Ex: Add ; TOS  $\leftarrow$  [TOS] + [TOS-1]

PUSH A ; TOS  $\leftarrow$  [A]

POP ; A  $\leftarrow$  [TOS]

TOS = Top of Stack

## ⑤ RISC Instruction:

(3)

- In this memory restricted to LOAD & STORE Instructions.
- All manipulation of data are allowed ~~only~~ → operands that are in processor registers.

Ex: Add  $R_i, R_j ; R_j \leftarrow [R_i] + [R_j]$

LOAD A,  $R_i ; R_i \leftarrow [A]$

STORE  $R_i, A ; A \leftarrow [R_i]$

Additional instructions are

Subtract  $R_i, R_j ; R_j \leftarrow [R_i] - [R_j]$

Multiply  $R_i, R_j ; R_j \leftarrow [R_i] * [R_j]$

Divide  $R_i, R_j ; R_j \leftarrow [R_i] / [R_j]$

### ① Perform the operation $[C = A+B]$

Ans: 1) Three address Instructions : Add A, B, C ;  $C \leftarrow [A] + [B]$

2) Two address Instructions : Move B, C ;  $C \leftarrow [B]$

Add A, C ;  $C \leftarrow [A] + [C]$

3) One-address Instruction : Load A ;  $AC \leftarrow [A]$

Add B ;  $AC \leftarrow [B] + [AC]$

STORE C ;  $C \leftarrow [AC]$

④ Zero address Instruction : PUSH A ; TOS  $\leftarrow [A]$

PUSH B ; TOS  $\leftarrow [B]$

Add ;  $TOS \leftarrow [TOS] + [TOS-1]$

$TOS \leftarrow [A] + [B]$

POP C ;  $C \leftarrow [TOS]$

⑤ RISC Instruction: Load A, R<sub>i</sub>; R<sub>i</sub>  $\leftarrow [A]$   
 load B, R<sub>j</sub>; R<sub>j</sub>  $\leftarrow [B]$   
 Add R<sub>i</sub>, R<sub>j</sub>, R<sub>k</sub>; R<sub>k</sub>  $\leftarrow [R_i] + [R_j]$   
 store R<sub>k</sub>, C; C  $\leftarrow [R_k]$

### Addressing modes:

- In general, a program operates on data that reside in the computer's memory. These data can be organized in a variety of ways.
- The different ways in which the location of an operand is specified in an instruction are referred to as addressing modes.
- Programs are normally written in high level language, which enables the programmer to use constants, local & global variables, pointers and arrays.

- |        |                             |                   |
|--------|-----------------------------|-------------------|
| Types: | ① Immediate addressing mode | ② Register        |
|        | ③ Absolute                  | ④ Indirect        |
|        | ⑤ Index                     | ⑥ Base with index |
|        | ⑦ Base with index & offset  | ⑧ Relative        |
|        | ⑨ Auto increment            | ⑩ Auto decrement. |

- Variables and constants are the simplest data types and are found in almost every computer program. In assembly language a variable is represented by allocating a register (①) a memory

location to hold its value. thus, the value can be changed as needed using appropriate instructions.

(4)

Register mode: the operand is the contents of a processor register  
the name of the register is given in the instruction.  
→ processor registers are used as temporary storage locations where the data in the register are accessed using register mode

Ex: Add. R<sub>1</sub>, R<sub>2</sub>; R<sub>2</sub>  $\leftarrow$  [R<sub>1</sub>] + [R<sub>2</sub>]

Absolute mode: the operand is in a memory location; the address of this location is given explicitly in the instruction. This mode is also called as direct addressing mode.  
→ the absolute mode can represent global variables in a program.

Ex:- move B, C; C  $\leftarrow$  [B]

Note: move A, R<sub>1</sub>; R<sub>1</sub>  $\leftarrow$  [A]

The instruction uses these two modes. [Register & Absolute Addressing modes].

Immediate mode: the operand is given explicitly in the instruction.

→ the immediate mode is only used to specify the value of a source operand. A common convention is to use the sharp sign [#] in front of the value to indicate an immediate operand.

Ex: move #200, R0

→ The value 200 is placed in R0.

→ Addresses and data constants can be represented in Assembly language using the Immediate mode.

Ex: A = B + 6

move B, R1

Add. #6, R1

move R1, A

Indirection and Pointers:

Indirect mode: the effective address of the operand is the contents of a register (B) memory location whose address appears in the instruction.

→ In the addressing mode, the instruction does not give the operand. of its address explicitly.

→ the name of the operand register (B) memory address is denoted in parentheses in an instruction.



- To execute the add instruction in above figure, the processor uses the value B, which is in register R1, as the effective address of the operand.
- It requests a read operation from the memory to read contents of location B. The value read is the desired operand, which the processor adds to the contents of register R0.
- Indirect addressing through a memory location is also possible is also shown in figure.
- In this case, the processor first reads the contents of memory location A, then requests a second read operation using the value B as an address to obtain the operand.
- The register (8) memory location that contains the address of an operand is called a pointer.

Ex:

```

move N, R1
move #NUM1, R2 } Initialization.

clear R0
loop
    Add (R2), R0
    Add #4, R2
    decrement R1
    branchz0 loop
    move R0, sum

```

- This is program for adding a list of numbers. Register R2 is used as a pointer to the numbers in list and operands are accessed indirectly through R2.
- Program loads the counter value n from memory location N into R1 & uses immediate addressing mode to place address of NUM1 into R2.

- Then it clears R0 to 0. the first time through the loop, add. instruction fetches the operand at location NUM1 and adds it to R0.
- The second Add instruction adds 4 to the contents of the pointer R2, so that it will contain the address value NUM2 when the above instruction is executed in the second pass through the loop.

### Index Addressing mode:

- It is useful in dealing with lists and arrays.
- The effective address of the operand is generated by adding a constant value to the contents of a register, whose address appears in the instruction.
- Index mode symbolically represented as  $X(R_i)$  where X denotes the constant value contained in the instruction and  $R_i$  is name of register involved.
- The effective address of the operand is given by

$$EA = X + [R_i]$$

- Below figure illustrates two ways of using the index mode.



(a) offset is given as a constant

(b) offset is in the index register.

- The index register R1, contains the address of memory location, and value X defines an offset from this address to the location

where the operand is found.

- The constant  $X$  corresponds to a memory address, and contents of index register define offset to operand.
- Considered a simple example involving a list of test scores for students taking a given course.
- Each record consists of student's Identification no (ID), followed by the scores student earned on three tests.
- There are  $n$  students in the class, and value ' $n$ ' is stored in location  $N$  immediately in front of the list.
- Suppose that, wish to compute sum of all scores obtained on each of the tests and store these three sums in memory locations  $\text{sum}_1$ ,  $\text{sum}_2$  &  $\text{sum}_3$ .



→  $R_0$  is used as index register, first  $R_0$  is set to point of ID location of 1st student record. Thus, it contains the address list

- Test scores of the first student are added to the running sums held in register  $R_1$ ,  $R_2$  &  $R_3$  which are initially cleared to zero.
- These scores are accessed using the index addressing modes  $4(R_0)$ ,  $8(R_0)$  &  $12(R_0)$ . The index register  $R_0$  is then incremented by 16 to point to the IO location of the second student.

- Register  $R_4$ , initialized to contain the value  $n$ , is decremented by 1 at the end of each pass through loop.
- When the contents of  $R_4$  reach 0, all student records have been accessed and loop terminates.
- The last three instructions transfer accumulated sums from registers  $R_1, R_2$  &  $R_3$  into memory locations  $sum_1, sum_2$  &  $sum_3$  respectively.

### Base with Index

- In this mode, offset  $X$  is second register called base register symbolically indicated as  $(R_i, R_j)$
- the effective address is the sum of contents of registers  $R_i$  &  $R_j$   $EA = [R_i] + [R_j]$

This sum of index addressing provide more flexibility in accessing operands, because both components of EA can be changed.

### Base with Index & offset

This mode uses two registers plus a constant, which can be denoted as  $X(R_i, R_j)$ .

- the effective address is sum of constants  $X$  & contents of register  $R_i$  &  $R_j$

$$EA = [R_i] + [R_j] + X$$

### Relative Mode

- It is useful version of Index mode, where PC is used instead of general purpose register (or) index register.
- Denoted as  $X(PC)$ . The effective address is determined by index mode using the PC (Program counter) in place of the general purpose register  $R_i$

$$EA = [PC] + X$$

→ The most common use of this mode to specify the target address is branch instructions. (7)

### Auto-Increment mode

→ The EA of the operand is contents of register specified in instruction. After accessing operand, the contents of this register automatically incremented to the next item in a list.

→ Auto increment mode is denoted by putting specified register in parentheses, to show that the contents of register are used as EA, followed by a plus sign to indicate that these contents are to be incremented after operand is accessed.

$(R_p) +$

$$EA = [R_i] \text{ Increment } R_i$$

→ The increment amount is 1, for Byte sized operands;  
2 for 16-bit operand and 4 for 32-bit operand.

### Auto-Decrement mode

→ In this mode, the contents of a register specified in instruction are first automatically decremented and then used as effective address of operand.

→ Auto decrement mode denoted by putting the specified register in parenthesis preceded by a minus sign to indicate that the contents of the register are to be decremented before being used as the EA.

$-(R_i) \text{ Decrement } R_i$

$$EA = [R_i]$$

→ In this mode, operands are accessed in descending order.

### Generic Addressing Modes

| Name         | Addressing function             | Assembler syntax |
|--------------|---------------------------------|------------------|
| 1. Immediate | $\text{operand} = \text{value}$ | # value          |
| 2. Register  | $EA = R_i$                      | $R_i$            |

| <u>Name</u>                    | <u>Addressing functions</u>      | <u>Assembler syntax</u> |
|--------------------------------|----------------------------------|-------------------------|
| 3. Absolute (Direct)           | $EA = LOC$                       |                         |
| 4. Indirect ( $R_i$ )<br>(LOC) | $EA = [R_i]$<br>$EA = [LOC]$     | $(R_i)$<br>$(LOC)$      |
| 5. Index                       | $EA = [R_i] + X$                 | $X(R_i)$                |
| 6. Base with<br>Index          | $EA = [R_i] + [R_j]$             | $(R_i, R_j)$            |
| 7. Base with<br>Index & offset | $EA = [R_i] + [R_j] + X$         | $X(R_i, R_j)$           |
| 8. Relative                    | $EA = [PC] + X$                  | $X(PC)$                 |
| 9. Auto-Increment              | $EA = [R_i];$<br>increment $R_i$ | $(R_i) +$               |
| 10. Auto-Decrement             | Decrement $R_i$<br>$EA = [R_i]$  | $-(R_i)$                |

### Stack and Queue's

- A computer program often needs to perform a particular subtask using familiar subroutine structure. In order to organize the control & information linkage between the main program & subroutine, a data structure called a stack is used.
- A stack is a list of data elements, usually words (or) bytes, with the accening restriction that elements can be added. (or) removed at one end of the list only.
- This end is called top of the stack, and the other end is called bottom of stack. The structure is sometimes referred as Pushdown Stack and Last-In-First-out [LIFO] Stack.
- LIFO means the last data item placed on the stack is first on removed when retrieval begins.

- The terms PUSH & POP are used to describe placing a new item on the stack & removing top item from stack respectively.
- Below figure shows a stack of word data items in the memory of computer
- A processor register is used to keep track of address of the elements of stack that is at the top at any given time. This register is called 'Stack pointer' (SP).



Fig: A stack of words in the memory.

- the PUSH operation can be implemented as

```

    Subtract #4, SP
    Move NewItem, (SP)
  
```

Here assumed 32-bit word length.

- These two instructions move the word from location newItem onto the top of the stack, decreasing the stack pointer by 4 before the move

- The POP instruction can be implemented as

```

    Move (SP), ITEM
    Add #4, SP
  
```

- These 2 instructions move the top value from the stack into

location Item and then increment the stack pointer by 4 so that it points to the new top element.



(a) After PUSH from NewItem      (b) After POP into Item

→ If processor has the Auto-increment & Auto-decrement addressing modes, then PUSH & POP operations can be performed by single instruction

PUSH  $\Rightarrow$  MOVE NewItem, -(sp)

POP  $\Rightarrow$  Move (sp)+, Item

→ When a stack is used in a program, it is usually allocated a fixed amount of space in the memory. Suppose that a stack runs from location 2000 (Bottom) down no further than location 1500 (TOP).

→ Avoid pushing an item onto stack when stack is reached maximum & avoid attempting to pop an item off an empty stack, which result programming error.

→ For avoiding this problem, a single instruction can replace the PUSH & POP operations that is

Compare      src, dst  
perform  $[dst] - [src]$

src - source  
dst - destination

## Routine for safe POP operation

```

SAFEPOP    compare #2000, SP
            Branchz0 Empty Error
            Move    (SP)+, Item

```

## Routine for safe PUSH operation

```

SAFEPUSH   compare #1800, SP
            Branch≤0 Full Error
            Move    NewItem, -(SP)

```

- Another useful data structure that is similar to the stack is called a queue & data are stored in and retrieved from a queue on First-in-First-out (FIFO) basis.
- In queue, new data are added at the back (high address end) and retrieved from the front (low address) of the queue.
- There are two differences b/w Stack & Queue.

### Stack

- One end of stack is fixed (bottom), while the other end rises & falls as data pushed & popped.
- A single pointer is needed to point to the top of the stack at any given time.

### Queue

- Both ends of a queue move to higher addresses as data are added at back & removed from the front.
- So two pointers are needed to keep track of two ends of the queue.
- Another difference between a stack & a queue is that, without further control a queue would continuously move through memory of computer in direction of higher addresses.
- One way to limit the queue to a fixed region in memory is to use a circular buffer.

- Let us assume BEGINNING is starting address of queue and END is ending address of queue.
- When the data reached to END address, space will have been created at the beginning if some items have been removed from the queue.
- Hence, Back pointer is reset to the value beginning and process continues.

### Logic Instructions

- Logic operations such as AND, OR, & NOT applied to individual bits, are the basic building blocks of digital circuits.
- These logic operations are done using instructions that apply these operations to all bits of a word (or byte) independently and in parallel.
- Not dst
- The NOT instruction complements all bits contained in the destination operand, changing 0's to 1's and 1's to 0's.

1's complement

Not R<sub>0</sub>

2's complement

Not R<sub>0</sub>

Add #1, R<sub>0</sub>

(or)

Negate R<sub>0</sub>

R<sub>0</sub> = 0011

1's com = 1100

2's com = 1100

$$\begin{array}{r} +1 \\ \hline 1101 \end{array}$$

- Now consider an application for the logic instruction and, which performs the bitwise AND operation on the source and destination operands.

- Suppose that four ASCII characters are contained in the 32-bit register R<sub>0</sub>. In this task, wish to determine if the left most character is z. If it is a conditional branch to Yes is to be made.

- ASCII code for z is 01011010, which is expressed in hexadecimal notation as 6A.

(10)

AND # \$FF000000, R<sub>0</sub>  
Compare # \$5A000000, R<sub>0</sub>  
Branch = 0 Yes

- The three instruction sequence implements the desired action.
- And instruction clears all bits in the right most three character positions of R<sub>0</sub> to zero, leaving the leftmost character unchanged.
- The compare instruction compares the remaining character at the left end of R<sub>0</sub> with the binary representation for the character Z. The branch instruction causes a branch to YES if there is a match.

### Shift & Rotate Instructions

- There are many applications that require the bits of an operand to be shifted right or left some specified number of bit positions.

#### Logical Shifts

Two logical shift instructions are needed, one for shifting left (Lshift L) & another for shifting right (Rshift R).

- These instructions shift an operand over a number of bit positions specified in a count operand contained in the instruction. The general form of Logical Shift Left instruction is

Lshift L count, dest

- The count operand may be given as an immediate operand, or it may be contained in a processor register. Vacated positions are filled with zero's, and the bits shifted out are passed through the carry flag 'c', and then dropped.
- Below figure shows an example of shifting the contents of register R<sub>0</sub> left by two bit positions.



|        |   |               |
|--------|---|---------------|
| Before | 0 | 01110 --- 011 |
| After  | 1 | 110 --- 01100 |



|        |               |   |
|--------|---------------|---|
| Before | 01110 --- 011 | 0 |
| After  | 0001110 --- 0 | 1 |

② logical shift left  
LShiftL #2, R0

Logical Shift Right  
LShiftRR #2, R0

### Arithmetic shifts

→ Shifting a number one bit position to the left is equivalent to multiplying it by 2 and shifting it to the right is equivalent to dividing it by 2.

→ Another observation is that on right shift the sign bit must be repeated as the fill-in bit for vacated position whereas in logical shifts vacated positions are filled with zero's.



|         |               |   |
|---------|---------------|---|
| Before: | 10011 --- 010 | 0 |
| After:  | 1110011 --- 0 | 1 |

Arithmetic Shift Right AshiftR #2, R0

### Rotate operations

→ In the shift operations, the bits shifted out of the operand are lost, except for the last bit shifted out which is retained in the carry flag 'C'.

→ To preserve all bits, a set of rotate instructions can be used. They move the bits that are shifted out of one end of operand back into other end.

→ Two versions of both the left & right rotate instructions are usually provided. In one version, the bits of the operand are simply rotated. In the other version, the

rotation includes the c flag.

→ The mnemonics Rotate L, Rotate LC, Rotate R, Rotate RC denote the instructions that perform the rotate operations.



a) Rotate L #2,  $R_0$



b) Rotate LC #2,  $R_0$



c) Rotate R #2,  $R_0$



d) Rotate RC #2,  $R_0$

→ Multiplication and Division

→ Two signed integers can be multiplied or divided by machine instruction with the same format like Add instruction.

Multiply  $R_i, R_j$

Performs operation  $R_j \leftarrow [R_i] \times [R_j]$

→ The product of two n-bit numbers can be as large as  $2n$  bits. Therefore, the answer will not necessarily fit into register  $R_j$ .

→ A number of instruction sets have a multiply instruction that computes the low-order n bits of the product & places it in reg  $R_j$ .

→ Higher-order n-bits are placed in  $R(j+1)$ .

→ Signed integer divide instruction is

Divide  $R_i, R_j$

which performs the operation

$$R_i \leftarrow [R_i] / [R_j]$$

→ Placing the quotient in  $R_j$ . The remainder may be placed in  $R(j+1)$ , or it may be lost.

### Digit packing example

- Consider following task that illustrates use of both shift operations and logic operation.
- Suppose that two decimal digits represented in ASCII code are located in memory at byte locations LOC & LOCfl.
- To represent each of these digits in the 4-bit BCD codes & store both of them in a single byte location packed. The result is said to be in packed-BCD format.
- The required task is to extract the low-order four bits in LOC & LOCfl & concatenate them into single byte at packed.

|                   |                      |
|-------------------|----------------------|
| Move #LOC, R0     | OR R1, R2            |
| Move (R0)+, R1    | Move byte R2, PACKED |
| LShiftL #4, R1    |                      |
| MoveByte (R0), R2 |                      |
| AND #\$F, R1      |                      |

## Basic Input / Output operations

(12)

- Input /Output (I/O) operations are essential, and I/O devices & performance can effect the performance of computer
- Consider a task that reads in character input from a keyboard and produces character output on a display screen.
- A simple way of performing such I/O tasks is to use a method known as program-controlled Input and Output.
- The rate of data transfer from keyboard to a computer is limited by the typing speed of user which is few characters per second.
- The rate of output transfer from computer to display is typically several thousand characters per second and the processor executes millions of instructions per second.
- The difference in speed b/w the processor and I/O devices creates need for mechanism to synchronize transfer of data between them.
- A solution for this problem is using Buffer registers at keyboard & display unit.
- The keyboard & display are separate devices as shown in below figure
- Consider problem of moving character code from keyboard to processor.
- Striking a key stores corresponding character code in a 8-bit buffer register associated with keyboard, called as DATAIN
- To inform the processor that a valid character is in DATAIN, a status control flag SIN is set to '1'. When SIN is set to 1, processor reads contents of DATAIN.
- When character is transferred to processor SIN is automatically cleared to '0'. If second character is entered, SIN again set to 1 and process repeats.
- A Buffer register DATAOUT & status control flag sout are used

for transfer from processor to display.

- when the display device is ready to receive a second character  $sout=1$  and processor transfers character code to DATAOUT after that  $sout=0$ .
- when the display device is ready to receive a second character  $sout$  is again set to 1.
- The Buffer registers DATAIN & DATAOUT & status flags SIN & SOUT are part of circuitry commonly known as device Interface



Fig: Bus connection for processor, keyboard, and display.

- The circuitry for each device is connected to the processor via Bus indicated in figure.
- For example, the processor can monitor the keyboard status flag SIN and transfer a character from DATAIN to register R1 by the following sequence of operations:

READWAIT Branch to READWAIT if  $SIN=0$   
Input from DATAIN to R1

- the first instruction tests the status flag and second instruction transfers input data when SIN is set to 1.

- An analogous sequence of operations is used for transferring op to display. Ex:

WRITEWAIT Branch to writewait if  $sout=0$   
Output from R1 to DataOUT

- The wait loop is executed repeatedly until status flag sout is set to 1, when sout=1, second instruction transfers a

character from R1 to Dataout to be displayed, and clear Sout to 0. (13)

- Many computers use an arrangement called memory-mapped I/O in which some memory address values are used to refer peripheral device buffer registers such as DataIN & DataOUT.
- Data can be transferred b/w these registers & the processor using instructions like Move, Load & Store.

↳ MoveByte DATAIN, R1

Move Byte R1, DATAOUT

- the move byte operation code signifies that the operand size is a byte.

→ SIN & SOUT are device status registers one for each of the two devices. Let us assume that bit b3 in registers INSTATUS & OUTSTATUS corresponds to SIN & SOUT respectively.

### Read operation

READWAIT Testbit #3, IN STATUS

Branch = 0 Readwait

Move Byte DataIN, R1

### Write operation

WRITEWAIT Testbit #3, OUTSTATUS

Branch = 0 WRITEWAIT

MoveByte R1, DATAOUT

- when the device is ready, i.e., when the bit tested becomes equal to 1, the data are read from input buffers (or) written into the o/p buffers otherwise (Testbit is 0) then condition of branch is true & branch is made to beginning of WAIT LOOP.

- The program shown in below uses two operations to read a line of characters typed at a keyboard & send them out to a display device.

- As the characters are read in one by one, they are stored

in a data area in memory & then echoed backout to the display.

Move #LOC, R0 ; Initialize pointer register R0 to point to the address of the first location in memory where characters are to be stored.

Read TestBit #3, INSTATUS ; wait for character to be entered in keyboard, & buffer (DATAIN) transfers char to memory, after that clears SNE=0

Branch=0 READ

MoveByte DATAIN, (R0)

ECHO TestBit #3, OUTSTATUS ; wait for display to become ready

Branch=0 ECHO

MoveByte (R0), DATAOUT

Move char just read to the display buffer register (DATAOUT)

Compare #CR, (R0) + check if CR is just read, if it's not CR then branch back & read another char.

Branch ≠0 READ

→ The program finishes when the carriage return character CR is Read, stored & send to display.

→ R0 is incremented for each character read & displayed by auto-increment addressing mode used in compare instructions