

## UNIT - 2

### Instruction Codes :-

- The internal organisation of a digital system (or) a computer is defined as the sequential or microoperations it performs on data stored in registers.
- The general purpose of a digital computer is capable of executing various microoperations and specific sequence of organisation it must perform.
- User can control this process by means of programs.

Program :- It is a set of instructions that specify the operations, operands, and sequence of its occurrence.

Instruction : A binary code that specifies a sequence of micro-operations for the computer.

Instruction cycle :- The computer reads each instruction from memory and places it in a control register. The control then interprets the binary code of following instruction and then proceeds to execute it by issuing a sequence of the micro operations.

Instruction code :- The instruction code of an instruction is mainly classified into two types. They are

1. op code (or) operation code
2. Address (or) operand.

### Operation code (opcode) :-

- The operation code of an instruction is a group of bits that can define an operation as add, shift, etc.
- The number of bits required for the operation code of an instruction depends upon the total number of operations available in that computer.

- The operation code must contains atleast  $n$  bits for a given  $2^n$  distinct operations.

### Address (operand) :-

- It is used to specify the location of operands such as registers or memory words.
- memory words are specified by their address.
- Registers are specified by their  $k$ -bit binary code.

$k$ -bit address  $\Rightarrow 2^k$  registers.

### Stored program organisation :-

- It is the simplest way to organise a computer is to have one processor register and an instruction code is formed with two parts. They are

  - 1) First part specifies operation to be performed.
  - 2) Second part specifies an address.

- The memory address tells about the control where to find an operand in memory.
- The operand is read from memory and uses as the data to be operated on together.



- Instructions are stored in one section of memory and data in another.
- For a memory unit with 4096 words we need 12 bits to specify an address, because  $2^{12} = 4096$ .
- If we store each instruction code in one 16-bit memory word, we have available 4 bits for the operation code to specify one out of 16 possible operations and 12-bits to specify the address of operand.

#### Accumulator (AC) :-

- Computers that have a single processor register usually assign to it the name accumulator and label it AC. The operation is performed with the memory operand and contents of AC.

#### Addressing of Operand :-

- Sometimes it is convenient to use the address bits of an instruction code not as an address, but as a operand.
- When the second part of an instruction code specifies an operand, then the operand is said to have a immediate operand.
- When the second part specifies the address of an operand, the instruction is said to have a direct address.
- When the second part of instruction designate an address of a memory word in which address of the operand is found to have an indirect address.
- One bit of the instruction code can be used to distinguish between a direct and indirect address.

→ The instruction code format shown in figure. It consists of a 3-bit operation code, a 12-bit address, and an indirect address mode bit designated by I. The mode bit is 0 for a direct address and 1 for an indirect address.



(a) instruction format



(c) & (b) Demonstration of direct and indirect address.

→ A direct address instruction is shown in figure (b).

→ It is placed in address 22 in memory. The 1 bit is 0, so the instruction recognised as a direct address.

→ The 0 is the independent bits to the bus.

instruction. The Opcode specifies an ADD instruction, and the Address part is binary equivalent of 457.

→ The control finds the operand in the memory at the address 457 and adds it to content of AC.

→ The instruction in address 35 is shown in Figure (c). It has a mode bit  $1=1$ .

→ Therefore, it is recognized as an indirect address instruction.

→ The address part is binary equivalent of 300. The control goes 300 to find address of operand and its results as 1350.

→ The operand found in address 1350 is added to the content of AC.

→ Thus the effective address in instruction of Figure (b) is 457 and in instruction of Figure (c) is 1350.

### Computer Registers :-

→ Computer instructions are normally stored in consecutive memory locations and are executed sequentially.

→ The control reads an instruction from the specific memory and executes it.

→ The need of register in computer for

\* Instruction sequencing needs a counter to calculate the address of next instruction after execution of current instruction is completed. For this purpose we need a Program Counter (PC).

- \* It is necessary to provide a register in the control unit for storing the instruction code after it is read from memory (IR).
  - \* Needs processor registers for manipulating data (ACR) and a register for holding a memory address (AR).
- The above requirements dictate the register configuration shown in below figure.
- The Registers are also listed in below table with a brief description of their function and number of bits that they have.

| Register<br>Symbol | Number<br>of<br>bits | Register Name        | Function                     |
|--------------------|----------------------|----------------------|------------------------------|
| DR                 | 16                   | Data Register        | Holds memory operand         |
| AR                 | 12                   | Address Register     | Holds address of memory      |
| AC                 | 16                   | Accumulator          | Processor Register           |
| IR                 | 16                   | Instruction Register | Holds instruction code       |
| PC                 | 12                   | Program Counter      | Holds address of instruction |
| TR                 | 16                   | Temporary Register   | Holds temporary data         |
| INPR               | 8                    | Input Register       | Holds input character        |
| OUTR               | 8                    | Output Register      | Holds output character       |

→ The data Register holds the operand read from the memory.

→ The Accumulator (AC) register is a general purpose processing register.



BASIC COMPUTER REGISTERS & MEMORY.

→ The instruction read from memory is placed in the Instruction Register (IR).

→ The Temporary Register (TR) is used for holding the temporary data during the process.

→ The memory address Register (AR) has 12 bits since this is the width of memory address.

→ The program counter (PC) also has 12 bits and it holds the address of next instruction to be read from memory after current instruction is executed.

→ TWO Registers are used for input and output.

\* The input Register (INPR) receives an 8-bit character from an input device.

\* The output Register (OUTR) holds an 8-bit character for an output device.

### common bus system:-

- The basic computer has eight registers, a memory unit and a control unit.
- Paths must be provided to transfer data from one register to another and between the memory and the register too.
- A more efficient scheme for transferring information in a system with many registers is to use a common bus.
- The connection of the registers and memory of the basic computer to a common bus system is shown in figure.
- The output of seven registers and memory are connected to the common bus.
- The specific output that is selected for the bus lines at any given time is determined from the binary value of the selection variables.
- The number along each output shows the decimal equivalent of the required binary selection.
- For ex, the number along the output of DR is 3.  
The 16-bit outputs of DR are placed on the bus lines when  $S_2, S_1, S_0 = 011$ .
- The lines from the common bus are connected to the inputs of each register and the data inputs of the memory.



- the particular register whose load (LD) is input is enabled receives the data from bus during the next clock pulse transition.
- the memory receives the contents of bus when its write input is activated.
- the memory places its 16-bit output onto the bus when the read input is activated and  $S_2 S_1 S_0 = 111$
- two registers, AR and PC, have 12 bits each since they hold a memory address.
- when the contents of AR or PC are applied to the 16-bit common bus, the four more significant digits are set to 0's.
- when AR or PC receives information from the bus, only the 12 least significant bits are transferred into Registers.
- the input Register INPR and output Register OUTR have 8 bits each.
- they communicate with the eight least significant bits in the bus.
- INPR is connected to provide information to the bus but OUTR can only receive information from bus.
- this is because INPR receives a character from an input device which is transferred to AC.
- OUTR receives a character from AC and delivers it to an output device.

- Five Registers have three control inputs :  
LD(load), INR(increment) and CLR (clear).
- this type of register is equivalent to a binary Counter with parallel load and synchronous clear.
- Two Registers have only a LD input.
- the input data and output data of the memory are connected to the common bus, but the memory address is connected to AR.
- therefore, AR must always be used to specify a memory address.
- The 16 inputs of AC come from an adder and logic circuit. The circuit has three sets of inputs.
  - \* one set of 16-bit inputs come from the data Register DR.
  - \* another set of 16-bit inputs come from outputs of AC.
  - \* The resultant of addition is transferred to AC and the end carry-out of addition is transferred to the flip flop E.
- A third set of 8-bit inputs come from the input register INPR.
- The content of any register can be applied onto the bus and an operation can be performed in adder and logic circuits during the same clock cycle.
- This can be done by placing the contents of AC on the bus (with  $s_0, s_1 = 100$ ), enabling the LD(load) input of DR, transferring the content of DR through the adder and logic circuit into AC.

### 3. Computer Instructions :-

→ The basic computer has three instructions code formats as shown below,



→ The operation code (opcode) part of the instruction contains three bits and the meaning of remaining 12 bits depends on the operation code encountered.

→ A memory reference instruction has use 12 bits to specify an address and 1 bit to specify address mode.

→ Address mode (I) is equal to 0 for direct address and 1 for indirect address.

→ The Register Reference instructions are recognized by the operation code 1.11 with a 0 in the left most bit.

→ A Register Reference instruction specifies an operation code 1.11 with a 0 in AC register.

→ An input - output instruction does not need a reference to memory and it recognised by OPC III.

→ The remaining 12 bits are used to specify the type of input - output operation. The instructions are

Table : Basic Computer Instructions

| Symbol | Hex decimal code |      | Description                    |
|--------|------------------|------|--------------------------------|
|        | I=0              | I=1  |                                |
| AND    | 0XXX             | 8XXX | AND memory word to AC          |
| ADD    | 1XXX             | 9XXX | ADD memory word to AC          |
| LDA    | 2XXX             | AXXX | Load memory word to AC         |
| STA    | 3XXX             | BXXX | Store content of AC in memory  |
| BUN    | 4XXX             | CXXX | Branch unconditionally         |
| BSA    | 5XXX             | DXXX | Branch and save return address |
| ISZ    | 6XXX             | EXXX | Increment and skip if zero     |
| CLA    | 7800             |      | Clear AC                       |
| CLE    | 7400             |      | Clear E                        |
| CMA    | 7200             |      | Complement AC                  |
| CME    | 7100             |      | Complement E                   |
| CIR    | 7080             |      | Circulate right AC & E         |
| CIL    | 7040             |      | Circulate left AC & E          |
| INC    | 7020             |      | Increment AC                   |
| SPA    | 7010             |      | Skip next, if AC positive      |
| SNA    | 7008             |      | Skip to next, if AC Negative   |
| SZA    | 7004             |      | Skip to next, if AC zero       |
| SZE    | 7002             |      | Skip to next, if E is 0.       |
| HLT    | 7001             |      | Halt computer.                 |
| INP    | F800             |      | Input character to AC          |
| OUT    | F400             |      | Output character from AC       |
| SKI    | F200             |      | Skip on input flag             |
| SKO    | F100             |      | Skip on output flag            |
| ION    | F080             |      | Interrupt on                   |
| IOF    | F040             |      | Interrupt off.                 |

→ The symbol designation is a three-letter word and represents an abbreviation intended for programmers and users.

→ The hexa decimal code is equal to the equivalent hexa decimal number or binary code used for instruction.

### Instruction set completeness :-

→ A computer should have a set of instructions so that the user can construct machine language program to evaluate any function.

→ The set of instructions are said to be complete if the computer includes a sufficient number of instructions in each categories as :-

\* Arithmetic, logical and shift operations.

\* Data instructions.

\* Program control (or) Branch.

\* Input and output instructions.

→ There is one arithmetic instruction, ADD, and two related instructions, complement AC (CMA) and the increment AC (INC), with this we can add and subtract binary numbers when negative numbers are given.

→ The circulate instruction, CLR and CLR; are used for arithmetic shift and as well as other type of shifts.

→ There are three logical operations : AND, complement AC (CMA) and AC (INC). With these three instructions we can add and subtract binary numbers when negative numbers

- moving information from memory to AC is accomplished with the load AC (LD A) instruction. Storing information from AC into memory is done with store AC.
- the branch instructions BUN, BSA and ISZ, together with the four skip instructions, provide capabilities for program control and checking of status conditions.
- the input (INP) and output (OUT) instructions cause information to be transferred between computer and external devices.

