

Microprocessors- Chapter-2  
Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT  
Chapter-2

Assembly Language Programming (10hrs)

**8085 Microprocessor Architecture:**

- ▶ 8-bit general purpose microprocessor
- ▶ Capable of addressing 64K of memory (with 16 address lines).
- ▶ Has 40 pins DIP (Dual Inline Package)
- ▶ Requires +5V power supply
- ▶ Can operate with maximum 3MHz single phase clock and minimum 500 KHz clock.
- ▶ 8085 upward compatible(its instructions and features are available in 8086)
- ▶ It provides 74 instructions with 5 addressing modes

8085  
- 64K address  
- 24 bit 5 bits  
- 8 bit  
- +5V supply  
- 40 pin

**8085 Pinouts and Signals:**



सुगम स्टेसनरी सप्लायर्स एण्ड फोटोकपी सर्विस  
बालकुमारी, ललितपुर ९८४९५९५९२  
NCIT College

Fig. 2.1: 8085 Pinouts



Fig. 2.2: Grouping of 8085 Pinouts

### 8085 Pin Configuration:

- Pins of 8085 are grouped into 6 categories:

#### 1. Address Bus(P21-P28):

- 16 signal lines
- These lines are split into 2 segments A15-A8 and AD<sub>7</sub>-AD<sub>0</sub>.
- 8 signal lines, A15-A8 are unidirectional and are used for



सुगम स्टेसनरी सप्लायर्स एण्ड फोटोकपी सर्विस  
बालकमारी, ललितपुर ९८४९५९५६२  
NCIT College

## Microprocessors- Chapter-2

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Most significant bits, called higher order address of 16-bit address.

### 2. Multiplexed Address/Data Bus (P12-P19):

- They are time multiplexed address and data bus.
- The signal lines AD7-AD0 are bidirectional.
- serve dual purpose:

During execution of instruction cycles, these lines are used as low order address bus

Data bus

- separated by Address Latch Enable (ALE).

### 3. Control and Status Signals(P29 – P34):

- This group includes:

2 control signals: RD and WR.

3 status signals : IO/M, S1 and S0 (to identify the nature of operation) , &

1 special signal : ALE (to indicate the beginning of operation )

#### (i) $\overline{RD}$ (Read) [P 32]:

Active low read control signal

- used to read the selected I/O or memory device and make data available on data bus.

#### (ii) $\overline{WR}$ (Write) [P31]:

Active low write control signal.

- indicated that the data on data bus are to be written on selected memory or I/O device.

#### (iii) $\overline{IO/M}$ (Input – Output / Memory) [P 34]:

- Status signal to differentiate between I/O and Memory operation.



FIGURE 4.1  
The 8085 Microprocessor Pinout and Signals  
NOTE: The 8085 is commonly known as the 8085  
SOURCE: (Pinout) Intel Corporation, Embedded Microprocessors (San Jose, Calif. Author, 1984), pp. 1-11.

- If  $\overline{IO} / \overline{M} = 1$ , input - output operation is done.
- If  $\overline{IO} / \overline{M} = 0$ , memory operation is done.
- These signals are combined with  $\overline{RD}$  and  $\overline{WR}$  control signals to generate I/O and Memory control signals ( $\overline{IOR}$ ,  $\overline{IOW}$ ,  $\overline{MEMR}$ ,  $\overline{MEMW}$ )

**(iv) S1, S0 Signals (S0= P29, s1 = P33):**

|    |    | Operations           |
|----|----|----------------------|
| S1 | S0 |                      |
| 0  | 0  | HLT                  |
| 0  | 1  | Write(Memory or I/O) |
| 1  | 0  | Read(Memory or I/O)  |
| 1  | 1  | Opcode Fetch         |

Similar to IO/M signals and identify various operations

- Rarely used in small operations

**(v.) Address Latch Enable (ALE)/P30]:**

- Active high signal.
- generated at the beginning of every machine cycle.
- Primarily used to latch the lower order address from the multiplexed bus and generate a separate set of 8 address lines A7-A0.

**4. Power Supply and Frequency:**

- $V_{cc}$  : +5V Power Supply
- $V_{ss}$  : Ground Reference
- $X_1, X_2$ :

  - . A crystal RL or LC network

- . Frequency is internally divided by 2, so to operate a system at 3 MHz; the crystal should have a frequency of 6 MHz

**- CLK (OUT):**

- . Used as a system clock for other devices.

**5. Externally Initiated Signals, Including Interrupts:**

- 8085 has 5 interrupt signals, 2 acknowledgement signals and 3 other signals.

**- Interrupt Signals are:**

**RST 7.5, RST 6.5, RST 5.5(Inputs) :**

- They are reset vectored interrupt that transfer the program control to specific location.
- cause internal restart for the system
- have higher priorities than INTR
- Among them the priority order is 7.5, 6.5 and 5.5.

**TRAP (Input):**

- Non-maskable interrupts and has highest priority.

- Used for critical events.

**INTR (Input):**

- Interrupt Request Signal

- Lowest priority signal

- used in data communication between I/O devices and microprocessor.

**INTA (Output)**

- Interrupt Acknowledgement signal.
- Microprocessor sends this signal after receiving INTR signal.

**READY (Input):**

- Used to delay microprocessor Read or Write Cycles until a slow responding peripheral is ready to send or receive data.

- When this signal goes low microprocessor waits and as soon as it goes high it reads the data in bus or writes in it.

#### HOLD (Input):

- Indicates that a peripheral devices e.g. DMA (Direct Memory Access) Controller is requesting the use of address and data buses.
- When this signal goes high, microprocessor stops the Buses as soon as the current cycle is completed.
- Microprocessor regains it when HOLD signal goes low.

#### HLDA (Output):

- This is a Hold Acknowledgement Signal and Acknowledges the HOLD request.
- Goes low when HOLD signal is removed and microprocessor takes over the Buses.

#### RESET - IN [P 36]:

- When the signal on this pin goes low, the Program Counter (PC) is set to zero.
- So, MPU is reset.

#### RESET OUT [P3]:

- It indicates that the microprocessor is being reset.
- This signal can be used to reset other devices,

#### (6.) Serial I/O Devices [P4 and P5]:

- SID (Serial Input Data) and SOD (Serial Output Data) used to implement serial transmission.
- In serial transmission, data are sent over a single line, one bit at a time, e.g. telephone line.



Internal Architecture of Intel 8085 Microprocessor:



Fig 2.3: Functional Block Diagram of 8085 Microprocessor

The internal architecture of 8085 microprocessor consists of:

- (1.) ALU (Arithmetic Logic Unit)
- (2.) Register Array
- (3.) Timing and Control Unit (CU)
- (4.) Instruction Register (IR) and Decoder
- (5.) Interrupt Controller
- (6.) Serial I/O Control

#### 1. Arithmetic and Logic Unit(ALU):

- performs the computing functions.
- It includes:
  - (i) the Accumulator(A) – 8 bit special purpose register used in arithmetic, logic, load and store operations as well as in I/O operations,
  - (ii) The temporary registers (8 bit register used to hold data temporarily during program execution and is not accessible to the programmer.)
  - (iii) The arithmetic and logic circuits, and
  - (iv) Five flag flip-flop registers.