### Timing and control :

- The timing for all registers in the basic computer is controlled by a master clock generator.
- The clock pulses are applied to all flip-flops and the registers in the system, including the flip-flops and registers in control unit.
- The clock pulses do not change the state of a register is enabled by control signal.
- The control signals are generated in the control unit and provide in the inputs for the multiplexers in the common bus, control inputs in processor registers, and microoperations for the accumulator.
- There are two major types of control organisation :

\* Handwired control

\* Microprogrammed control

→ the difference between handwired and microprogrammed control are:

| Handwired control                                                                              | microprogrammed control                                                                               |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| * The control logic is implemented with gates, flipflops, decoders and other digital circuits. | * The control information is stored in control memory. It is used to initiate the required sequences. |
| * The advantage that it can be optimized to produce a fast mode of operation.                  | * Compared with the handwired control operation is slow.                                              |
| * Requires changes in the wiring among the various components.                                 | * Modifications can be done by updating the micro program.                                            |

→ The block diagram of the handwired control unit is as shown in figure.

→ It consists of two decoders, a sequence counter, and a number of control logic gates.

→ An instruction read from memory is placed in the instruction Register (IR). It divided into 3 parts:

- (i) The 1 bit
- (ii) The operation code

(iii) The bits 0 through 11.

→ The operation code in bits 12 through 14 are decoded with a 3x8 decoder. The eight outputs of the decoder are designated by symbols D<sub>0</sub> through D<sub>7</sub>.

→ Bit 15 of the instruction is transferred through a flip-flop designated by symbol I.

- Bits 0 through 11 are applied to control logic gates.
- The 4-bit sequence counter can count in binary from 0 through 15.



- The outputs of the counter are decoded into 16 timing signals  $T_0$  through  $T_{15}$ .
- The sequence Counter SC can be incremented (or) cleared synchronously.
- The counter is incremented to provide the sequence of timing signals out of 4x16 decoder.

→ As an example, consider the case where SC is incremented to provide timing signals  $T_0, T_1, T_2, T_3$  and  $T_4$  in sequence. At time  $T_4$ , SC is cleared to 0 if the decoder output  $D_3$  is active.

→ This is expressed symbolically as

$$D_3 T_4 : SC \leftarrow 0.$$

→ The timing diagram will shows the time relationship of the control signal.



EXAMPLE OF CONTROL TIMING SIGNALS.

- The sequence counter SC responds to this positive transition of clock.
- Initially, the CLR input of SC is active. The first positive transition of the clock clears SC to 0, which in turn activates the timing signal.
- SC is incremented with every positive clock transition, unless its CLR input is active.
- This produces the sequence of timing signals  $T_0, T_1, T_2, T_3, T_4$  and so on, as shown in diagram.
- The last three waveforms in figure shown SC is cleared when  $D_3 T_4 = 1$ .
- Output  $D_3$  from the operation decoder becomes active at end of timing signal  $T_2$ .
- When timing signal  $T_4$  becomes active, the output of the AND gate that implements the control function  $D_3 T_4$  becomes active.
- This signal is applied to the CLR input of SC. On the next positive clock transition the counter clear to 0.
- This causes the timing signal  $T_0$  to become active instead of  $T_5$  that would have been active if SC were incremented instead of cleared.

#### Instruction cycle :-

- A program residing in the memory unit of the computer consists of a sequence of instructions.
- The program is executed in the computer by going through a cycle for each instruction.
- Each instruction cycle in turn is subdivided into a sequence of subcycles or phases.

→ In the basic computer each code instruction cycle consists of the following phases :

1. Fetch an instruction from memory.
2. Decode the instruction.
3. Read the effective address from memory.
4. Execute the instruction.

→ upon the completion of step 4, the control goes back to step 1 to fetch, decode and execute the next instruction.

#### Fetch and Decode :-

- Initially, the program counter PC is loaded with the address of the first instruction in program.
- The sequence counter SC is cleared to 0, providing a decoded Timing signal T<sub>0</sub>.
- The micro operations for the fetch and decode phases can be specified by following Register Transfer statement.
- The below figure shows how the first two register transfer statements.

To : AR  $\leftarrow$  PC

T<sub>0</sub> : IR  $\leftarrow$  M[AR], PC  $\leftarrow$  PC + 1

T<sub>1</sub> : D<sub>0</sub>, ..., D<sub>7</sub>  $\leftarrow$  Decode IR(12-14)

AR  $\leftarrow$  IR(0-11), I  $\leftarrow$  IR(15)

→ The figure shows how the first two Register Transfer statements are implemented in the bus system.



Register transfers for the fetch phase.

→ To provide the data path to a transfer of PC to AR, we must apply timing signal to the  $T_0$ , it achieve the following connection.

\* place the content of PC onto the bus by making the bus selection input  $S_2, S_1, S_0$  equal to 010.

\* Transfer the content of bus to AR by enabling the LD input of AR.

→ In order to implement the second statement it is

necessary to use the timing signal  $T_1$  to provide the following connections in bus system.

\* Enable the read input of memory.

\* place the content of memory onto bus by making

$$S_2 S_1 S_0 = 111.$$

\* Transfer the content of the bus to IR by enabling the LD input of IR.

\* increment PC by enabling the INR input of PC.

→ Multiple input OR gates are included in the diagram because there are other control functions that will be initiate similar operations.

#### Determine the type of Instructions :-

→ the timing signal that is after active the decoding is  $T_2$ .

→ During the time  $T_2$ , the control unit determine the type of instruction that was read from memory.

→ the flow chart shows the initial configurations for the instruction cycle and also how the control determines the instruction cycle after decoding.

→ Decoder output  $D_1$  is equal to 1, if the operation code is equal to binary 111.

→ If  $D_1 = 1$ , the instruction must be a register-reference (or) input-output type.

→ If  $D_1 = 0$ , the operation code must be one of the other seven values 000 through 110, specifying a memory-reference instruction.

→ Control then inspects the value of the first bit of the instruction, which is in flip-flop 1.

- IF  $D_7 = 0$  and  $I = 2$ , indicates a memory-reference instruction with a direct address.
- IF  $D_7 = 1$  and  $I = 0$ , indicates a register-reference instruction.
- IF  $D_7 = 01$  and  $I = 1$ , indicates an input-output instruction.
- The three instruction types are subdivided into four separate paths.
- The selected operation is activated with the clock transition associated with timing signal  $T_3$  as

$D_7' T_3 : AR \leftarrow M[AR]$

$D_7' I' T_3 : \text{nothing}$

$D_7 I' T_3 : \text{Execute a register}$

$D_7 I T_3 : \text{Execute an input-output instruction.}$



## Register-Reference instructions :-

- Register-Reference instructions are recognized by the Control, when  $D_7=1$  and  $I=0$ .
- These instructions use bits 0 through 11 of the instruction code to specify one of 12 instructions.
- These 12 bits are available in IR (0-11).
- The control functions and microoperations for the register-reference instructions are listed in table.
- These instructions are executed with the clock transition associated with the timing variable  $T_3$ .
- Control function needs the Boolean relation  $D_7 I' T_3$ , which we designed and designated for convenience by symbol  $\gamma$ .
- By assigning symbol  $B_i$  to bit  $i$  to IR, all controls be

$D_7 I' T_3 : \gamma$  (common to all Registers)

IR(11) :  $B_i$  (bit in IR(0-11))

|                                                                                           |                  |
|-------------------------------------------------------------------------------------------|------------------|
| $\gamma$ : $SC \leftarrow 0$                                                              | clear SC         |
| CLA $\gamma B_{11}$ : $AC \leftarrow 0$                                                   | clear AC         |
| CLE $\gamma B_{10}$ : $E \leftarrow 0$                                                    | clear E          |
| CMA $\gamma B_9$ : $AC \leftarrow \bar{AC}$                                               | complement AC    |
| CME $\gamma B_8$ : $E \leftarrow \bar{E}$                                                 | complement E     |
| CIR $\gamma B_7$ : $AC \leftarrow \text{sh}r AC, AC(15) \leftarrow E, E \leftarrow AC(0)$ | circulate right  |
| CIL $\gamma B_6$ : $AC \leftarrow \text{sh}l AC, AC(0) \leftarrow E, E \leftarrow AC(15)$ | circulate left   |
| INC $\gamma B_5$ : $AC \leftarrow AC + 1$                                                 | increment AC     |
| SPA $\gamma B_4$ : IF ( $AC(15) = 0$ ) then<br>$(PC \leftarrow PC + 1)$                   | Skip if positive |

SNA  $\gamma_{B_3}$  : IF ( $AC(1s) = 1$ ) then SKIP IF negative  
 $(PC \leftarrow PC + 1)$

SNA  $\gamma_{B_2}$  : IF ( $AC = 0$ ) then SKIP IF AC zero  
 $(PC \leftarrow PC + 1)$

SZE  $\gamma_B$  : IF ( $E = 0$ ) then SKIP IF E zero  
 $(PC \leftarrow PC + 1)$

HLT  $\gamma_B$  :  $S \leftarrow 0$  (when  $S$  is 0) HALT COMPUTER.  
Start-stop flip-flop

#### Execution of Register-Reference Instructions.

- FOR EXAMPLE, the instruction CLA has a hex decimal code 7800, which gives binary equivalent as below  
0111 1000 0000 0000, The first bit is a zero.
- The next three bits constitute the operation code and are recognized by decoder output  $D_7$ .
- Bit  $B_{11}$  in IR is 1, and is recognized from  $B_{11}$ . The control function that initiates the micro operation for instruction.
- The Execution of a register-reference instruction is completed at time  $T_9$ .
- The sequence counter SC is cleared to 0 and the control goes back to fetch, with timing signal  $T_6$ .
- The condition control statements must be recognised as part of the control conditions.
- The AC is positive, when the sign bit in  $AC(1s) = 0$ ; it is negative when  $AC(1s) = 1$ . The content of AC is zero ( $AC = 0$ ) if all flip-flops of registers are zero.
- The HLT instruction clears a start-stop flip-flops and the sequence counter from counting.

## Memory-Reference Instructions :-

- The table shows the seven memory-reference instructions.
- the decoded output  $D_i$  for  $i = 0, 1, 2, 3, 4, 5$  and 6 from the operation decoder that belongs to each instruction is included in table.
- The effective address of the instruction is in the address register AR and was placed there during the timing signal  $T_2$ , when  $I=0$  and  $T_3$  when  $I=1$ .
- The execution of memory-reference instruction is starts with Timing signal  $T_4$ .
- The symbolic description of each instruction is specified in table in terms of register transfer form.

| Symbol | Operation<br>decoder | Symbolic description                                |
|--------|----------------------|-----------------------------------------------------|
| AND    | $D_0$                | $AC \leftarrow AC \wedge M[AR]$                     |
| ADD    | $D_1$                | $AC \leftarrow AC + M[AR], E \leftarrow \text{Out}$ |
| LDA    | $D_2$                | $AC \leftarrow M[AR]$                               |
| STA    | $D_3$                | $M[AR] \leftarrow AC$                               |
| BUN    | $D_4$                | $PC \leftarrow AR$                                  |
| BSA    | $D_5$                | $M[AR] \leftarrow PC, PC \leftarrow AR+1$           |
| ISZ    | $D_6$                | $M[AR] \leftarrow M[AR]+1$                          |

### AND to AC :-

- This is an instruction that performs the AND logic operation on pairs of bits in AC and the memory word specified by address.

→ The sum is transferred into AC and output carry Cout is transferred to E flipflop.

→ The microoperations needed to execute this are

$$D_1 T_4 : DR \leftarrow M[AR]$$

$$D_1 T_5 : AC \leftarrow AC + DR, E \leftarrow Cout, SC \leftarrow 0.$$

### LDA : Load to AC :-

→ This instruction transfers the memory word that specified by effective address to AC.

→ The microoperations needed to execute this instructions are

$$D_2 T_4 : DR \leftarrow M[AR]$$

$$D_2 T_5 : AC \leftarrow DR, SC \leftarrow 0.$$

### STA : Store AC :-

→ This instruction stores the contents of AC into the memory word specified by effective address.

→ Since the output of AC is applied to the bus and the data input of memory is connected to bus, we can execute this instruction as

$$D_3 T_4 : M[AR] \leftarrow AC, SC \leftarrow 0$$

### BUN : Branch unconditionally :-

→ This instruction transfers the program to the instruction specified by the effective address.

→ The BUN instruction allows the programmer to specify an instruction out of sequence and we say that the program branches unconditionally.

→ The micro operation is executed with micro operation as :

$$D_4 T_4 : PC \leftarrow AR, SC \leftarrow 0.$$

## BSA: Branch and save address of return :-

- this instruction is useful for branching to a portion of the program called sub-routine (or) procedure.
- when executed, the BSA instruction stores the address of next instruction in sequence into a memory location.
- The effective address plus one is then transferred to PC to serve as address of first instruction in subroutine.
- This operation was specified with following register transfer:

$$M[AR] \leftarrow PC, PC \leftarrow AR + 1$$

- A numeric example that demonstrates how this instruction is used with subroutine as shown.



(a) memory, PC and AR at time  $T_4$  (b) memory and PC after

at time  $T_4$

Execution

- The BSA instruction is assumed to be in memory at address 20.
  - The 1 bit is 0 and the address part of instruction has the binary equivalent of 135.
  - After the fetch and decode phases, PC contains 21, which is the address of next instruction in program.
  - This is shown in part(A) of figure.
  - The BSA instruction performs the following operation
- $$M[135] \leftarrow 21, PC \leftarrow 135 + 1 = 136.$$
- The result of this operation is shown in part(B).
  - The return address 21 is stored in memory location 135 and control continues with subroutine program.
  - The return to the original program is accomplished by means of an indirect BUN instruction placed at end.
  - When this instruction is executed, control goes to the indirect phase to read effective address at location 135.
  - When the BUN instruction is executed, the effective address 21 is transferred to PC.
  - The BSA instruction must be executed with a sequence of two micro operations.

$D_5 T_4 : M[AR] \leftarrow PC, AR \leftarrow AR + 1$

$D_5 T_5 : PC \leftarrow AR, SC \leftarrow 0.$

### ISZ : increment and skip if zero :-

- This instruction increments the word specified by the effective address, and if the incremented value is equal to 0, PC is incremented by 1 to skip next.
- Since it is not possible to increment a word

Inside the memory, it is necessary to read the word into DR, increment DR, and store back in memory.

→ This is done with following sequence

$D_6 T_4 : DR \leftarrow M[AR]$

$D_6 T_5 : DR \leftarrow DR + 1$

$D_6 T_6 : M[AR] \leftarrow DR, SC \leftarrow 0.$

if ( $DR = 0$ ) then ( $PC \leftarrow PC + 1$ ).

### Control flow chart :-

#### Memory - Reference instructions



Flow chart for memory reference instructions

## 7. Input-Output and Interrupt :-

- Instructions and data stored in memory must come from some input device.
- Computational results must be transmitted to the user through some output device.
- To demonstrate the most basic requirements for input and output communication, we will use as an illustration a terminal unit with a keyboard & printer.

### Input-Output Configuration:-

- The terminal sends and receives serial information.
- Each quantity of information has 8 bits or an alpha numeric code.
- The serial information from the keyboard is shifted into the input register INPR.
- The serial information for the printer is stored in the output register OUTR.
- These two registers communicate with a communication interface serially and with the AC in parallel.
- The input-output configuration is shown as



- The input Register INPR consists of 8 bits and holds alphanumeric input information.
- The 1-bit input flag FG1 is a control flip-flop.
- The flag bit is set to 1 when new information is available in input device and cleared to 0 when the information is accepted by computer.
- The output Register OUTR works similarly but the direction of flow of information is reversed.
- Initially, the output flag FGO is set to 1.
- The computer checks the flag bit; if it is 1, then the information from AC is transferred in parallel to OUTR and FGO is cleared to 0.

### Input-output Instructions :-

- Input and output instructions are needed to transfer information to and from AC register, for checking the flag bits, and for controlling interrupt facility.
- Input-output instructions have an operation code 1111 and recognized by control when D7=1 and i=2.
- $D_7 I_6 = P$  (common to all input-output instructions)  
 $I_{R(i)} = B_i$  [Bit in IR (6-11) that specifies instructions]

|                                                                 |                      |
|-----------------------------------------------------------------|----------------------|
| $P : SC \leftarrow 0$                                           | clear SC             |
| INP $P B_{11} : AC(0-7) \leftarrow INPR, FG1 \leftarrow 0$      | input character      |
| OUT $P B_{10} : OUTR \leftarrow AC(0-7), FGO \leftarrow 0$      | output character     |
| SKI $P B_9 : IF (FG1 = 1) \text{ then } (PC \leftarrow PC + 2)$ | skip on input flag   |
| SKO $P B_8 : IF (FG0 = 1) \text{ then } (PC \leftarrow PC + 2)$ | skip on output flag  |
| ION $P B_7 : IEN \leftarrow 1$                                  | interrupt enable on  |
| IOF $P B_6 : IEN \leftarrow 0$                                  | interrupt enable off |

### INPUT-OUTPUT Instructions

- These instructions are executed with the clock transition associated with timing signal  $T_3$ .
- Each control function needs a Boolean relation  $D_7IT_3$ , which we designated for convenience by symbol  $p$ .
- The control function is distinguished by one of the bits in IR (6-11).
- By assigning the symbol  $B_i$  to Bit  $i$  ~~of IR~~, all control functions can be denoted by  $pB_i$  for  $i=6$  through 11.
- The sequence counter  $SC$  is cleared to 0, when  $p = D_7IT_3 = 1$ .
- The last two instructions set and clear an interrupt enable flip-flop  $IEN$ .

#### program interrupt:

- The computer keeps checking the flag bit, and when it finds it set, it initiates an information transfer.
- The difference of information flow rate between the computer and that of the input-output device makes this type of transfer inefficient.
- An alternative to the programmed controlled procedure is to let the external device inform the computer when it is ready for the transfer.
- In the meantime the computer can be busy with other tasks. This type of transfer uses the interrupt facility.
- While the computer is running a program, it does not check the flags.
- When a flag is set, the computer is momentarily interrupted from the current program.
- Then computer deviates momentarily from the current program.

- It returns to the current program to continue what it was doing to perform input or output transfer.
- the interrupts enable flip-flops IEN can be set and cleared with two instructions.
  - \* when IEN is cleared to 0, the flags Cannot interrupt the computer.
  - \* when IEN is set to 1, the computer can be interrupted.
- the way that the interrupt is handled by the device can be explained by above flowchart.
- An interrupt flip-flop R is included in computer. when R=0, it goes through an instruction cycle.
- During the execute phase of instruction cycle IEN is checked by control.
- If it is 0, that indicates the programmer does not want to use the interrupt, so the control will continues with next instruction.
- If IEN is 1, control checks the flag bits. If both flags are 0, it indicates that neither the input nor the output registers are ready for transfer information.
- If either flag is set to 1, while IEN=1, flipflop R is set to 1. At the end of execute phase, control checks the values of R, and if it is equal to 1, it goes to an interrupt cycle instead of an instruction cycle.



Flowchart of interrupt cycle.

### Interrupt cycle :-

- The interrupt cycle is a hardware implementation of a branch and save return address operation.
- The return address available in PC is stored in specific location.
- That location may be a processor register, a memory stack, or a specific memory location.
- The example in next page, shows that what happens during the interrupt cycle.
- From the figure,
  - \* when an interrupt occurs and R is set to 1, while the control is executing the instruction at address 255.



- \* At this time, the return address 256 is in PC.
- \* The programmer has previously placed an input-output service program in memory starting from address 1120 and a BUN 1120 instruction at address 12.
- \* The programmer has a sign that, when control reaches timing signal T<sub>0</sub> and finds R=1, it proceeds with the interrupt cycle.
- \* The contents of PC (256) is stored in memory location 0, PC is set to 1, and R is cleared to 0.
- \* The branch instruction at address 1 causes the program to transfer input-output service program at 1120.
- \* This program checks the flags, determines which flag is set, and transfers required input.
- \* This is shown in figure (b).

### complete computer Description :-

- the final flowchart of instruction cycle, including the interrupt cycle for basic computer. The interrupt flip-flop R may be set at any time during indirect execute phase.
- the control returns the timing signal T after  $S_C$  is cleared to 0. If  $R=1$ , the computer goes through an interrupt or instruction cycle.
- If the instruction is one of the memory-Reference instructions, the computer first checks if there is an address (indirect) and then continues to execute the decoded instruction.
- If the instruction is one of the Register-Reference instructions, it is executed with one of microoperations listed.
- Instead of using a flowchart, we can describe the operation of the computer with a list of register transfer statements. This is done by accumulating all the control functions and micro operations.
- The control functions and the micro operations for the entire computer are summarized. The register transfer statements will describe in a concise form the internal organisation of basic computer.
- The control functions and conditional control statements listed in table format and formulate the boolean functions for the gates in control unit.
- A register transfer language is useful not only for describing internal organisation, but also specifying the logic circuit needed for design.

### Design of Accumulator Logic :-

- The circuits associated with the AC register are shown in figure. The adder and logic circuit has 3 inputs.
- One set of 16 inputs comes from the outputs of AC.
- Another set of 16 input comes from data Register DR.
- A third set of eight inputs comes from the input register INPR. The outputs of the adder and logic circuit provide the data input for register.
- In addition of this, it is necessary to include logic gates for controlling LD, INPR, and CLR in register.
- Inorder to design the logic associated with AC, it is necessary to go over the Register transfer statements.

$DR \rightarrow T_5 : AC \leftarrow AC \wedge DR$  AND with DR

$DR \rightarrow T_6 : AC \leftarrow AC + DR$  Add with DR

$DR \rightarrow T_7 : AC \leftarrow DR$  Transfer from DR

$PB_{11} : AC(0-7) \leftarrow INPR$  Transfer from INPR

$YB_9 : AC \leftarrow \overline{AC}$  Complement

$YB_7 : AC \leftarrow Sh\& AC, AC(15) \leftarrow E$  Shift right

$YB_6 : AC \leftarrow sh\& AC, AC(0) \leftarrow E$  Shift left

$YB_1 : AC \leftarrow 0$  Clear

$YB_5 : AC \leftarrow AC + 1$  Increment

→ From the above list, we can achieve the control logic gates and the adder and logic circuit.



circuit associated with AC.

\* <sup>last page</sup> programming the basic computer :-

#### Introduction :-

- A total computer system is an inclusion of both the hardware and software.
- Hardware consists of physical components and all associated equipment.
- Software refers to the program that are written from the computer.
- This part will introduces some elementary programming concepts and shows their relation to the hardware representation of instructions.
- The usefulness of various machine instructions is then demonstrated by means of several basic programming examples.