#### Flag Register:

- It is an 8 bit special purpose register (with 5 bits carrying significant information), that generally reflects the intermediate or final status of the result or conditions of data in the accumulator.
- The result of every arithmetic and logic operations are stored in accumulator, and the flags (flip-flops) are set or reset according to the result of the operation.
- Thus, helps in taking further decisions.

The bit positions reserved for different flags in flag register array are as follows:

| D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|----|----|----|----|----|----|----|----|
| S  | Z  | X  | AC | X  | P  | X  | CY |

Fig.2.4. Flag Register Array (where, X = don't care conditions)

#### S-Sign Flag (For -ve no. S=1 and for +ve no. S=0):

- Used for indicating the sign of the data in the accumulator.
- For signed numbers, if D7 bit is 1, the number is viewed as negative number and if it is 0, the number is considered positive.
- Thus after the execution of arithmetic or logic operations, sign flag is set for negative value and reset for positive value.
- In arithmetic operations with signed numbers, bit D7 is reserved for indicating the sign, and remaining 7 bits are used to indicate the magnitude of a number.

#### Z-Zero Flag (if result = 0 , Z=1, if result ≠ 0, Z=0 ):

- This flag is set if the result of the ALU operations is 0 and reset if the result is non-zero.
- This flag is modified by the results in the accumulator as well as in other registers.
- For example:

2<sup>0</sup>

|          |   |          |       |            |
|----------|---|----------|-------|------------|
| 10110011 | + | 01001101 | ----- | 1 00000000 |
|----------|---|----------|-------|------------|

RJSC      RJSCL      SJM      SJL  
Z=1      Z=1      00H      00H

Here, Z = 1 as the result of the operation (addition) is 00H.

10110011  
+ 01001101  
-----  
1 00000000

10110011  
+ 01001101  
-----  
1 00000000

10110011  
+ 01001101  
-----  
1 00000000

10110011  
+ 01001101  
-----  
1 00000000

The internal architecture of 8085 microprocessor consists of:

(1.) ALU (Arithmetic Logic Unit)

(2.) Register Array

(3.) Timing and Control Unit (CU)

(4.) Instruction Register (IR) and Decoder

(5.) Interrupt Controller

(6.) Serial I/O Control

1. Arithmetic and Logic Unit(ALU):

- performs the computing functions.
- It includes:

(i) the Accumulator(A) - 8 bit special purpose register used in arithmetic,

logic load and store operations as well as in I/O operations.  
program execution and is not accessible to the programmer.)

(ii) The temporary registers (8 bit register used to hold data temporarily during

logic load and store operations as well as in I/O operations,  
(iii) The arithmetic and logic circuits, and

(iv) Five flag flip-flop registers.

Flag Register:

It is an 8 bit special purpose register (with 5 bits carrying significant information), that generally reflects the intermediate or final status of the result or conditions of data in the accumulator.

The result of every arithmetic and logic operations are stored in accumulator, and the flags (flip-flops) are set or reset according to the result of the operation.

Thus, helps in taking further decisions.



Fig. 2.4. Flag Register Array (where, X = don't care conditions)

S-Sign Flag: For -ve no. S=1 and for +ve no. S=0

- Used for indicating the sign of the data in the accumulator.
- For signed numbers, if D7 bit is 1, the number is viewed as negative number and if it is 0, the number is considered positive.
- In arithmetic operations with signed numbers, bit D7 is reserved for indicating the value and reset for positive value.
- Thus after the execution of arithmetic or logic operations, sign flag is set for negative value and reset for positive value.
- This flag is set if the result of the ALU operations is 0 and reset if the result is non-zero.
- This flag is modified by the results in the accumulator as well as in other registers.
- For example:

| 2 - 0    |          |
|----------|----------|
| 10110011 |          |
| +        |          |
| 01001101 |          |
|          | -----    |
| 1        | 00000000 |

Flags: SF (Sign Flag), ZF (Zero Flag), AF (Auxiliary Carry Flag), CF (Carry Flag), OF (Overflow Flag).

Here, Z=1 as the result of the operation (addition) is 00H.

- Zero flag is also set if data in register becomes 00H after increment or decrement operation.

#### A.C. Auxiliary Carry Flag (AC = 1 if carry occurs from bit D3 – D4, during addition):

- This flag is set whenever a carry occurs from lower nibble to upper nibble, i.e. when a carry is generated from by digit D3 and passed onto digit D4.

Used for BCD operations.

#### P2. Parity Flag (P=1 for even parity & P=0 for odd parity):

Parity is defined as the number of 1s in the data in accumulator.

- After arithmetic and logical operations, if the result has even number of 1s, this flag is set and reset if it has odd number of 1s.

So, parity flag is set for even parity and reset for odd parity.

E.g. For data byte 0000 0011, P=1, for even no. of 1s although magnitude of no. is odd.

#### C-Carry Flag(C=1, for overflow during addition & borrow during subtraction):

- In an arithmetic operations such as addition and subtraction involving two 8 bit numbers, there is a situation when an add result is overflow from highest order bit or a borrow may be required in subtraction.

In both cases, the carry flag is set, otherwise it is reset.

|                   |                    |
|-------------------|--------------------|
| 1011 0101         | 1011 0101          |
| + 0110 1100       | - 1100 1100        |
| -----             | -----              |
| Carry 1 0010 0001 | Borrow 1 1110 1001 |

#### 2. Register Array:

- 8085 has 8 and 16 bit registers.

- 8 bit registers are B, C, D, E, H, L, Accumulator, and Flag.

- There are two 16 bit registers:

- Program Counter (PC),



Fig 2.4. Register Array in 8085 microprocessor

#### Temporary Register W and Z:

- They hold 8-bit data during the execution of some instruction.
- They are used internally and are not available to the programmer.

#### Temporary Register (near ALU):

- It is an 8 bit register and is used to hold data for brief time period, during and arithmetic/logic operations.

~~Not available to programmer.~~

#### 16-bit registers:

- (i) Program Counter(PC):
- Deals with sequencing and execution of instruction.

- Contains 16 bit address of the next instruction to be executed.
- Acts as a pointer to the next instruction to be executed.
- It is operated by the processor and points the instruction after the processor has fetched the previous one.

(ii) Stack Pointer (SP):

- Stack is the area of Read/Write (RAM) memory used to hold data that will be retrieved soon.

- The beginning of stack is defined by loading a 16-bit address in the Stack Pointer (SP).

- The stack is usually accessed in First -In - Last -Out (FILO) basis or Last- In -First-Out (LIFO) basis.

- Stack writing instructions fill the memory position in progressively decreasing order.

- Instructions for Stack access: PUSH, POP

- During PUSH operation, higher order register content is pushed first.

- E.g. PUSH B, then B pushed and then C.

- Decrementing and Incrementing is always done by 2 bytes, since all the stack operations involve register pair.

3.) Timing and Control Unit:

- This unit synchronizes all the microprocessor operations with the clock and generates the control signals necessary for communication between the microprocessor and peripherals.

- E.g.  $\overline{RD}$  And  $\overline{WR}$  are control signals indicating the availability of data on the data bus.

(4.) Instruction Register and Decoder:

- When instruction is fetched from memory, it is loaded in the Instruction Register (IR).
- Then the decoder decodes the instruction and establishes the sequence of events to follow.

- The instruction register is not programmable and cannot be accessed through any instruction.

(5.) Interrupt Control:

- 8085 has 5 interrupt signals: TRAP, RST 7.5, RST 6.5, RST 5.5, and INTR.
- $\overline{IN74}$  is Interrupt Acknowledgement Signal.
- Valid interrupt may occur for at least 160 ms.

(6.) Serial I/O Control:

- The two 8085 pins: SID (Serial Input Data) and SOD (Serial Output Data) are specially designed for software controlled serial I/O.
- Data transfer is controlled through two instructions: SIM and RIM.
- These instructions are used for interrupt and serial I/O.
- SIM instruction is used to output data serially from the SOD line.
- RIM instruction is used to input serial data through the SD line.
- Bit D7 of RIM and SIM is separated for SID and SOD lines respectively.

8085 Bus Configuration:

- The 8085 microprocessor performs its functions, using three sets of communication lines, called busses.

- (i) The address bus,
- (ii) The data bus, and
- (iii) The control bus.

(i) Address Bus:

- It is a group of 16 lines generally identified as A0 to A15.
- The address bus is unidirectional, i.e. bits flow in one direction from microprocessor to peripheral devices.

- Thus, MPU uses address bus to identify a peripheral or memory location.

In a computer system, each peripheral or memory location is identified by a binary number, called an address, and the address bus is used to carry a 16-bit address.

16 address lines can address up to  $2^{16} = 65,536$  memory locations, or its memory addressing capability is  $2^{16} = 64K$ .

### (ii) Data Bus

It is a group of 8 lines used for data flow.

- These lines are bidirectional i.e. data flow in both directions between the MPU and memory and peripheral devices.

MPU uses data bus to transfer information.

The eight data lines enable the MPU to manipulate 8-bit data ranging from 00 to FF.

$$(2^8 = 256)$$

The largest number that can appear on data bus is  $(1111\ 1111)_2 = (FF)_{16} = (255)_0$ .

### (iii) Control Bus:

- It is comprised of various signal lines that carry synchronization signals.
- MPU uses such lines to provide timing signals.

MPU generates specific control signals for every operation (such as Memory or I/O Read or Write) it performs

- Instruction Word Size:**
- 8085 instruction set is classified into the following 3 groups according to word size or byte size:

#### (1.) 1-byte instructions,

- (2.) 2- byte instructions, and

- (3.) 3- byte instructions.

#### (1.) 1-byte instructions:

- It includes the opcode and operand in the same byte.

e.g., (i) MOV C, A [byte = 4FH]

(ii) ADD B [byte = 80H]

(iii) CMA [byte = 2FH]



- When ALE = 1, the address can be latched, and when ALE = 0, the address is saved.

#### 8085 INSTRUCTIONS

- An instruction is a command to the microprocessor to perform a given task, on specified data.
- Set of instructions is known as program.
- Each instruction has 2 parts: (i) opcode, (ii) operand
- Opcode (operation code) represents the task to be performed and Operand is the data to be operated on.

**(2.) 2-byte instruction:**

- Here 1<sup>st</sup> byte specifies the operation code, and 2<sup>nd</sup> byte specifies the operand.

E.g.s. (i) MVI A, 32H [1<sup>st</sup> byte = 3EH, 2<sup>nd</sup> byte = 32H]

(ii) MVI B, F2H [1<sup>st</sup> byte = 06H, 2<sup>nd</sup> byte = F2H]

**(3.) 3-byte instruction:**

- Here, 1<sup>st</sup> byte specifies the opcode, and following 2-bytes specifies the 16-bit address. E.g.s. (i) LDA 2050H [1<sup>st</sup> byte = 3AH, 2<sup>nd</sup> byte = 50H, 3<sup>rd</sup> byte = 20H]

(ii) JMP 2085H [1<sup>st</sup> byte = C3H, 2<sup>nd</sup> byte = 85H, 3<sup>rd</sup> byte = 20H]

**8085 Instruction Sets**

Since the 8085 is an 8-bit device it can have up to 256 instructions.

- However, the 8085 only uses 246 combinations that represent a total of 74 instructions.

- Most of the instructions have more than one format.

8085 instructions can be grouped into five different groups:

- Data Transfer (Copy) Instructions
- Arithmetic Instructions
- Logic and Bit Manipulation Instructions
- Branch Instructions
- Machine Control Instructions

**1. Data Transfer (Copy) Instructions:**

- These instructions perform the following six operations:

- Load an 8-bit number in a register.
- Load 16-bit number in a register pair.
- Copy from register to register.
- Copy between register and memory.
- Copy between I/O and accumulator.
- Copy between registers and stack memory.

They are:

(i) MVI Rd, data [Loads 8-bit data in a register.]

E.g. MVI B, 4FH

(ii) MOV Rd, Rs [Copy data from source register Rs into destination register Rd]

E.g. MOV B, A

(iii) LXI Rp, 16-bit [Loads 16-bit number in a defined registers pair.]

E.g. LXI B, 2050H

(iv) OUT 8-bit (port address) [Send (write) data byte from the accumulator to an output port (device.)]

E.g. OUT 01H

(v) IN 8-bit (port address) [Accepts (reads) data byte from an input port/device and place it in the accumulator]

E.g. IN 07H

(vi) LDA 16-bit memory address [Copy the data byte into A from the memory specified by 16-bit memory address]

E.g. LDA 2050H

(vii) STA 16-bit memory address [Copy the data byte into memory specified by 16-bit address from A]

E.g. STA 2070H

(viii) LDAXX Rp [Copy the data byte into A from the memory specified by the address in the register pair]

E.g. LDAX B

(ix) STAXX Rp [Copy the data byte from A into the memory specified by the address in the register pair]

E.g. STAX D

(x) MOV M, R [Copies the content of specified register to the memory location specified by HL pair]

E.g. MOV M, B

## Microprocessors- Chapter-1

Prepared By:

Er. Ramu Pandey, Asst. Prof., NCIT

(x) MOV R, M

[Copies the content of the memory location specified by HL pair to the register specified.]

e.g. MOV R, D

[Store H and L Register Direct]

(xi) SHLD address

[Store H and L Register Direct]  
Flags set, S=0, Z=0 and CY=1]

e.g. SHLD 2050H ( here, assume HL registers contain 01H and FFH respectively.)

e.g. SHLD 2050H ( here, assume HL registers contain 01H and FFH respectively.)

then after executing above instruction 2050H = FFH and 2051H = 01H respectively.)

(xii) LHD address

[Load H and L Register Direct]  
e.g. LHD 2050H ( here, assume 2050H = FFFH and 2051H = 01H respectively, then after executing above instruction, [H] = 01H and [L] = FFH respectively.)

(xiii) XCHG

[Exchange contents of H and L with D and E respectively]

e.g. XCHG

[Load H and L Register Direct]

(xiv) ADC M

[Add contents of memory to A, the address of memory is in HL register]

e.g. ADD M

[Add contents of memory to A, the address of memory is in HL register]

(xv) ADC R

[Adds the contents of specified register to A, including carry]

e.g. ADC B