## Machine language :-

- A program is a list of instructions (on statements) for directing the computer to perform a required data-processing task.
- There are various types of programming languages that are used for computer. But they can execute only when they are in binary format.
- programs may be written in one of the following categories. They are :-
  - (i) Binary code
  - (ii) octal (or) Hexadecimal code
  - (iii) symbolic code
  - (iv) High-level programming languages.

## Definition :-

- A machine language program is a binary program of category, because of simple equivalency between binary (or) octal (or) hexadecimal representation.
- The hardware of a computer will execute these instructions and perform the given task.
- whatever it, the computer knowledge or hardware recognises only this type of instruction code.

## Binary to Add two numbers

| location | Instruction code    |
|----------|---------------------|
| 0        | 0010 0000 0000 0100 |
| 1        | 0001 0000 0000 0101 |
| 10       | 0011 0000 0000 0110 |
| 101      | 1111 1111 1110 1001 |

## Assembly language :-

- A programming language is defined as by set of rules.
- Users must conform with all format language rules.
- Almost every commercial computer has its own particular assembler.
- The basic unit of an assembly language program is a line of code. The specific language is defined by set of rules.
- We will now formulate the rules of an assembly language for writing symbolic program for computers.

## Rules of language :-

- \* The label field may be empty (or) it may specify a symbolic address.
- \* The instruction field specifies a machine instruction (or) a pseudo instruction.
- \* The comment field may be empty (or) include a comment.

## Symbolic address:-

- A symbolic address consists of one (or) more but not more than three alphanumeric characteristics.
- The first character must be letter and remaining two may be any.
- The symbol can be chosen arbitrary by the programmer.

### \* Rules :- It must have :-

- 1) A memory-reference instruction (MRI).
- 2) A Register-reference / input-output instruction (non-MRI).
- 3) A pseudo instruction with / without an operand.

### Pseudo instruction :-

- A pseudo instruction is not a machine instruction but rather than an instruction to the assembler giving information about some phase of translation.
- The ORG (origin) pseudocode informs the assembler that the instruction or operand in the following line is to be placed in memory location.

### Symbol giving information for Assembler

ORG      Hexadecimal number  $N$  is the memory location for the instruction.

END      Denotes end of symbolic program.

DEF N      Signed decimal number  $n$  to convert into binary.

HEX N      Hexadecimal number  $N$  to convert to binary.

### The Assembler :-

- An assembler is a program that accepts a symbolic language program and produces its binary machine equivalent language.
- The assembler is a program that operates on the character strings and produces an equivalent binary interpretation.
- The input symbolic program is called the source program and binary program is called the object program.

## program Loops :-

- A program loop is a sequence of instructions that are executed many times, each time with different set of data.
- Program loops are specified by Fortran by a DO statement.

Eg:- DIMENSION A(100)  
INTEGER SUM, A  
SUM=0  
DO 3 J= 1, 100  
3 SUM = SUM + A(J).

compiler :- A system program that translates a program written in a high-level programming language such as C above to a machine language program is called as a "Compiler".

## pointer and counter:-

- The pointer and a counter together with the indirect address operation go form a program loop.
- The pointer points to the address of current operand and the counter counts the number of times that the loop is executed.
- In computers with more than one processor register, it is possible to use one processor register as a pointer and another processor register as a counter and third as an accumulator.
- When processor registers are used as pointers and the counters, they are called as index registers.

Line

1. ORG 100 Origin of program is Hex 100
2. LDA ADS load first address of operand.
3. STA PTR Store to pointer
4. LDA NBR /load minus 100
5. STA CTR Store in counter
6. CLA Clear in Accumulator
7. LOP ADD PTR 1 Add an operand to Ac1
8. ISZ PTR increment pointer
9. ISZ CTR increment counter
10. BLN LOP Repeat loop again.
11. STA SUM Store sum
12. HLT Wait
13. ADS, HEX 150 First address of operands
14. PTR, 0 Hex 0 location Reserve for pointer
15. NBR, DEC -100 Const to initialize counter
16. CTR, 0 Hex 0 location for counter
17. SUM, Hex 0 sum is stored
18. ORG 150 Origin of operand is HEX 150
19. DEC 75 First operand
- 118 DEC 23 Last operand
- 119 END IEND

## programming Arithmetic and logic operations :-

- The number of instructions available in a computer may be a few hundred in a large system or a few dozen in small.
- Some computer performs given operation with one machine instruction, But Others may require a large number of machine instruction to perform same Operation.
- As an illusion, consider four basic arithmetic operations. Some computers have machine instructions to add, Subtract, multiply and divide.
- Operations not included in the set of machine instructions must be implemented by a program.
- Operations that are implemented in a computer with one computer machine and implemented by hardware.
- Operations that are implemented by sets of instruction that constitute a program are implemented by software.
- Hardware implementation is more costly because of the additional circuits.
- Software implementation results in long programs both in number of instructions and execution time too.
- This section demonstrates the software implementation of a few arithmetic and logic operations.
- Programs can be developed for any arithmetic operation and not only for fixed binary data, but also for decimal and floating point data as well.

### Multiplication program:-

→ The program for multiplying two numbers is based on the procedure we use to multiply with pen & paper.

→ The flowchart shows, the multiplication process consists of checking the bits of the multiplier  $y$  and adding the multiplicand  $x$  as many times as there is 1's in  $y$ , provide the value of  $x$  is shifted left from one line to next line.

→ Since the computer can add only two numbers at a time, we reserve a memory location, denoted by  $P$ , to store intermediate sums.

→ The intermediate sums are called partial products, since they hold a partial products until all numbers are added.

→ As shown in the numerical example under  $P$ , the second partial products starts with zero.

→ The multiplicand  $x$  is added to the content of  $P$  for each bit of multiplier  $y$ .

→ The final value in  $P$  forms the product. The numerical examples has numbers with four significant bits.

→ When multiplied, the product contains 8 specific significant bits. The computer can use numbers with 8 significant bits to produce upto 16 bits.



Flow chart for  
multiplication program

- The above flowchart shows the algorithm for programming of multiplication operation. The program has a loop that is traversed eight times.
- The multiplier bit can be checked if it is transferred to E register. This is done by clearing E, loading the values.

- the bit is stored in E is the low-ordered bit of the multiplier. we now check the value of E.
- If it is 1, the multiplicand X is added to the partial product P.
- If it is 0, the partial product does not change.
- we then shift the value of X once to the right by loading it into the AC and circulating left E and AC. The loop is repeated.
- The loop is repeated eight times by incrementing location CTR and checking when it reaches zero.
- The program in Table G-14 lists the instructions for multiplying two unsigned numbers.
- The initialization is not listed but included when program is loaded in computer.

program to multiply two positive numbers

|            |                               |  |
|------------|-------------------------------|--|
| ORG 100    |                               |  |
| L0P, CLE   | 1Clear E                      |  |
| LDA Y      | 1Load multiplier              |  |
| CIR        | 1Transfer multiplier bit to E |  |
| STA Y      | 1Store shifted multiplier     |  |
| ONE, LDA X | 1 Load multiplicand           |  |
| ADD P      | 1 add to partial product      |  |
| STAP       | 1 Store partial product       |  |
| CLE        | 1Clear E                      |  |
| ZRO, LDA X | 1 Load multiplicand           |  |
| CIL        | 1 Shift left                  |  |
| STA X      | 1 Store shifted multiplicand  |  |
| ISZ CTR    | 1 Increment counter           |  |

|             |                                   |
|-------------|-----------------------------------|
| BUN LOP     | / counter not zero ; repeat loop  |
| HLT         | / counter is zero ; halt          |
| CTR, DEC-8  | 1 These location takes as counter |
| X, HEX 000F | 1 multiplicand stored here        |
| Y, HEX 000B | 1 multiplier stored here          |
| P, HEX 0    | 1 product formed here             |
| <u>END</u>  |                                   |

- This example has shown that if a computer does not have a machine instruction required.
- Thus we have demonstrated the software implementation of multiplication operation.
- The corresponding hardware implementation is present in sec. 10-3.

### Double precision Addition :-

- When two 16-bit unsigned numbers are multiplied, the result is a 32-bit product, that must be stored in two memory words.
- A number which is stored in two memory words is said to have double precision.
- When a partial product is computed, it is necessary that a double precision number be added to multiplicand.
- For greater accuracy, the programmer may wish to employ double-precision numbers and perform arithmetic with operands that occupy two memory words.
- Now we develop a program that is used to add two - double precision numbers.

## program to add two double precision Number

|        |                       |
|--------|-----------------------|
| LDA AL | Load A low            |
| ADD BL | Add B low, carry in E |
| STA CL | Store C low           |
| CLA    | Clear AC              |
| CIL    | circulate left        |
| ADD AH | Add A high and carry  |
| ADD BH | Add B high and carry  |
| STA CH | Store C high          |
| HLT    | halt                  |

## Allocation of Operands

AL,

AH,

BL,

BH,

CL,

CH,

possible allocation possibilities

## Logic Operation :-

- The computer has three machine instructions that perform logic operations : AND, CMN and CLA.
- The LDA instruction may be considered as an logic operation that transfers a logic operand into AC.
- All 16 micro operations can be implemented by the software means of because any logic function can be implemented using AND and its Complement.

\* For example, the OR operation is not available as a machine instruction in basic computer.

→ From DeMorgan's theorem we know

$$x+y = (x'y')'$$

→ A program that forms the OR operation of two logic Operands A and B is as

LDA A load first operand A.

CMA complement to get  $\bar{A}$ .

STA TMP store in temporary location.

LDA B load secondary operand B.

CMA complement to get  $\bar{B}$ .

AND TMP AND with A to get  $\bar{A} \wedge \bar{B}$ .

CMA complement again to get AVB.

→ The logic operations can be implemented in similar fashion by software.

### Shift operation :-

→ The circular shift operations are machine instructions in basic computer.

→ The other shifts or interests are logic shifts and the arithmetic shifts.

→ These can be programmed by a small number of the instructions.

→ The logical shifts requires zeros to be added at the extreme positions. For that we need two operations, CLE and CIR.

→ For a logic shift left operation, we need

CLE and CIL.

- The arithmetic shifts depends on the type or representation of negative numbers.
- For the basic computer we have adopted the signed 2's complement representation.
- The rules for the arithmetic shifted are listed in above table.
- For an arithmetic right shift it is necessary that the sign bit in left most position remains unchanged.
- But the sign bit itself shifted into high-order bit position of number.
- The program for arithmetic right-shift requires that we set E to same value as sign bit.

CLE

1 Clear E to 0 □

SPR

1 Skip if AC is positive ←

E remains □

CME

1 AC is negative, set E to 1. ←

CIR

1 Circulate E and AC. ←

Star page (cont-)

### Control of AC Register :-

- The gate structure of the control, that controls the LD, INR, and CLR inputs of AC is as shown. ←
- The gate configuration is derived from the control functions in list above. ←
- The control function for microoperation clear is  $\gamma B_{11}$ , where  $\gamma = D_7 I' T_3$  and  $B_{11} = I R U 1 1$ . ←
- The output of AND gate that generates this control function is connected to CLR input of register. ←

→ Similarly the output of the gate function that implements the increment microoperation is connected to the INR input of register.

→ The other seven microoperations are generated in the adder and logic circuit and are loaded into AC in a proper time.



## PROBLEMS