[Adds with carry the content of memory address stored in HL pair to the content of A]

e.g. ADC M

[Adds with carry the 8-bit data in the instruction to A]

(xvi) ACI 8-bit data

[Adds with carry the 8-bit data in the instruction to A]  
e.g. ACI 33H

(xvii) DAD RP

[Adds contents of specified register pair to the content of HL pair i.e. used for 16 bit addition]

e.g. DAD B ( suppose initially [HL] = 0242H and [BC] = 0123H )

(xviii) ADD R

[Add the contents of specified register to the contents of accumulator (A) and store the final result in A.]

(xix) SUB R

[Subtracts the content of specified register from the content of A]

(xx) INC R

[Increments / Decrement can be performed on any 8 or 16 bit register content.]

The different arithmetic instructions of 8085 microprocessor are:

(i) Addition:

(i) ADD R [Add the contents of specified register to the contents of accumulator (A) and store the final result in A.]

(ii) SUB R

[Subtract the contents of specified register from the content of A]

(iii) SUI 8-bit data

[Subtract the content of specified register from the content of A]

(iv) SBB R

[Subtract the content of specified register from the content of A]

(v) SBI 8-bit data

## Microprocessors- Chapter-2

Prepared By:

Er. Ramu Pandey, Asst. Prof., NCIT

(i) ADD B

[let A = 93H and B= B7H, now result after ADD B , in A = 14AH so Flags set, S=0, Z=0 and CY=1]

(ii) ADI 8-bit data

[ Add 8-bit data to the contents of A ]

(iii) ADD M

[Add contents of memory to A, the address of memory is in HL register]

(iv) ADC R

[ Adds the contents of specified register to A, including carry]

(v) ADC M

[ Adds with carry the content of memory address stored in HL pair to the content of A]

(vi) ACI 8-bit data

[Adds with carry the 8-bit data in the instruction to A]

(vii) DAD RP

[Adds contents of specified register pair to the content of HL pair i.e. used for 16 bit addition]

e.g. DAD B ( suppose initially [HL] = 0242H and [BC] = 0123H )

(viii) ADD R

[Add the contents of specified register to the contents of accumulator (A) and store the final result in A]

(ix) SUB R

[Subtract the content of specified register from the content of A]

(x) INC R

[Increments / Decrement can be performed on any 8 or 16 bit register content.]

(xi) DEC R

[Decrements / Increment can be performed on any 8 or 16 bit register content.]

(xii) SUI 8-bit data

[Subtract the content of specified register from the content of A]

(xiii) SBB R

[Subtract the content of specified register from the content of A]

(xiv) SBI 8-bit data

[Subtract the content of specified register from the content of A]

### (iii) Increment/Decrement:

- (i) INR R ; Increment content of R by 1
- (ii) INR M ; Increment content of HL pair by 1  
[e.g. INX B; increments the content of BC by 1]
- (iii) INX Rp ; Decrement content of R by 1
- (iv) DCR R ; Decrement content of HL pair by 1
- (v) DCR M ; Decrement content of BC by 1
- (vi) DCX Rp [e.g. DCX B; decrements the content of BC by 1]

### (iii) Logical and Bit Manipulation Instructions:

These instructions perform :

- (i) AND, (ii) OR, (iii) X-OR (exclusive OR) (iv) Compare (v) Rotate Bits

- These instructions implicitly assume that the accumulator is one of the operand and place the final result in A.

- The various instructions available under this category are:

- (i) ANA R ; Logically ANDs the content of specified register to the content of A and store the final result in A
- (ii) ANI 8-bit data
- (iii) ANA M
- (iv) ORA R ; Logically ORs the content of specified register to A
- (v) XRA R ; Exclusive ORs the content of R and A
- (vi) XRI 8-bit data
- (vii) XRA M

\* Logical instructions are used for masking (hide certain bit) operation

E.g.s, ANI 80H (Masks all other bits except MSB)

ANI 01H (Masks all other bits except LSB)

### Compare Instructions:

- (i) CMP R (ii) CPI 8-bit data (iii) CMP M

For these instructions:

If A>R , Cy is set and Z is reset.  
If A<R , Cy is set and Z is reset.

(So, here we compare the data by checking the carry flags after executing these instructions.)  
Complement(Logical NOT or does its complement):

- (i) CMC (Complements Cy Flag)
- (ii) CMA (Complements contents of Register A)

### Other bit-manipulation instructions:

- (i) RAL ; Rotate Accumulator Left through Carry-bit D7 is placed in the carry flag and carry flag is placed in LSB (9-bit rotation)
- (ii) RAR ; Rotate Accumulator Right through Carry-bit D0 is placed in the carry flag and carry flag is placed in MSB (9-bit rotation)
- (iii) RLC ; Rotate Accumulator Left - D7 bit is placed in D0 as well as in carry flag (8-bit rotation)
- (iv) RRC ; Rotate Accumulator Right - D0 bit is placed in D7 as well as in carry flag (8-bit rotation)

Note: RLC can be used to multiply a number by 2 and RRC can be used to divide a number by 2.

### (iv) Branch Instructions:

- These are used to change the program sequence.

#### Unconditional:

- (i) JMP 16-bit address ; Unconditional jump to specified address

#### Conditional:

- (i) JZ 16-bit address ; Jump to specified address if Zero Flag is set (if Z=1) or result is zero

|                           |                                                                     |
|---------------------------|---------------------------------------------------------------------|
| (ii) JNZ 16-bit address   | ; Jump to specified address if Not Zero (if Z=0)                    |
| (iii) JC 16-bit address   | ; Jump to specified address if Carry (i.e. if carry flag, CY=1)     |
| (iv) JNC 16-bit address   | ; Jump to specified address if Not Carry (i.e. if carry flag, CY=0) |
| (v) JP 16-bit address     | ; Jump to specified address on Positive (i.e. if sign flag, S=0)    |
| (vi) JM 16-bit address    | ; Jump to specified address on Negative (i.e. if sign flag, S=1)    |
| (vii) JPE 16-bit address  | ; Jump on even parity (i.e. if parity flag, P=1)                    |
| (viii) JPO 16-bit address | ; Jump on odd parity (i.e. if parity flag, P=0)                     |
| (ix) CALL 16-bit address  | ; Subroutine call                                                   |
| (x) RET                   | ; Return to main program from the subroutine.                       |

#### (v) Machine Control Instructions:

(i) HLT ; Stop and wait for the next program

(ii) NOP ; No operation

#### Addressing Modes in 8085 Microprocessor:

- The various ways in which processor can access data, during program execution are referred to as its addressing modes.

- In other word, the way in which the operand is specified is called its addressing modes.

- Best selection of addressing mode helps in reducing the computational complexity in any program.

#### (iii) Register Addressing Mode:

- In this addressing mode, registers are used to define the data . i.e. both source and destination.
- e.g. MOV A, B ; Copies the content of Register B to Accumulator.
- ADD D ; Adds the content of Accumulator and D register and store the result in Accumulator.

#### (iv) Register Indirect Addressing Mode:

- In this addressing mode, the register pair are used to define the memory address of data.

e.g. LDAX B ; Copy the data byte into A from the memory specified by the address in the register pair BC

STAX D; Copy the data byte from A to the memory specified by the address in the register pair DE

- The operand is the data present in the instruction i.e. the data is present in the instruction itself.

- Operands can be of 8 or 16-bits in size.

(v) Implied Addressing Mode:

- In this addressing mode, the operand for the instruction is hidden and it is normally the Accumulator (A).

e.g. CMA ; Complements (Is complement) the value of Accumulator

RRC ; Rotate Accumulator Right - D0 bit is placed in D7 as well as

in carry flag

RLC ; Rotate Accumulator Left - D7 bit is placed in D0 as well as  
in carry flag

Register Transfer Language (RTL)

- > Every digital modules in digital system are best defined by the registers they contain and the operations that are performed on the data stored in them.
- > The operations executed on data stored in registers are called microoperations. The result of the operation may replace the previous binary information of a register or may be transferred to another register. Examples of microoperations are shift, count, clear, and load.
- > It is possible to specify the sequence of microoperations in a computer by explaining every operation in words, but this procedure usually involves a lengthy descriptive explanation. So, we use symbolic notation to describe these microoperations.
- > The symbolic notation used to describe the microoperation transfers among registers is called a Register Transfer Language (RTL).
- > The term 'Register Transfer' implies the availability of hardware logic circuits that can perform a stated microoperation and transfer the result of operation to the same or another register. And the 'Language' refers to programming language that denotes the procedure for writing symbols to specify a given computational process. Thus, a register transfer language is a system for expressing in symbolic form the microoperation sequences among the registers of a digital module.
- > In RTL, the registers are generally denoted by capital letters and the information transfer from one register to another register is designated in symbolic form by means of a replacement operator. The general example of register transfer language can be as:

$RI \leftarrow R2$

- This statement denotes a transfer (replacement) of content of register R2 into register RI but the content of register R2 does not change after the transfer.
- > Moreover, in RTL we can also show the predetermined control condition. For example:

P:  $RI \leftarrow R2$

Here, P is a control signal generated in the control section. The above example specifies that the content of register R2 is only transferred to RI, if and only if P=1.

- > We can also define the different instructions used in 8085 and 8086 microprocessors using RTL as follows:

MOV A, B ; A  $\leftarrow$  B  
ADD B ; A  $\leftarrow$  [A] + [B]

Stack and Subroutine:

- > The stack is a group of memory locations in a R/W memory that is used for temporary storage of binary information during execution of a program.
- > The starting memory location of stack is defined in the main program, and space is reserved.
- > The method of information storage resembles a stack of books.
- > Stack works on the basis of rule Last-in-First-Out (LIFO) or First-in-Last-Out.
- > The beginning of stack is defined in the program by using the instruction:

LXI SP, 16-bit address

which loads a 16-bit memory address in the stack pointer register of the microprocessor.

E.g. LXI SP, 2099H

Here, Stack Pointer(SP) register is loaded with the memory address 2099H and storing of data bytes begins from 2098H and continues in the decreasing order of memory address.

- > PUSH and POP instructions are used to insert into and retrieve data from the stack
- > Because 2 data bytes are being stored at a time, the 16-bit memory address in stack is decremented by 2 while storing the data byte and address is incremented by 2 while retrieving the data byte.



### TIMING DIAGRAM 8085

- Timing Diagram is a graphical representation of instruction execution in steps with respect to the clock.

The execution time is represented in T-states.

The following control signals, status signals and buses must be shown in the Timing Diagram:

- Higher Order Address Bus,

- Lower Order Address Bus

- ALE - WR - RD - IO/M, S1 and S0



#### T-state:

- Defined as one subdivision of operation performed in 1 clock period.

- 1 T-state is precisely equal to 1 clock-period.

#### Machine Cycle:

- Time required to perform 1 operation may be opcode fetch, memory read, memory write or I/O read or I/O write is called a machine cycle.

- Consists of 4 to 6 T-states.

#### Instruction Cycle:

- Time required to execute an instruction is called an instruction cycle.

In 8085 microprocessor, the instruction cycle consists of 1 to 5 machine cycles.

#### Combination of Status Signals

| Machine Cycle | IO/M | S <sub>1</sub> | S <sub>0</sub> |
|---------------|------|----------------|----------------|
| Opcode fetch  | 0    | 1              | 1              |
| Memory read   | 0    | 1              | 0              |
| Memory write  | 0    | 0              | 1              |
| I/O read      | 1    | 1              | 0              |
| I/O write     | 1    | 0              | 1              |

#### M<sub>n</sub> - Machine Cycle

#### T<sub>n</sub> - T State

- Machine Cycles of 8085
- The 8085 Microprocessor has 5 basic machine cycle:

1. Opcode Fetch Cycle (4T- 6T states)
2. Memory read Cycle (3T state)
3. Memory Write Cycle (3T state)
4. I/O Read Cycle (3T state)
5. I/O Write Cycle (3T state)

### 1. Opcode Fetch Machine Cycle

- Each instruction of the processor has one byte opcode.
- The opcodes are stored in memory. So, the processor executes the opcode fetch machine cycle to fetch the opcode from memory.
- Hence, every instruction starts with opcode fetch machine cycle.
- The time taken by the processor to perform opcode fetch is 4-6 T states.
- When it has 41 states, the initial 3 T-states are used to fetch the instruction from memory and 4<sup>th</sup> T-state is used to decode and execute the instruction.



Fig. 2.5: Data Flow Diagram from Memory to MPU

### Timing Diagram of Opcode Fetch Machine Cycle:



Instructions that require T<sub>5</sub> & T<sub>6</sub> states for Opcode Fetch:

| Instruction         | Operation performed               |
|---------------------|-----------------------------------|
| CALL                | Stack pointer is decremented by 1 |
| CALL conditional    | Stack pointer is decremented by 1 |
| PUSH R <sub>p</sub> | Register pair decremented by 1    |
| DCX R <sub>p</sub>  | Register pair decremented by 1    |
| INX R <sub>p</sub>  | Register pair incremented by 1    |
| PC+HL               | HL pair transferred to PC         |
| SPHL                | HL pair transferred to SP         |
| RET conditional     | The condition of flags checked    |

### 2. Memory Read Machine Cycle of 8085:

- > The memory read machine cycle is executed by the processor to read a data byte from the memory.
- > The processor takes 3T states to execute this cycle.
- > The instruction which has more than one byte word size, use this machine cycle after opcode fetch machine cycle.

Timing Diagram of Memory Read Machine Cycle:



### 3. Memory Write Machine Cycle of 8085:

- > The memory write machine cycle is executed by the processor to write a data byte in a memory location.
- > The processor takes 3T states to execute this machine cycle.

Timing Diagram of Memory Write Machine Cycle



Note: In memory write machine cycle , there is no tri-state in T2 state.



**4. I/O Read Machine Cycle of 8085:**

- The I/O Read Machine Cycle is executed by the processor to read a data byte from the I/O Port or from the peripheral, which is I/O mapped in the system.
- The processor takes 3T states to execute this task.
- The IN instruction uses this machine cycle during the execution.

Timing Diagram of I/O Read Machine Cycle:

**5. I/O Write Machine Cycle of 8085 (Used by OUT instruction)**

Timing Diagram of I/O Write Machine Cycle:



### Timing Diagram of MOV R1,R2

Timing Diagram of MOV R1,R2



Instructions having similar Timing Diagram:

|                         |                      |
|-------------------------|----------------------|
| ALL MOV R1,R2           | ALL ADD R            |
| ALL ADC R               | CMA, CMC, STC        |
| ALL CMP R               | ALL INR R            |
| ALL DCR R               | ALL ORAR, ANAR, XRAR |
| ALL ROTATE INSTRUCTIONS | ALL SUB R            |
| ALL SBB R               | RIM, SIM             |
| DAA                     | EL1, DI              |
| NOP                     | XCHG                 |

Timing Diagram of MVI A, 32H

Assume Memory Address as :

|       |                          |
|-------|--------------------------|
| 2000H | 3EH<br>(Opcode of MVI A) |
| 2001H | 32H (data)               |

### Timing Diagram of MVI A, 32H



**Instructions having Similar Timing Diagram like that of MVI A,32H:**

|          |            |
|----------|------------|
| ADI DATA | ANI DATA   |
| ACI DATA | ORI DATA   |
| SUI DATA | XRI DATA   |
| SBI DATA | MVI R,DATA |

**Important Instructions:**

- (i). MOV A,C - Op code Fetch
- (ii). MVI A,33H - Op code Fetch, Memory Read
- (iii). LXI B,2065H- Op code Fetch, Memory Read, Memory Read, Memory Write
- (iv). STA C00AH - Op code Fetch, Memory Read, Memory Read, Memory Write
- (v). MOV A,M- Op code Fetch, Memory Read
- (vi). IN 84H- Op code Fetch, Memory Read, I/O Read
- (vii). OUT 80H- Op code Fetch, Memory Read, I/O Write
- (viii). STAX B - Op code Fetch, Memory Write

**Execution of an Instruction:**

How long does it take to execute the two-byte instruction (e.g. MVI A,32H) if the working clock frequency of the microprocessor is 2MHz?

Solution:

Here, Clock frequency,  $f = 2\text{ MHz}$

Time period or Time for 1 T-state =  $1/f = 1/(2 \times 10^6)\text{ }\mu\text{s} = 0.5\text{ }\mu\text{s}$

Execution time for opcode fetch ( $4T$ ) =  $4 * 0.5\text{ }\mu\text{s} = 2\text{ }\mu\text{s}$

Execution time for memory read ( $3T$ ) =  $3 * 0.5\text{ }\mu\text{s} = 1.5\text{ }\mu\text{s}$

Execution time for instruction =  $2\text{ }\mu\text{s} + 1.5\text{ }\mu\text{s} = 3.5\text{ }\mu\text{s}$



FIGURE 5.1  
8085 Timing for Execution of OUT Instruction

Assembly Language Programs(ALPs in 8085 Microprocessor):

1. Write a program to perform the following:

- Load the no. 1BH in D
- Load the no. B5H in B
- Increment the content of B by 1.
- Decrement the content of D by 1.
- Subtract the content of D from the content of B.
- Display the result at OUT port 1.

**Solution:**

MVI D, 1BH

MVI B, B5H

INR B

DCR D

MOV A, B

SUB D

OUT PORT1

HLT

rate device  
tied.

I/O device:  
I generate a  
is combined  
able an out-



FIGURE 5.2  
8085 Timing for Execution of IN Instruction

- WAP to load the data byte in the register C. Mask the high-order bits (D7-D4) and display the low order bits (D3-D0) at output. Exclusive-OR the result with 57H and display at OUT PORT2.

**Solution:**

MVI C, A8H

MOV A, C

ANI OFH

OUT PORT1

XRI 57H

OUT PORT2

HLT

3. WAP to load the byte 8EH in register D and F7H in register E. Mask the higher order bits (D7-D4) from both the data bytes , EX-OR the low order bit (D3-D0) and display the answer.

Solution:  
MVID.8EH  
MOVA,D  
ANI  
MVID.8EH  
MVI,E,F7H  
MOV,A,D  
ANI,0FH  
MOV,D,A  
MOV,A,E  
ANI,0FH  
XRA,D  
OUT PORT1  
HLT

5. Write an ALP to do the following:  
a) Load A with byte 1.  
b) Load B with byte 2.  
c) Compare the equality of the contents of A and B  
d) If two nos. are equal, display 01 otherwise display 00H at port 1.

Solution:  
MVI,A,byte1  
MVI,B,byte2  
SUB,B  
JNZ,loop  
MVI,A,01H  
OUT PORT1  
HLT  
loop: MVI,A,00H  
OUT PORT  
HLT

4. Write a program to load two unsigned numbers in register B and C respectively. Subtract C from B. If the result in 2's complement convert the result in absolute magnitude and display it port 1. Otherwise display the result.

Solution:

```
MVIB,byte1  
MVIC,byte2  
MOV A,B  
SUB,C  
JNC,label1  
CMA  
ADI01H  
label1: OUT PORT1  
HLT
```

6. The following block of data is stored in memory location from C055 to C05A H. Transfer the entire block of data to the locations C080 to C085 H in reverse order.  
Data: 22, A5, B2, 99, 7F, 37

Solution:

```
LXI H,C055H  
LXI D,C085H  
MOV B,06H  
next:MOV A,M  
STAXD  
INX H  
DCX D  
DCR B
```

JNZ next

7. Write a program to find larger of two nos. 1<sup>st</sup> no in C001 and 2<sup>nd</sup> no in C002 and result in

C003 H.

Solution:

```
LXI H, C001 H  
MOV A, M  
INX H  
CMP M  
JNC loop  
MOV A, M  
loop: STA C003 H  
HLT
```

9. Write an ALP to multiply two nos; eg 05 H × 08 H

Solution:

```
MVI A, 00H  
MVI B, 08H  
MVI C, 05H  
loop: ADD B  
DCR C  
JNZ loop  
STA C000H  
HLT
```

8. Write an ALP to find the smallest no in a data array. Data from location C000H to C005H,

Solution:

```
LXI H, C000H  
MVI C, 06H  
MOV A, M  
DCR C  
loop: INX H  
CMP M  
JC loop1  
MOV A, M  
loop1: DCR C  
JNZ loop1  
STA C000H  
HLT
```

10. Write an ALP for the following addition.  
 $1^2 + 2^2 + 3^2 + 4^2 + 5^2 + 6^2 + 7^2 + 8^2 + 9^2$

Solution:

```
MVI A, 00H  
MVI B, 09H  
loop1: MOV C, B  
loop2: ADD B  
DCR C  
JNZ loop2  
DCR B  
JNZ loop1  
OUT PORT1  
HLT
```

11. Write an ALP to count the no. of 1 in the given string '0100110' and display the result at COCOH.

Solution:

```
MVI A, A6H  
MVI B, 00H  
MVI C, 08H  
loop1: RAL  
JNC loop2  
INR B  
loop2: DCR C  
JNZ loop1  
MOV A,B  
STA COCOH  
HLT
```

12. The following data are stored in memory location starting from C0B0 to C0B9 H . Take a test no. 48. Find out how many times the no 48 is repeated. Display the result at COCOH.

DADA: 12, 23, 34, 45, 48, 56, 48, 67, 48, 89.