- 5-1.** A computer uses a memory unit with 256K words of 32 bits each. A binary instruction code is stored in one word of memory. The instruction has four parts: an indirect bit, an operation code, a register code part to specify one of 64 registers, and an address part.
- How many bits are there in the operation code, the register code part, and the address part?
  - Draw the instruction word format and indicate the number of bits in each part.
  - How many bits are there in the data and address inputs of the memory?
- 5-2.** What is the difference between a direct and an indirect address instruction? How many references to memory are needed for each type of instruction to bring an operand into a processor register?
- 5-3.** The following control inputs are active in the bus system shown in Fig. 5-4. For each case, specify the register transfer that will be executed during the next clock transition.

|    | $S_2$ | $S_1$ | $S_0$ | LD of register | Memory | Adder |
|----|-------|-------|-------|----------------|--------|-------|
| a. | 1     | 1     | 1     | IR             | Read   | —     |
| b. | 1     | 1     | 0     | PC             | —      | —     |
| c. | 1     | 0     | 0     | DR             | Write  | —     |
| d. | 0     | 0     | 0     | AC             | —      | Add   |

- 5-4.** The following register transfers are to be executed in the system of Fig. 5-4. For each transfer, specify: (1) the binary value that must be applied to bus select inputs  $S_2$ ,  $S_1$ , and  $S_0$ ; (2) the register whose LD control input must be active (if any); (3) a memory read or write operation (if needed); and (4) the operation in the adder and logic circuit (if any).
- $AR \leftarrow PC$
  - $IR \leftarrow M[AR]$
  - $M[AR] \leftarrow TR$
  - $AC \leftarrow DR$ ,  $DR \leftarrow AC$  (done simultaneously)
- 5-5.** Explain why each of the following microoperations cannot be executed

during a single clock pulse in the system shown in Fig. 5-4. Specify a sequence of microoperations that will perform the operation.

- $IR \leftarrow M[PC]$
- $AC \leftarrow AC + TR$
- $DR \leftarrow DR + AC$  ( $AC$  does not change)

- 5-6. Consider the instruction formats of the basic computer shown in Fig. 5-5 and the list of instructions given in Table 5-2. For each of the following 16-bit instructions, give the equivalent four-digit hexadecimal code and explain in your own words what it is that the instruction is going to perform.
- 0001 0000 0010 0100
  - 1011 0001 0010 0100
  - 0111 0000 0010 0000
- 5-7. What are the two instructions needed in the basic computer in order to set the  $E$  flip-flop to 1?
- 5-8. Draw a timing diagram similar to Fig. 5-7 assuming that  $SC$  is cleared to 0 at time  $T_3$ , if control signal  $C_7$  is active.

$$C_7 T_3: SC \leftarrow 0$$

$C_7$  is activated with the positive clock transition associated with  $T_1$ .

- 5-9. The content of  $AC$  in the basic computer is hexadecimal A937 and the initial value of  $E$  is 1. Determine the contents of  $AC$ ,  $E$ ,  $PC$ ,  $AR$ , and  $IR$  in hexadecimal after the execution of the CLA instruction. Repeat 11 more times, starting from each one of the register-reference instructions. The initial value of  $PC$  is hexadecimal 021.
- 5-10. An instruction at address 021 in the basic computer has  $I = 0$ , an operation code of the AND instruction, and an address part equal to 083 (all numbers are in hexadecimal). The memory word at address 083 contains the operand B8F2 and the content of  $AC$  is A937. Go over the instruction cycle and determine the contents of the following registers at the end of the execute phase:  $PC$ ,  $AR$ ,  $DR$ ,  $AC$ , and  $IR$ . Repeat the problem six more times starting with an operation code of another memory-reference instruction.
- 5-11. Show the contents in hexadecimal of registers  $PC$ ,  $AR$ ,  $DR$ ,  $IR$ , and  $SC$  of the basic computer when an ISZ indirect instruction is fetched from memory and executed. The initial content of  $PC$  is 7FF. The content of memory at address 7FF is EA9F. The content of memory at address A9F is 0C35. The content of memory at address C35 is FFFF. Give the answer in a table with five columns, one for each register and a row for each timing signal. Show the contents of the registers after the positive transition of each clock pulse.
- 5-12. The content of  $PC$  in the basic computer is 3AF (all numbers are in hexadecimal). The content of  $AC$  is 7EC3. The content of memory at address 3AF is 932E. The content of memory at address 32E is 09AC. The content of memory at address 9AC is 8B9F.
- What is the instruction that will be fetched and executed next?
  - Show the binary operation that will be performed in the  $AC$  when the instruction is executed.

- c. Give the contents of registers  $PC$ ,  $AR$ ,  $DR$ ,  $AC$ , and  $IR$  in hexadecimal and the values of  $E$ ,  $I$ , and the sequence counter  $SC$  in binary at the end of the instruction cycle.
- 5-13. Assume that the first six memory-reference instructions in the basic computer listed in Table 5-4 are to be changed to the instructions specified in the following table.  $EA$  is the effective address that resides in  $AR$  during time  $T_4$ . Assume that the adder and logic circuit in Fig. 5-4 can perform the exclusive-OR operation  $AC \leftarrow AC \oplus DR$ . Assume further that the adder and logic circuit cannot perform subtraction directly. The subtraction must be done using the 2's complement of the subtrahend by complementing and incrementing  $AC$ . Give the sequence of register transfer statements needed to execute each of the listed instructions starting from timing  $T_4$ . Note that the value in  $AC$  should not change unless the instruction specifies a change in its content. You can use  $TR$  to store the content of  $AC$  temporary or you can exchange  $DR$  and  $AC$ .

| Symbol | Opcode | Symbolic designation                                 | Description in words                 |
|--------|--------|------------------------------------------------------|--------------------------------------|
| XOR    | 000    | $AC \leftarrow AC \oplus M[EA]$                      | Exclusive-OR to $AC$                 |
| ADM    | 001    | $M[EA] \leftarrow M[EA] + AC$                        | Add $AC$ to memory                   |
| SUB    | 010    | $AC \leftarrow AC - M[EA]$                           | Subtract memory from $AC$            |
| XCH    | 011    | $AC \leftarrow M[EA]$ , $M[EA] \leftarrow AC$        | Exchange $AC$ and memory             |
| SEQ    | 100    | If ( $M[EA] = AC$ ) then<br>$(PC \leftarrow PC + 1)$ | Skip on equal                        |
| BPA    | 101    | If ( $AC > 0$ ) then $(PC \leftarrow EA)$            | Branch if $AC$ positive and non-zero |

- 5-14. Make the following changes to the basic computer.
1. Add a register to the bus system CTR (count register) to be selected with  $S_2S_1S_0 = 000$ .
  2. Replace the ISZ instruction with an instruction that loads a number into CTR.

LDC Address       $CTR \leftarrow M[Address]$

3. Add a register reference instruction ICSZ: Increment CTR and skip next instruction if zero. Discuss the advantage of this change.

- 5-15. The memory unit of the basic computer shown in Fig. 5-3 is to be changed to a  $65,536 \times 16$  memory, requiring an address of 16 bits. The instruction format of a memory-reference instruction shown in Fig. 5-5(a) remains the same for  $I = 1$  (indirect address) with the address part of the instruction residing in positions 0 through 11. But when  $I = 0$  (direct address), the address of the instruction is given by the 16 bits in the next word following the instruction. Modify the microoperations during time  $T_2$ ,  $T_3$ , (and  $T_4$  if necessary) to conform with this configuration.

- 5-16. A computer uses a memory of 65,536 words with eight bits in each word. It has the following registers: PC, AR, TR (16 bits each), and AC, DR, IR (eight bits each). A memory-reference instruction consists of three words: an 8-bit operation-code (one word) and a 16-bit address (in the next two words). All operands are eight bits. There is no indirect bit.
- Draw a block diagram of the computer showing the memory and registers as in Fig. 5-3. (Do not use a common bus).
  - Draw a diagram showing the placement in memory of a typical three-word instruction and the corresponding 8-bit operand.
  - List the sequence of microoperations for fetching a memory reference instruction and then placing the operand in DR. Start from timing signal  $T_0$ .
- 5-17. A digital computer has a memory unit with a capacity of 16,384 words, 40 bits per word. The instruction code format consists of six bits for the operation part and 14 bits for the address part (no indirect mode bit). Two instructions are packed in one memory word, and a 40-bit instruction register *IR* is available in the control unit. Formulate a procedure for fetching and executing instructions for this computer.
- 5-18. An output program resides in memory starting from address 2300. It is executed after the computer recognizes an interrupt when *FGO* becomes a 1 (while *IEN* = 1).
- What instruction must be placed at address 1?
  - What must be the last two instructions of the output program?
- 5-19. The register transfer statements for a register *R* and the memory in a computer are as follows (the X's are control functions that occur at random):

|             |                      |                                |
|-------------|----------------------|--------------------------------|
| $X'_3 X_1:$ | $R \leftarrow M[AR]$ | Read memory word into <i>R</i> |
| $X'_1 X_2:$ | $R \leftarrow AC$    | Transfer <i>AC</i> to <i>R</i> |
| $X'_1 X_3:$ | $M[AR] \leftarrow R$ | Write <i>R</i> to memory       |

The memory has data inputs, data outputs, address inputs, and control inputs to read and write as in Fig. 2-12. Draw the hardware implementation of *R* and the memory in block diagram form. Show how the control functions  $X_1$  through  $X_3$  select the load control input of *R*, the select inputs of multiplexers that you include in the diagram, and the read and write inputs of the memory.

- 5-20. The operations to be performed with a flip-flop *F* (not used in the basic computer) are specified by the following register transfer statements:

|         |                        |                                        |
|---------|------------------------|----------------------------------------|
| $xT_3:$ | $F \leftarrow 1$       | Set <i>F</i> to 1                      |
| $yT_1:$ | $F \leftarrow 0$       | Clear <i>F</i> to 0                    |
| $zT_2:$ | $F \leftarrow \bar{F}$ | Complement <i>F</i>                    |
| $wT_5:$ | $F \leftarrow G$       | Transfer value of <i>G</i> to <i>F</i> |

Otherwise, the content of *F* must not change. Draw the logic diagram showing the connections of the gates that form the control functions and the inputs of flip-flop *F*. Use a JK flip-flop and minimize the number of gates.

- 5-21. Derive the control gates associated with the program counter  $PC$  in the basic computer.
- 5-22. Derive the control gates for the write input of the memory in the basic computer.
- 5-23. Show the complete logic of the interrupt flip-flops  $R$  in the basic computer. Use a  $JK$  flip-flop and minimize the number of gates.
- 5-24. Derive the Boolean logic expression for  $x_2$  (see Table 5-7). Show that  $x_2$  can be generated with one AND gate and one OR gate.
- 5-25. Derive the Boolean expression for the gate structure that clears the sequence counter  $SC$  to 0. Draw the logic diagram of the gates and show how the output is connected to the INR and CLR inputs of  $SC$  (see Fig. 5-6). Minimize the number of gates.

## CHAPTER 5

5-1

$$256K = 2^8 \times 2^{10} = 2^{18}$$

$$64 = 2^6$$

(a) Address : 18 bits

Register code: 6 bits

Indirect bit: 1 bit

25

$32 - 25 = 7$  bits for opcode.

(b) 1 7 6 , 18 = 32 bits

|   |        |          |         |
|---|--------|----------|---------|
| I | Opcode | Register | Address |
|---|--------|----------|---------|

(c) Data ; 32 bits ; address : 18 bits.

5-2

A direct address instruction needs two references to memory : (1) Read instruction ; (2) Read operand.

An indirect address instruction needs three references to memory : (1) Read instruction ; (2) Read effective address ; (3) Read operand.

5-3

(a) Memory read to bus and load to IR :  $IR \leftarrow M[AR]$

(b) TR to bus and load to PC :  $PC \leftarrow TR$

(c) AC to bus, write to memory, and load to DR :  
 $DR \leftarrow AC, M[AR] \leftarrow AC$ .

(d) Add DR (or INPR) to AC :  $AC \leftarrow AC + DR$

5-4

|     | <u>S<sub>2</sub> S<sub>1</sub> S<sub>0</sub></u> | <u>(1)<br/>Load (LD)</u> | <u>(2)<br/>Memory</u> | <u>(3)<br/>Adder</u> |
|-----|--------------------------------------------------|--------------------------|-----------------------|----------------------|
| (a) | $AR \leftarrow PC$                               | 010 (PC)                 | AR                    | -                    |
| (b) | $IR \leftarrow M[AR]$                            | 111 (M)                  | IR                    | Read                 |
| (c) | $M[AR] \leftarrow TR$                            | 110 (TR)                 | -                     | Write                |
| (d) | $DR \leftarrow AC$<br>$AC \leftarrow DR$         | 100 (AC)                 | DR and AC             | Transfer<br>DR to AC |

5-5

- (a)  $IR \leftarrow M[PC]$  PC cannot provide address to memory.  
Address must be transferred to AR first

$AR \leftarrow PC$   
 $IR \leftarrow M[AR]$

- (b)  $AC \leftarrow AC + TR$  Add operation must be done with DR, Transfer TR to DR first.

$DR \leftarrow TR$   
 $AC \leftarrow AC + DR$

- (c)  $DR \leftarrow DR : AC$  Result of addition is transferred to AC (not DR). To save value of AC, its content must be stored temporary in DR (or TR).

$AC \leftarrow DR$ ,  $DR \leftarrow AC$  (See answer to Problem 5-4(d))  
 $AC \leftarrow AC + DR$   
 $AC \leftarrow DR$ ,  $DR \leftarrow AC$

5-6

(a)  $\begin{array}{r} 0001 \quad 0000 \quad 0010 \quad 0100 \\ \text{ADD} \quad \dots \quad (024)_{16} \end{array} = (1024)_{16}$

ADD content of  $M[024]$  to AC ADD 024

(b)  $\begin{array}{r} 1011 \\ I \text{ STA} \end{array} \quad \begin{array}{r} 0001 \quad 0010 \quad 0100 \\ (124)_{16} \end{array} = (B124)_{16}$

Store AC in  $M[M[124]]$  STA I 124

(c)  $\begin{array}{r} 0111 \\ \text{Register} \end{array} \quad \begin{array}{r} 0000 \quad 0010 \quad 0000 \\ \text{Increment AC} \end{array} = (7020)_{16}$  INC

5-7

CLE clear E

CME Complement E



5-9

|         | E | AC   | PC  | AR  | IR   |
|---------|---|------|-----|-----|------|
| Initial | I | A937 | 021 | -   | -    |
| CLA     | I | 0000 | 022 | 800 | 7800 |
| CLE     | O | A937 | 022 | 400 | 7400 |
| CMA     | I | 56C8 | 022 | 200 | 7200 |
| CME     | O | A937 | 022 | 100 | 7100 |
| CIR     | I | D49B | 022 | 080 | 7080 |
| CIL     | I | 526F | 022 | 040 | 7040 |
| INC     | I | A938 | 022 | 020 | 7020 |
| SIA     | I | A937 | 022 | 010 | 7010 |
| SNA     | I | A937 | 023 | 008 | 7008 |
| SZA     | I | A937 | 022 | 004 | 7004 |
| SZE     | I | A937 | 022 | 002 | 7002 |
| HLT     | I | A937 | 022 | 001 | 7001 |

5-10

|         | PC  | AR  | DR   | AC   | IR   |
|---------|-----|-----|------|------|------|
| Initial | 021 | -   | -    | A937 | -    |
| AND     | 022 | 083 | B8F2 | A832 | 0083 |
| ADD     | 022 | 083 | B8F2 | 6229 | 1083 |
| LDA     | 022 | 083 | B8F2 | B8F2 | 2083 |
| STA     | 022 | 083 | -    | A937 | 3083 |
| BUN     | 083 | 083 | -    | A937 | 4083 |
| BSA     | 084 | 084 | -    | A937 | 5083 |
| TSZ     | 022 | 083 | B3F3 | A937 | 6083 |

5-11

|                | PC  | AR  | DR   | IR   | SC |
|----------------|-----|-----|------|------|----|
| Initial        | FFF | -   | -    | -    | 0  |
| T <sub>0</sub> | FFF | FFF | -    | -    | 1  |
| T <sub>1</sub> | 800 | FFF | -    | EA9F | 2  |
| T <sub>2</sub> | 800 | A9F | -    | EA9F | 3  |
| T <sub>3</sub> | 800 | C35 | -    | EA9F | 4  |
| T <sub>4</sub> | 800 | C35 | FFFF | EAAF | 5  |
| T <sub>5</sub> | 800 | C35 | 0000 | EA9F | 6  |
| T <sub>6</sub> | 801 | C35 | 0000 | EA9F | 0  |

5-12

$$(a) 9 = (1001)_2$$

$$I=1 \quad \begin{array}{r} 1001 \\ \hline ADD \end{array} \quad ADD \ I \ 32E$$

|        |     |       |
|--------|-----|-------|
| Memory | 3AF | 932E  |
|        | 32E | 09 AC |
|        | 9AC | 8B9F  |

(b)

$$\begin{array}{r} AC = 7EC3 \\ DR = 8B9F \\ \hline 0A62 \end{array} \quad (ADD)$$

$$AC = 7EC3$$

(E=1)

$$(c) PC = 3AF + 1 = 3B0$$

$$IR = 932E$$

$$AR = 9AC$$

$$E = 1$$

$$DR = 8B9F$$

$$I = 1$$

$$AC = 0A62$$

$$SC = 0000$$

5-13

XOR

$D_0 T_4 : DR \leftarrow M[AR]$

$D_0 T_5 : AC \leftarrow AC \oplus DR, SC \leftarrow 0$

ADM

$D_1 T_4 : DR \leftarrow M[AR]$

$D_1 T_5 : DR \leftarrow AC, AC \leftarrow AC + DR$

$D_1 T_6 : M[AR] \leftarrow AC, AC \leftarrow DR, SC \leftarrow 0$

SUB

$D_2 T_4 : DR \leftarrow M[AR]$

$D_2 T_5 : DR \leftarrow AC, AC \leftarrow DR$

$D_2 T_6 : AC \leftarrow \overline{AC}$

$D_2 T_7 : AC \leftarrow AC + 1$

$D_2 T_8 : AC \leftarrow AC + DR, SC \leftarrow 1$

XCH

$D_3 T_4 : DR \leftarrow M[AR]$

$D_3 T_5 : M[AR] \leftarrow AC, AC \leftarrow DR, SC \leftarrow 0$

SEQ

$D_4 T_4 : DR \leftarrow M[AR]$

$D_4 T_5 : TR \leftarrow AC, AC \leftarrow AC \oplus DR$

$D_4 T_6 : \text{If } (AC = 0) \text{ then } (PC \leftarrow PC + 1), AC \leftarrow TR, SC \leftarrow 0$

BPA

$D_5 T_4 : \text{If } (AC = 0 \wedge AC(15) = 0)$

$\text{then } (PC \leftarrow AR), SC \leftarrow 0$

5-14

Converts the ISZ instruction from a memory-reference instruction to a register-reference instruction.

The new instruction ICSZ can be executed at time  $T_3$  instead of time  $T_6$ , a saving of 3 clock cycles.

5-15 Modify Fig. 5-4:



5-16

(a)



(b)



(c)  $T_0: IR \leftarrow M[PC], PC \leftarrow PC + 1$

$T_1: AR(0-7) \leftarrow M[PC], PC \leftarrow PC + 1$

$T_2: AR(8-15) \leftarrow M[PC], PC \leftarrow PC + 1$

$T_3: DR \leftarrow M[AR]$



1. Read 40-bit double instruction from memory to IR and then increment PC,
2. Decode opcode 1.
3. Execute instruction 1 using address 1.
4. Decode opcode 2.
5. Execute instruction 2 using address 2.
6. Go back to step 1.

5-18

(a) BUN 2300

(b) JON  
BUN 0 I (Branch indirect with address 0)

5-19



5-20

$$J_F = X T_3 + \bar{Z} T_2 + W T_5 G \quad K_F = Y T_1 + \bar{Z} T_2 + W T_5 G'$$



5-21 From Table 5-6: ( $Z_{DR}=1$  if  $DR=0$ ;  $Z_{AC}=1$  if  $AC=0$ )

$$\begin{aligned} INR(PC) &= R'T_1 + RT_2 + D_6 T_6 Z_{DR} + P.B_9(FGI) + P.B_8(FGO) \\ &\quad + rB_4(AC_{15})' + rB_3(AC_{15}) + rB_2 Z_{AC} + rB_1 E' \end{aligned}$$

$$LD(PC) = D_4 T_4 + D_5 T_5$$

$$CLR(PC) = RT_1$$

The logic diagram is similar to the one in Fig. 5-16,

5-22

$$Write = D_3 T_4 + D_5 T_4 + D_6 T_6 + RT_1 \quad (M[AR] \leftarrow xx)$$

5-23

$$(T_0 + T_1 + T_2)'(IEN)(FGI + FGO); \quad R \leftarrow 1$$

$$RT_2; \quad R \leftarrow 0.$$



5-24

$\chi_2$  places PC onto the bus. From Table 5-6:

$$R'T_0 : AR \leftarrow PC$$

$$R T_0 : TR \leftarrow PC$$

$$D_5 T_4 : M[AR] \leftarrow PC$$

$$\chi_2 = R'T_0 + RT_0 + D_5 T_4 = (R' + R)T_0 + D_5 T_4 = T_0 + D_5 T_4$$



5-25

From Table 5-6:

$$\begin{aligned}
 CLR(SC) = & RT_2 + D_7 T_3 (I' + I) + (D_0 + D_1 + D_2 + D_5) T_5 \\
 & + (D_3 + D_4) T_4 + D_6 T_6
 \end{aligned}$$



- 6-1. The following program is stored in the memory unit of the basic computer. Show the contents of the AC, PC, and IR (in hexadecimal), at the end, after each instruction is executed. All numbers listed below are in hexadecimal.

| Location | Instruction |
|----------|-------------|
| 010      | CLA         |
| 011      | ADD 016     |
| 012      | BUN 014     |
| 013      | HLT         |
| 014      | AND 017     |
| 015      | BUN 013     |
| 016      | C1A5        |
| 017      | 93C6        |

- 6-2. The following program is a list of instructions in hexadecimal code. The computer executes the instructions starting from address 100. What are the content of AC and the memory word at address 103 when the computer halts?

SECTION 6-8 Input-Output Programming      209

| Location | Instruction |
|----------|-------------|
| 100      | 5103        |
| 101      | 7200        |
| 102      | 7001        |
| 103      | 0000        |
| 104      | 7800        |
| 105      | 7020        |
| 106      | C103        |

- 6-3. List the assembly language program (of the equivalent binary instructions) generated by a compiler from the following Fortran program. Assume integer variables.

```
SUM = 0
SUM = SUM + A + B
DIF = DIF - C
SUM = SUM + DIF
```

- ✓6-3. List the assembly language program (of the equivalent binary instructions) generated by a compiler from the following Fortran program. Assume integer variables.

```
SUM = 0  
SUM = SUM + A + B  
DIF = DIF - C  
SUM = SUM + DIF
```

- 6-4. Can the letter I be used as a symbolic address in the assembly language program defined for the basic computer? Justify the answer.
- 6-5. What happens during the first pass of the assembler (Fig. 6-1) if the line of code that has a pseudoinstruction ORG or END also has a label? Modify the flowchart to include an error message if this occurs.
- ✓6-6. A line of code in an assembly language program is as follows:

DEC -35

- a. Show that four memory words are required to store the line of code and give their binary content.
- b. Show that one memory word stores the binary translated code and give its binary content.
- 6-7. a. Obtain the address symbol table generated for the program of Table 6-13 during the first pass of the assembler.  
b. List the translated program in hexadecimal.
- ✗6-8. The pseudoinstruction BSS N (block started by symbol) is sometimes employed to reserve N memory words for a group of operands. For example, the line of code

A, BSS 10

informs the assembler that a block of 10 (decimal) locations is to be left free, starting from location A. This is similar to the Fortran statement DIMENSION A(10). Modify the flowchart of Fig. 6-1 to process this pseudoinstruction.

- 6-9. Modify the flowchart of Fig. 6-2 to include an error message when a symbolic address is not defined by a label.
- 6-10. Show how the MRI and non-MRI tables can be stored in memory.
- 6-11. List the assembly language program (of the equivalent binary instructions) generated by a compiler for the following IF statement:

IF(A - B) 10, 20, 30

The program branches to statement 10 if  $A - B < 0$ ; to statement 20 if  $A - B = 0$ ; and to statement 30 if  $A - B > 0$ .

- 6-12. a. Explain in words what the following program accomplishes when it is executed. What is the value of location CTR when the computer halts?  
 b. List the address symbol table obtained during the first pass of the assembler.  
 c. List the hexadecimal code of the translated program.

```

ORG 100
CLE
CLA
STA CTR
LDA WRD
SZA
BUN ROT
BUN STP
      ROT,
      CIL
      SZE
      BUN AGN
      BUN ROT
AGN,
      CLE
      ISZ CTR
      SZA
      BUN ROT
      STP,
      CTR,
      WRD,    HLT
              HEX 0
              HEX 62C1
END

```

- 6-13. Write a program loop, using a pointer and a counter, that clears to 0 the contents of hexadecimal locations 500 through 5FF.
- 6-14. Write a program to multiply two positive numbers by a repeated addition method. For example, to multiply  $5 \times 4$ , the program evaluates the product by adding 5 four times, or  $5 + 5 + 5 + 5$ .
- 6-15. The multiplication program of Table 6-14 is not initialized. After the program is executed once, location CTR will be left with zero. Show that if the program is executed again starting from location 100, the loop will be traversed 65536 times. Add the needed instructions to initialize the program.

- 6-16. Write a program to multiply two unsigned positive numbers, each with 16 significant bits, to produce an unsigned double-precision product.
- 6-17. Write a program to multiply two signed numbers with negative numbers being initially in signed-2's complement representation. The product should be single-precision and signed-2's complement representation if negative.
- 6-18. Write a program to subtract two double-precision numbers.
- 6-19. Write a program that evaluates the logic exclusive-OR of two logic operands.
- 6-20. Write a program for the arithmetic shift-left operation. Branch to OVF if an overflow occurs.
- 6-21. Write a subroutine to subtract two numbers. In the calling program, the BSA instruction is followed by the subtrahend and minuend. The difference is returned to the main program in the third location following the BSA instruction.
- 6-22. Write a subroutine to complement each word in a block of data. In the calling program, the BSA instruction is followed by two parameters: the starting address of the block and the number of words in the block.
- 6-23. Write a subroutine to circulate E and AC four times to the right. If AC contains hexadecimal 079C and E = 1, what are the contents of AC and E after the subroutine is executed?
- 6-24. Write a program to accept input characters, pack two characters in one word and store them in consecutive locations in a memory buffer. The first address of the buffer is  $(400)_{16}$ . The size of the buffer is  $(512)_{10}$  words. If the buffer overflows, the computer should halt.
- 6-25. Write a program to unpack two characters from location WRD and store them in bits 0 through 7 of locations CH1 and CH2. Bits 9 through 15 should contain zeros.
- 6-26. Obtain a flowchart for a program to check for a CR code (hexadecimal 0D) in a memory buffer. The buffer contains two characters per word. When the code for CR is encountered, the program transfers it to bits 0 through 7 of location LNE without disturbing bits 8 through 15.
- 6-27. Translate the service routine SRV from Table 6-23 to its equivalent hexadecimal code. Assume that the routine is stored starting from location 200.
- 6-28. Write an interrupt service routine that performs all the required functions but the input device is serviced only if a special location, MOD, contains all 1's. The output device is serviced only if location MOD contains all 0's.

## CHAPTER 6

6-1

|     |         | <u>AC</u> | <u>PC</u> | <u>IR</u> |
|-----|---------|-----------|-----------|-----------|
| 010 | CLA     | 0000      | 011       | 7800      |
| 011 | ADD 016 | C1A5      | 012       | 1016      |
| 012 | BUN 014 | C1A5      | 014       | 4014      |
| 013 | HLT     | 8184      | 014       | 7001      |
| 014 | AND 017 | 8184      | 015       | 0017      |
| 015 | BUN 013 | 8184      | 013       | 4013      |
| 016 | C1A5    |           |           |           |
| 017 | 93C6    |           |           |           |

$$(C1A5)_{16} = 1100 \ 0001 \ 1010 \ 0101 \text{ AND}$$

$$(93C6)_{16} = \frac{1001 \ 0011 \ 1100 \ 0110}{1000 \ 0001 \ 1000 \ 0100} = (8184)_{16}$$

6-2

|     |      | <u>AC</u>                                  |
|-----|------|--------------------------------------------|
| 100 | 5103 |                                            |
| 101 | 7200 |                                            |
| 102 | 7001 |                                            |
| 103 | 0000 | ← BSA 103<br>→ CMA<br>HLT<br>5101 ← Answer |
| 104 | 7800 | 0000                                       |
| 105 | 7020 | 0001                                       |
| 106 | C103 | BUN 103 I                                  |

6-3

|     |     |   |                   |
|-----|-----|---|-------------------|
| CLA | SUM | { | SUM = 0           |
| STA |     |   |                   |
| LDA | SUM | { | SUM = SUM + A + B |
| ADD |     |   |                   |
| ADD | B   | } |                   |
| STA | SUM | { |                   |
| LDA | C   | } |                   |
| CMA | DIF | { | DIF = DIF - C     |
| INC |     |   |                   |
| ADD | DIF | } |                   |
| STA | DIF | { |                   |
| LDA | SUM | } | SUM = SUM + DIF   |
| ADD | DIF | { |                   |
| STA | SUM | } |                   |

A more efficient compiler will optimize the machine code as follows:

|         |
|---------|
| LDA A   |
| ADD B   |
| STA SUM |
| LDA C   |
| CMA     |
| INC     |
| ADD DIF |
| STA DIF |
| ADD SUM |
| STA SUM |

- 6-4 A line of code such as: LDA I is interpreted by the assembler (Fig. 6-2) as a two symbol field with I as the symbolic address. A line of code such as: LDA I I is interpreted as a three symbol field. The first I is an address symbol and the second I as the Indirect bit.  
 Answer: Yes, it can be used for this assembler.

6-5

The assembler will not detect an ORG or END if the line has a label; according to the flow chart of Fig. 6-1. Such a label has no meaning and constitutes an error. To detect the error, modify the flow chart of Fig. 6-1:



6-6 (a) memory word    characters    Hex    binary

|   |         |       |                     |
|---|---------|-------|---------------------|
| 1 | D E     | 44 45 | 0100 0100 0100 0101 |
| 2 | C space | 43 20 | 0100 0011 0010 0000 |
| 3 | - 3     | 2D 33 | 0010 1101 0011 0011 |
| 4 | 5 CR    | 35 0D | 0011 0101 0000 1101 |

$$(b) (35)_{10} = (0000\ 0000\ 0010\ 0011)_2$$

$$-35 \rightarrow 1111\ 1111\ 1101\ 1101 = (\text{FF DD})_{16}$$

|                |     |     |                                                             |
|----------------|-----|-----|-------------------------------------------------------------|
| <u>6-7 (2)</u> | LOP | 105 | $(100)_{10} = (0000 \ 0000 \ 0100 \ 0100)_2$                |
|                | ADS | 10B | $(-100)_{10} = (1111 \ 1111 \ 1001 \ 1100)_2 = (FF9C)_{16}$ |
|                | PTR | 10C | $(75)_{10} = (0000 \ 0000 \ 0100 \ 1011)_2 = (0048)_{16}$   |
|                | NBR | 10D |                                                             |
|                | CTR | 10E |                                                             |
|                | SUM | 10F | $(23)_{10} = (0000 \ 0000 \ 0001 \ 0111)_2 = (0017)_{17}$   |

(b)

| Loc | Hex  | ORG 100        | Loc | Hex  |              |
|-----|------|----------------|-----|------|--------------|
| 100 | 210B | LDA ADS        | 10B | 0150 | ADS, HEX 150 |
| 101 | 310C | STA PTR        | 10C | 0000 | PTR, HEX 0   |
| 102 | 210D | LDA NBR        | 10D | FF9C | NBR, DEC-100 |
| 103 | 310E | STA CTR        | 10E | 0000 | CTR, HEX 0   |
| 104 | 7800 | CLA            | 10F | 0000 | SUM, HEX 0   |
| 105 | 910C | LOP, ADD PTR I |     |      | ORG 150      |
| 106 | 610C | ISZ PTR        | 150 | 004B | DEC 150      |
| 107 | 610E | ISZ CTR        | :   | :    | :            |
| 108 | 4105 | BUN LOP        | :   | :    |              |
| 109 | 310F | STA SUM        | 1B3 | 0017 | DEC 23       |
| 10A | 7001 | HLT            |     |      | END          |

6-8 Modify flow chart of Fig. 6-1



6-9



| (a) MRI Table |           |       | (b) non-MRI Table |           |       |
|---------------|-----------|-------|-------------------|-----------|-------|
| memory word   | symbol    | HEX   | word              | symbol    | HEX   |
| AND           | 1 A N     | 41 4D | CLA               | 1 C L     | 43 4C |
|               | 2 D space | 44 20 |                   | 2 A space | 41 20 |
|               | 3 value   | 00 00 |                   | 3 value   | 78 00 |
| ADD           | 4 A D     | 41 44 | CLE               | 4 C L     | 43 4C |
|               | 5 D space | 44 20 |                   | 5 E space | 45 20 |
|               | 6 value   | 10 00 |                   | 6 value   | 74 00 |
| etc.          |           |       | etc.              |           |       |

6-11

```

LDA B
CMA
INC
ADD A / Form A-B
SPA / skip if AC positive.
BUN N10 / (A-B)<0, go to N10
SZA / skip if AC=0
BUN N30 / (A-B)>0, go to N30
BUN N20 / (A-B)=0, go to N20

```

6-12(a) The program counts the number of 1's in the number stored in location WRD. Since WRD =  $(62C1)_{16}$  =  
 $(0110\ 0010\ 1100\ 0001)_2$   
number of 1's is 6; so CTR will have  $(0006)_{16}$

| (b) |      | ORG 100                                 |
|-----|------|-----------------------------------------|
| 100 | 7400 | CLE                                     |
| 101 | 7800 | CLA                                     |
| 102 | 3110 | STA CTR / Initialize counter to zero    |
| 103 | 2111 | LDA WRD                                 |
| 104 | 7004 | SZA                                     |
| 105 | 4107 | BUN ROT                                 |
| 106 | 410F | BUN STP / Word is zero; stop with CTR=0 |
| 107 | 7040 | ROT, CIL / Bring bit to E               |
| 108 | 7002 | SZE                                     |
| 109 | 410B | BUN AGN / bit=1, go to count it         |
| 10A | 4107 | BUN ROT / bit=0, repeat                 |
| 10B | 7400 | AGN, CLE                                |
| 10C | 6110 | ISZ CTR / Increment counter             |

6-12 (b) Continued

|     |      |               |                              |
|-----|------|---------------|------------------------------|
| 10D | 7004 | SZA           | /check if remaining bits = 0 |
| 10E | 4107 | BUN ROT       | /No; rotate again            |
| 10F | 7001 | STP, HLT      | /Yes; stop                   |
| 110 | 0000 | CTR, HEX 0    |                              |
| 111 | 62C1 | WRD, HEX 62C1 |                              |
|     |      | END           |                              |

6-13  $(100)_{16} = (256)_{10}$  500 to 5FF  $\rightarrow (256)_{10}$  locations

|          |          |                             |  |
|----------|----------|-----------------------------|--|
| ORG      | 100      |                             |  |
| LDA      | ADS      |                             |  |
| STA      | PTR      | /Initialize pointer         |  |
| LDA      | NBR      |                             |  |
| STA      | CTR      | /Initialize counter to -256 |  |
| CLA      |          |                             |  |
| LOP, STA | PTR I    | /store zero                 |  |
| ISZ      | PTR      |                             |  |
| ISZ      | CTR      |                             |  |
| BUN      | LOP      |                             |  |
|          | HLT      |                             |  |
| ADS,     | HEX 500  |                             |  |
| PTR,     | HEX 0    |                             |  |
| NBR,     | DEC -256 |                             |  |
| CTR,     | HEX 0    |                             |  |
|          | END      |                             |  |

6-14

|          |         |                       |  |
|----------|---------|-----------------------|--|
| LDA      | A       | /Load multiplier      |  |
| SZA      |         | /Is it zero ?         |  |
| BUN      | NZR     | /A=0, product=0 in AC |  |
|          | HLT     |                       |  |
| NZR,     | CMA     |                       |  |
|          | INC     |                       |  |
|          | STA CTR | /Store -A in counter  |  |
|          | CLA     | /Start with AC=0      |  |
| LOP, ADD | B       | /Add multiplicand     |  |
| ISZ      | CTR     |                       |  |
| BUN      | LOP     | /Repeat Loop A times  |  |
|          | HLT     |                       |  |
| A,       | DEC -   | /multiplier           |  |
| B,       | DEC -   | /multiplicand         |  |
| CTR,     | HEX 0   | /counter              |  |
|          | END     |                       |  |

6-15 The first time the program is executed, location CTR will go to 0. If the program is executed again starting from location  $(100)_{16}$ , location CTR will be incremented and will not reach 0 until it is incremented  $2^{16} = 65,536$  times, at which time it will reach 0 again.

We need to initialize CTR and P as follows:

|     |     |
|-----|-----|
| LDA | NBR |
| STA | CTR |
| CLA |     |
| STA | P   |

↓  
Program  
↓

|      |        |
|------|--------|
| NBR, | DEC -8 |
| CTR, | HEX 0  |
| P,   | HEX 0  |

6-16 Multiplicand is initially in location XL. Will be shifted left into XH (which has zero initially). The partial Product will contain two locations PL and PH (initially zero). Multiplier is in location Y. CTR=-16

|             |   |                                               |
|-------------|---|-----------------------------------------------|
| LOP, CLE    | ] | same as beginning of<br>Program in Table 6-14 |
| LDA Y       |   |                                               |
| CIR Y       |   |                                               |
| STA Y       |   |                                               |
| SZE         |   |                                               |
| BUN ONE     |   |                                               |
| BUN ZRO     | ] | Double-precision add<br>$P \leftarrow X + P$  |
| ONE, LDA XL |   |                                               |
| ADD PL      |   |                                               |
| STA PL      |   |                                               |
| CLA         |   |                                               |
| CIL         |   |                                               |
| ADD XH      | ] | Same as program<br>in Table 6-15              |
| ADD PH      |   |                                               |
| STA PH      |   |                                               |
| CLE         |   |                                               |