Solution:

```
SHLD 2504 H  
HLT
```

13. 8 bit multiplication, product is 16 bit. The multiplicand is loaded in the two consecutive memory locations 2501H and 2502H. The multiplier is stored in 2053 H. Store the product in 2504 and 2505 H.

Solution:

```
LHD 2501 H  
XCHG  
LDA 2503 H  
LXI H, 0000  
MVI C, 08  
loop1: DAD H  
RAL  
JNC loop2  
DAD D  
loop2: DCR C  
JNZ loop1  
HLT
```

14. Write an ALP to divide two nos. The dividend is in C001 and divisor is in C002. Store the quotient in COCOH and remainder in C0C1.

Solution:

```
LXI H, C0B0H  
MVI B, 00H  
MVI C, 0AH  
loop1: MOV A,M  
CPI 48H  
JNZ loop2  
INR B  
loop2: INX H  
MOV C,M  
MVI C, 00H  
loop1: CMP B  
JC loop2  
INR C  
SUB B  
JNZ loop1  
DCR C  
JNZ loop1  
MOV A,B
```

MOV A,C  
STA COCOH  
HLT

15. To arrange 54, EB, 85, A8 & 99 in descending order. These numbers are stored in the memory location 2501 to 2505 H. The count = 05 is restored in 2500 H. Results are to be stored in 2601 to 2605 H.

Solution:

LXI D, 2601 H  
LXI H, 2500 H  
MOV B, M

Start CALL Subroutine 1

STAX D

CALL Subroutine2

INX D

DCR B

JNZ start

HLT

Subroutine 1:

LXI H, 2500H

SUB A

LXI H, 2501H

MOV C,M

Loop1: INX H

CMP M

JNC loop2

MOV A,M

Loop2: DCR C

JNZ loop1

RET

Subroutine2:

LXI H, 2500H

MOV C,M

Loop1

Note: Subroutine1 gives the largest number of array. Subroutine2 finds the largest number and replaces it by 00.

16. Write an ALP in 8085 to find whether the given number is palindrome or not.

Solution:

lxi h, 1221h

mvi c, 04h

mov a,l

again: rrc

dec c

jnz again

sub b

jnz again1

lxi h,fifth

hit

again1: lxi h,0000h

hlt

17. Write an ALP in 8085 to find the number of 1's in given 10 bytes.

Solution:

fit

19. Write an ALP to find the successive Fibonacci series (up to 10<sup>th</sup> term) and store the result starting from memory location 3000H.

**Solution:**

```
lxi h,2000h
ldi d,3000h
again: mvi c,08h
        mvi b,00h
        mov a,m
        rotate: ral
                jnc again
                inr b
again: der c
        jnz rotate
        mov a,b
        stax d
        inx h
        inx d
        mov a,l
        cpi 0ah
        jnz again]
        hlt
```

```
loop: mvi a,0
        mvi b,1
        lxi h,3000
        mvi c,0ah
        add b
        mov d,a
        mov a,b
        mov b,d
        der c
        jnz loop
        hlt
```

18. Write an ALP to divide two numbers; dividend is stored in memory location 2000H and divisor in memory location 2001H.

**Solution:**

20. Write an ALP to subtract two 16-bit numbers stored at memory locations starting from 2000H and 2003H and store the result at memory locations starting from 200AH.

**Solution:**

```
;to divide the two number in hex
mvi e,00h
ida 2000h
mov b,a
ida 2001h
mov d,a
mov a,b
again:sub d
        again:sub d
        jc loop
        inr e
        jump again]
loop: adc d
        sta 3000h
        mov a,e
        sta 3001h
```

```
LHLD 2000H
XCHG
LHLD 2003H
MOV A,L
SUB E
MOV L,A
MOV A,H
SBB D
MOV H,A
SHLD 200AH
HLT
```

21. Write an ALP in 8085 to add two 32-bit numbers

Note: 4 memory locations are required to store each byte of 32-bit data and we assume two starting memory locations as 2000H and 3000H for adding them

LXI H, 2000H; starting address of first 32-bit data  
LXI B, 3000H; starting address of second 32-bit data  
LXI D, 4000H; starting address to store added result  
MOV C, 0AH; loop counter  
addnextrabyte LDAX B; load data byte from memory pointed by BC pair to  
; accumulator

MOV B, M; load the data byte stored in memory location pointed by HL pair ;to B

ADC B; Adds the content of A and B i.e. first byte is added

STA X D; store the result in memory locations pointer by DE pair

INX H  
INXB  
INXD  
DCR C  
JNZ addnextrabyte  
HLT

22. Write an ALP in 8085 to find the square root of a number.

Hint:

Initialize two registers one with initial value 00H (say, C) and other with 01H (say, E), load the number from memory location to find square root to A, start the loop to subtract E from A and increment its value by 2, and increment C, compare E with A , repeat the loop till E equals A. When E equals A, C contains the desired square root of a number.

Solution:

LXI H, 2000H  
MOV A, M ; Load the number 2000H to Accumulator to find its square root  
MVIC, 00H ; Clear C to store square root  
MVI E, 01H ; Load 01H in E to compare  
Loop: SUB E ; Subtract E from A to check whether A equals E  
INR E  
INR C  
CPI 00H; Check whether after subtraction result is 0,i.e either E equals A  
JNZ Loop; if E is not equal to A, jump to Loop  
MOV A, C  
STA 2001H ; Store result or square root of a number stored in 2000H in 2001H  
HLT

Code Conversion Programs:

BCD TO BINARY Conversion:

The conversion of a BCD number into its binary equivalent employs the principle of *position-weighting* in the given number.

For example:  $72_{10} = 7 \times 10 + 2$

The digit 7 represents 70 based on its second position from the right. Therefore, converting  $72_{BCD}$  into its binary equivalent requires multiplying the second digit by 10 and adding the first digit.

Algorithm:

- 1) Separate an 8-bit packed BCD number into two 4-bit unpacked BCD digits: BCD1 and BCD2.
- 2) Convert each digit into its binary value according to its position.
- 3) Add both binary numbers to obtain the binary equivalent of the BCD number.

Program:

```
LDA 2000H ; Load BCD number from memory location 2000H
MOV B, A; Store in B for future use
ANI 0FH ; Mask most significant four bits
MOV C, A; Save unpacked BCD1 in register C
MOV A, B; Get BCD again
ANI F0H ; Mask least significant four bits
RRC ; Rotate right and convert most significant four bits to least significant four bits as BCD2
RRC
RRC
RRC

MOV B, A; Save unpacked BCD2 in B register
XRA A, C; Clear accumulator to store sum
MUL D, 0AH ; Set D as a multiplier of 10
```

BINARY TO BCD Conversion:

The conversion of binary to BCD is performed by dividing the number by the powers of ten; the division is performed by subtraction method.

For example, assume the binary number:

$$1111\ 1111_2 = FFH = 255_{10}$$

To represent this number in BCD requires twelve bits or three BCD digits, labeled here as BCD<sub>3</sub> (MSB), BCD<sub>2</sub>, and BCD<sub>1</sub> (LSB)

$$= 0010\ 0101\ 0101 \text{ (equivalent of 2, 5 and 5)}$$

BCD<sub>3</sub>, BCD<sub>2</sub>, BCD<sub>1</sub>.

The conversion can be performed as follows:

1. If the number is less than 100, goto step 2, otherwise divide by 100 or subtract 100 repeatedly until the remainder is less than 100. The quotient is the most significant BCD digit, BCD<sub>3</sub>.
2. If the number is less than 10, goto step 3, otherwise divide by 10 repeatedly until the remainder is less than 10. The quotient is BCD<sub>2</sub>.
3. The remainder from step 2 is BCD<sub>1</sub>.

Program:

```
LXI SP, 27FFH : Initialize stack pointer
LDA 6000H : Get the binary number in accumulator
CALL SUBROUTINE : Call subroutine
HLT : Terminate program execution
```

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Prepared By: Er. Ramu Pandey, Asst. Prof., NCIT

Subroutine to convert binary number into its equivalent BCD number:

```

SUBROUTINE:          ; Subroutine to convert binary number into its equivalent BCD number:
PUSHB              ; Save BC register pair contents
PUSHD              ; Save DE register pair contents
PUSHD              ; Load divisor decimal 10 in C register
MVIB, 64H          ; Initialize Digit1
MVIC, 0AH          ; Initialize Digit2
MVID, 00H          ; Initialize Digit1
MVE, 00H          ; Initialize if number < Decimal 100
STEP1: CMPB         ; Check if number < Decimal 100
JC STEP2           ; If yes go to step 2
SUBB              ; Subtract decimal 100
INRE               ; Update quotient
JMP STEP1          ; Go to step 1
STEP2: CMPC         ; Check if number < Decimal 10
JC STEP3           ; If yes go to step 3
SUBC              ; Subtract decimal 10
INRD               ; Update quotient
JMP STEP2          ; Continue division by 10
STEP3: STA 6100H      ; Store Digit0
MOV A, D           ; Get Digit1
STAX D             ; Store Digit1
MOV A, E           ; Get Digit2
STAX D             ; Store Digit2
POP D              ; Restore DE register pair
POP B              ; Restore BC register pair
RET                ; Return to main program

CALL ASCII          ; Call conversion routine
STAX D             ; Store first ASCII Hex in COOAH
INXD               ; Point to next memory location, get ready to store next byte
MOV A, B           ; Get number again for second digit
CALL ASCII          ; Call conversion routine
STAX D             ; Store second ASCII Hex in COOAH
HLT                ; Halt

```

ASCII: This subroutine converts a binary digit between 0 to F to ASCII Hex code

ANJ OFH ; Mask high-order nibble

CPI OAH ; Is digit less than 10?

JC CODE ; If digit is less than 10 goto CODE to add 30H

ADI 07H ; Add 7H to obtain code for digits from A to F.

CODE: ADI 30H ; Add base number 30H

RET ; Return to main program

ASCII TO HEX Conversion:

Algorithm

- 1) Load the ASCII number in to the accumulator.
- 2) Subtract 30h from the number.
- 3) Compare the number with 0A.
- 4) If number < 0A, then store result and exit else go to step 5.
- 5) Subtract 07h from the number and store result.
- 6) Terminate the program.

Program:

```
LDA 2000H
SBI 30H
CPI 0AH
JC AHHEAD
SBI 07H
AHEAD: STA 2001H
HLT
```

Counter and delay:

Timing delay using one register:  
MVI C, FFH ..... 7 T state

Loop DCR C ..... 4 T state  
JNZ Loop ..... 10 or 7 T state

Consider a micro computer with 2 MHZ frequency

Clock period,  $T = 1/f = \frac{1}{2} = 0.5 \mu\text{sec}$

Delay for inst. Outside the loop,  $T_0 = \text{No of T state} \times T$   
=  $7 \times 0.5$

Delay for inst inside the loop,  $T_1 = \text{No of T state} \times T * (N_{i0})$   
=  $(14 \times 0.5 \times 10 - 6 \times 255)$   
=  $1785 \mu\text{sec}$

Now,  $T_{LA} = T_1 - 3 \times 0.5$   
=  $1785 - 1.5$   
=  $1.7835 \text{ ms}$

$$\begin{aligned}T_D &= T_0 + T_L \\&= 3.5 + 1785 \\&= 1788.5 \\&= 1.7885 \text{ ms}\end{aligned}$$

Time delay for register pair:

|                     |            |
|---------------------|------------|
| LXI B, 2344 H ..... | 10 T state |
| Loop DCXB .....     | 6 T state  |
| MOV A, C .....      | 4 T state  |
| ORA B .....         | 4 T state  |
| JNZ loop .....      | 10/7       |

Delay calculation:

$$\begin{aligned}T_0 &= T_{state} * T \\&= 10 \times 0.5 \times 10^{-3} \\&= 10\text{ ms} \\T_L &= \text{No of T state} * T * (N_{IO}) \\&= 24 * 0.5 * 90.92 \\&= 109.108\text{ ms} \\&\approx 109\text{ ms}\end{aligned}$$

$$\text{Total Delay} = T_0 + T_L$$

Time delay using a loop within a loop:

$$\begin{aligned}&\text{MOV B, } 38\text{H ..... } 7\text{ T} \\&\text{Loop1: MVI C, FFH ..... } 7\text{ T} \\&\text{Loop 1 DCR C, ..... } 4\text{ T} \\&\text{JNZ loop1 ..... } -10/7\text{ T} \\&\text{DCR B ..... } -4\text{ T} \\&\text{JNZ loop2 ..... } 10/7\text{ T}\end{aligned}$$

**Delay calculation:**

$$T_0 = 7 * \text{count } \mu\text{s}$$

$$T_L = 35 * T$$

$$= 35 * 0.5$$

$$= 17.5 \mu\text{s}$$

$$\begin{aligned}T_D &= T_L + T_0 \\1\text{ ms} &= T_L + 17.5 * 10^{-6} \\1\text{ ms} &= 7 * \text{count} * 10^{-6} + 17.5 * 10^{-6} \\140.35 &= 7 * \text{count} \\&= 140.35 / 7 \\&= 8\text{CH}\end{aligned}$$

**Q.** Write a program to generate a continuous square wave with the period 500  $\mu$  sec. Assume the system clock period is 325  $\mu$  sec and use bit D0 to output the square wave.

**Solution:**

MVID, AA  
ROTATE: MOV A, D

RLC

MOV D, A

ANI 01H

OUT PORT 1

MVI B, count

delay: DCR B

JNZ delay

JMP ROTATE

Delay: DCR C

JNZ delay

**Q.** Write a program to count continuously in hexadecimal from FFH to 00H in a system with 0.5  $\mu$  s clock period. Use registers C to set up a 1 ms delay between each count and display the number at one of the output ports.

**Solution:**

MVI B, 00H  
Next: DCR B

MVI C, count

Delay: DCR C

JNZ delay

$$T_L = 14 * 325 * 10^{-9} * \text{count} \text{ or } 14 * 325 * (\text{count} - 1) + 11 \text{ T-state} * 325$$

$$T_O = 46 * 325 * 10^{-9}$$

$$T_D = T_L + T_O$$

$$250 = (52.4)10 = 34 \text{ H}$$

**Bus**