Continued next page

## 6-16 continued

|      |     |                 |                                          |
|------|-----|-----------------|------------------------------------------|
| ZRO, | LDA | XL              | Double-precision<br>left-shift $XH + XL$ |
| CIL  |     |                 |                                          |
| STA  | XL  |                 |                                          |
| LDA  | XH  |                 |                                          |
| CIL  |     |                 |                                          |
| STA  | XH  |                 |                                          |
| ISZ  | CTR | Repeat 16 times |                                          |
| BUN  | LOP |                 |                                          |
| HLT  |     |                 |                                          |

## 6-17

If multiplier is negative, take the 2's complement of multiplier and multiplicand and then proceed as in Table 6-14 (with  $CTR = -7$ ).

Flow-Chart :



6-18

$$C \leftarrow A - B$$

|                         |            |
|-------------------------|------------|
|                         | CLE        |
|                         | LDA BL     |
|                         | CMA        |
|                         | INC        |
|                         | ADD AL     |
|                         | STA CL     |
| save                    | CLA        |
| carry                   | [ CIL      |
|                         | STA TMP    |
|                         | LDA BH     |
|                         | CMA        |
|                         | ADD AH     |
| add carry $\rightarrow$ | ADD TMP    |
|                         | STA CH     |
|                         | HLT        |
|                         | TMP, HEX 0 |

To form a double-precision  
2's complement of subtrahend  
 $BH + BL$ ,  
a 1's complement is  
formed and 1 added once.

Thus, BL is complemented  
and incremented while  
 $BH$  is only complemented.

Location TMP saves the  
carry from E while BH  
is complemented.

6-19

$$z = x \oplus y = xy' + x'y = [(xy')' \cdot (x'y)']'$$

|         |         |
|---------|---------|
| LDA Y   | AND TMP |
| CMA     | CMA     |
| AND X   | STA Z   |
| CMA     | HLT     |
| STA TMP | X, —    |
| LDA X   | Y, —    |
| CMA     | Z, —    |
| AND Y   | TMP, —  |
| CMA     |         |

6-20

|          |                                        |
|----------|----------------------------------------|
| LDA X    |                                        |
| CLE      |                                        |
| CIL      | / zero to low order bit; sign bit in E |
| SZE      |                                        |
| BUN ONE  |                                        |
| SPA      |                                        |
| BUN OVF  |                                        |
| BUN EXT  |                                        |
| ONE, SNA |                                        |
| BUN OVF  |                                        |
| EXT, HLT |                                        |



6-21 Calling program

BSA SUB  
 HEX 1234 /subtrahend  
 HEX 4321 /minuend  
 HEX 0 /difference

subroutine

SUB, HEX 0  
 LDA SBR I  
 CMA  
 INC  
 ISZ SUB  
 ADD SUB I  
 ISZ SUB  
 STA SUB I  
 ISZ SUB  
 BUN SUB I

6-22Calling Program

BSA CMP  
 HEX 100 /starting address  
 DEC 32 /number of words

Subroutine

CHP, HEX 0  
 LDA CMP I  
 STA PTR  
 ISZ CMP  
 LDA CMP I

CMA  
 INC  
 STA CTR  
 LDA PTR I  
 CMA  
 STA PTR I  
 ISZ PTR  
 ISZ CTR  
 BUN LOP  
 ISZ CMP  
 BUN CMP I  
 PTR,  
 CTR,  
 —

6-23

CR4, HEX 0

CIR  
 CIR  
 CIR  
 CIR

BUN CR4 I

|   |                            |      |
|---|----------------------------|------|
| E | <u>AC</u>                  | AC   |
| I | <u>0000 0111 1001 1100</u> | HEX  |
| I | <u>1001 0000 0111 1001</u> | 079C |

6-24

LDA ADS  
 STA PTR  
 LDA NBR  
 STA CTR  
 LOP, BSA IN2 /subroutine Table 6-20  
 STA PTR I  
 ISZ PTR  
 ISZ CTR

BUN LOP  
 HLT  
 ADS, HEX 400  
 PTR, HEX 0  
 NBR, DEC -512  
 CTR, HEX 0

6-25

|     |                                                  |               |
|-----|--------------------------------------------------|---------------|
| LDA | WRD                                              | STA CH2       |
| AND | MS1                                              | HLT           |
| STA | CH1                                              | WRD, HEX -    |
| LDA | WRD                                              | CH1, HEX -    |
| AND | MS2                                              | CH2, HEX -    |
| CLE |                                                  | MS1, HEX 00FF |
| BSA | SR8 /subroutine to<br>shift right<br>eight times | MS2, HEX FF00 |

6-26



6-27

| <u>Location</u> | <u>Hex code</u> |      |     |       |  |
|-----------------|-----------------|------|-----|-------|--|
| 200             | 3213            | SRV, | STA | SAC   |  |
| 201             | 7080            |      | CIR |       |  |
| 202             | 3214            |      | STA | SE    |  |
| 203             | F200            |      | SKI |       |  |
| 204             | 4209            |      | BUN | NXT   |  |
| 205             | F800            |      | INP |       |  |
| 206             | F400            |      | OUT |       |  |
| 207             | B215            |      | STA | PT1 I |  |
| 208             | 6215            |      | ISZ | PT1   |  |
| 209             | F100            | NXT, | SKO |       |  |
| 20A             | 420E            |      | BUN | EXT   |  |
| 20B             | A216            |      | LDA | PT2 I |  |
| 20C             | F400            |      | OUT |       |  |
| 20D             | 6216            |      | ISZ | PT2   |  |
| 20E             | 2214            | EXT, | LDA | SE    |  |
| 20F             | 7040            |      | CIL |       |  |
| 210             | 2213            |      | LDA | SAC   |  |
| 211             | F080            |      | ION |       |  |
| 212             | C000            |      | BUN | ZRD I |  |
| 213             | 0000            | SAC, | —   |       |  |
| 214             | 0000            | SE,  | —   |       |  |
| 215             | 0000            | PT1, | —   |       |  |
| 216             | 0000            | PT2, | —   |       |  |

6-28

|      |     |                    |                  |     |               |
|------|-----|--------------------|------------------|-----|---------------|
| SRV, | STA | SAC                | NXT,             | LDA | MOD           |
|      | CIR |                    |                  | SZA |               |
|      | STA | SE                 |                  | BUN | EXT           |
|      | LDA | MOD /check MOD     | service          | SKO |               |
|      | CMA |                    |                  | BUN | EXT           |
|      | SZA |                    | output           | LDA | PT2 I         |
|      | BUN | NXT / MOD# all 1's | device           | OUT |               |
|      | SKI |                    |                  | ISZ | PT2           |
|      | BUN | NXT                |                  |     |               |
|      | INP |                    |                  |     |               |
|      | OUT |                    |                  |     |               |
|      | STA | PT1 I              |                  |     |               |
|      | ISZ | PT1                |                  |     |               |
|      | BUN | EXT / MOD# 0       | EXT, continue as |     |               |
|      |     |                    |                  |     | in Table 6-23 |