



## Advance Assembly Language Programming -

COUNTER: A counter is designed by loading an appropriate count in a Register. A loop is set up to decrement the count for the down counter or the increment the count for the up counter. A Timing delay is designed by loading a register with the delay count and setting up a loop to decrement the count until zero.

Counter and time delay are important technique. They are commonly used in application such as traffic signal, digital clocks, process control and serial data transfer.



COUNTER - A Counter is designed by loading an appropriate number into one of the Register and using the increment or decrement the instructions. A loop is designed to check whether the condition reached at the final position.

TIME DELAY - The procedure for design a specific delay and similar to set up the counter. A Register is loaded with a number depending on the time delay required and then the register is decremented for reaching the initial count.

Time delay using one Register -





# POORNIMA

COLLEGE OF ENGINEERING

## DETAILED LECTURE NOTES

PAGE NO. ....

$\lambda$ ,  $\times 2$  Clock frequency of the system  $f = 2 \text{ MHz}$

Clock period  $T = \frac{1}{f} = \frac{1}{2 \times 10^6} = 0.5 \mu\text{sec.}$

Time to execute MVI =  $7 \text{ T-state} \times 0.5 \mu\text{sec.}$   
 $= 3.5 \mu\text{sec.}$

Time delay in the Loop -

$T_L$  = time delay in the loop

$T$  = System clock period.

$N_{10}$  = Equivalent decimal number of the hexadecinal count loaded in the delay Register.

$$T_L = (0.5 \times 10^{-6} \times 14 \times 255)$$
$$= 1785 \mu\text{sec.}$$
$$\approx 1.8 \text{ m sec.}$$

The T-state for jump instruction is 10/7. The 8085 CPU requires 10T-state to execute a conditional Jump. When it jumps to change and for sequence the program.

$$T_{LA} = T_L - (3 \text{ T-state} \times \text{clock period})$$

$$1785.0 \text{ } \mu\text{s} - 1.5 \text{ } \mu\text{s} = 1783.5 \text{ } \mu\text{s}$$

So the total delay for execution the instructions.

Total delay = Time to execute instruction outside loop.

+

Time to execute loop instruction.

$$T_D = T_0 + T_{LA}$$

$$= (7 \times 0.5 \text{ } \mu\text{s}) + (1783.5 \text{ } \mu\text{s})$$

$$= 1787 \text{ } \mu\text{s}.$$

$$\approx 1.8 \text{ ms.}$$

The time delay can be varied by changing the count FFH.



# POORNIMA

COLLEGE OF ENGINEERING

## DETAILED LECTURE NOTES

PAGE NO. ....

### Time delay Using a loop within a Loop Technique -

A time delay can also be achieved by using two loops. Register C is used in the inner loop and Register B is used for the outer loop.



### Delay Calculation -

The delay for the Loop 1 is  $T_{L1} = 1783.5 \mu s$  and for loop 2 it is calculated by the following loop.

$$\begin{array}{r} 3 \\ \times 16 + 8 = 5 \\ 16 \quad 16^0 \end{array}$$

$$3 \times 16 + 8 = 5$$

$$\begin{aligned}
 T_{L2} &= 56(T_L + 21 \text{ T-state } \times 0.5 \text{ usec}) \\
 &= 56(1783.5 \text{ usec} + 10.5 \text{ usec}) \\
 &= 100.46 \text{ ms.}
 \end{aligned}$$

The total delay include the execution time for the first instruction and the delay outside the loop provide the significant execution time.

The time delay within a loop can be increased by using instruction so that it not affect the program execution time and metoring process.



Flow Diagram of Loop.



# POORNIMA

COLLEGE OF ENGINEERING

## DETAILED LECTURE NOTES

PAGE NO. ....

### Time Delay using a Register Pair :

It can be increased by setting a loop and using a Register pair with a 16 bit number (FFFFH). The 16 bit number is decremented by using the instruction Dex. The instruction Dcx does not set the zero flag and without testing the test flag, jump instruction can not check desired data.

| <u>Label</u> | <u>Opcode</u> | <u>Operand</u> | <u>Comment</u>                  | <u>T-state</u> |
|--------------|---------------|----------------|---------------------------------|----------------|
|              | LXI           | B, 2384H.      | load BC with 16 Bit count       | 10             |
| Loop:        | Dcx           | B              | dec <sup>n</sup> BC by one      | 6              |
|              | Mov           | A, C           | place content of C in A         | 4              |
|              | ORA           | B              | OR(B) with C to set zero flag.  | 4              |
|              | JNZ           | Loop           | if result ≠ 0 jump back to loop | 10/7           |

## Time Delay:

$$(2384)_H = 2 \times (16)^3 + 3 \times (16)^2 + 8 \times (16) + 4(16^0)$$
$$= 9092_{10}$$

in the clock period of the system.  
 $\approx 0.54 \text{ sec.}$

$$T_L = 0.5 \times 24 \times 9092_{10}$$

$\approx 109 \text{ ms}$  (without adjusting last cycle).

$$\text{Total delay} \Rightarrow T_D = 109 \text{ ms} + T_o$$
$$= 109 \text{ ms.}$$



# Poornima

## COLLEGE OF ENGINEERING

DETAILED LECTURE NOTES

### MACROS:-

A macro is a named block of assembly language statement. Once defined it can be involved as many program as we wish. When the macro can be invoked the code is inserted directly into the program at the location where it was invoked.

This type of automatic code insertion, is known as inline expansion. It is referred to calling a MACRO. In that program the call instruction is not specified by the programmer.

- \* Creating macro is similar to create a new opcode that can be used in the program.
- \* Declaring macros are defined directly at the beginning of a source program or they are placed in a separate file & copied into a program by an include directive. Macros are explained during the assembler steps.

At every point when the macro is called, the assembler insert a copy to the macro source code into the program.

### Defining Macros -

It is defined by MACRO and END In directions. The Syntax is -

macro name MACRO

Parameter 1

Parameter 2

:

:

END M.

There is no fixed rule regarding indentation but the indent statement between macro name & END m specified the value definition term.

\* Macro sequences execute faster than subroutines because there are no CALL & RET instructions.  
to execute -



# POORNIMA

## COLLEGE OF ENGINEERING

### DETAILED LECTURE NOTES

#### Subroutine :-

It is a group of instruction written separately from the main program to perform a function that occur repeatedly in the main program. If the time delay is required between three successive event, three delay can be written in the main program.

To avoid repetition of the same delay instruction the subroutine technique is used. Delay instruction ~~are~~ written once, Separately from the main program.

It has two instruction to implement subroutine Call & Ret.

The call instruction is used in the main program to call a subroutine & RET instruction is used at the end of the subroutine to return the main program. When a subroutine is called the content of the program Counter, which is the address of the instruction following the call instruction.

## Call : 16 bit memory address

Call subroutine unconditionally -

- it is the 3 byte instruction that transfer the program sequence to the subroutine address.
- save the content of the PC on the stack.
- decrement the stack pointer register by two .
- Jump unconditionally to the memory location specified by second & third byte .
- The instruction is accompanied by RET instruction.

RET : → Return from subroutine unconditionally  
→ 1 Byte instruction  
→ Insert 2 byte from top of the stack into the PC & increment the SP.  
Register by two .  
→ Unconditionally RET from the subroutine.



# POORNIMA

## COLLEGE OF ENGINEERING

### **DETAILED LECTURE NOTES**

#### STACK IMPLEMENTATION :-

The stack in an 8085 described as a set of memory location in the R/W memory specified by the programmer in the main memory content.

The beginning of the stack is defined by using the instruction `LXI SP`, which load a 16-bit memory address in the stack pointer register.

Once, the stack location is defined, storing of data byte begin at the memory location that is one less than the stack pointer register.

Data byte in the Register Pair can be stored on the stack in the reverse order. by using the instruction push. Data byte can be transferred to the next memory location. by POP instruction.

The stack is shared by the programmer & the microprocessor. The Programme can store & retrieve the information automatically.

## Instruction for Stack Implementation:

- \* LXI SP, 16 Bit  $\Rightarrow$  Load stack pointer with the 16 bit memory address.
- \* PUSH Rp  $\Rightarrow$  Store Register Pair on stack.
- \* PUSH B  $\Rightarrow$  Copies the content of specified Register pair on the stack.
- \* PUSH PSW  $\Rightarrow$  Stack Pointer Register is decremented & the content of high order Register one copied in the memory.
  - $\Rightarrow$  Stack Pointer Register is again decremented & content of low order Register copied in that location.
- \* POP Rp  $\Rightarrow$  Retrieve Register Pair from stack.
- \* POP B  $\Rightarrow$  Copies the content of 2 top memory location of the stack into the specified Rp.
- \* POP PSW  $\Rightarrow$  first-the content defined by SP the Register are copied into the low order Register the content of the next-memory location are copied into the high order Register.



# POORNIMA

## COLLEGE OF ENGINEERING

### DETAILED LECTURE NOTES

PAGE NO. ....

#### STACK OPERATION:-

LXI SP, 2099 H.

LXI H, 42 F2 H.

PUSH H H.

Delay Counter

POP H.



#### Instructions & Register Content-



Register After the PUSH instruction.



Register after the POP instruction.

- The stack pointer is decremented by one to 2098H and the content of the H Register copied to memory location 2098H.
- The stack pointer is again decremented by one to 2097 & the content of Register L are copied to memory location 2097H.
- The content of Register Pair HL are not destroyed, however HL → is made available for the delay counter.



# POORNIMA

## COLLEGE OF ENGINEERING

### DETAILED LECTURE NOTES

PAGE NO. ....

#### Interrupts :-

An interrupt is the process of data transfer whereby an external device or a peripheral can inform the processor that it is ready for communication and it requires attention.

The interrupt-request can be classified in 2 categories -

→ Maskable Interrupt -

→ Non maskable Interrupt -

8085 includes 4 maskable interrupt & 1 non-maskable interrupt.

The microprocessor can ignore or delay a maskable interrupt request if it is performing some critical task. It has to respond to the non-maskable request immediately.

The interrupt process allows the microphones to respond the external request for attention or service on a demand basis and leave the microprocessor free to perform other task.

### 8085 Interrupts :

It is controlled by the interrupt enable flip flop. If the flip flop is enabled & the input of the interrupt signal. This is maskable interrupt & can be disabled.

#### EI (Enable Interrupt) :-

- It is 1 byte instruction
- Set the interrupt enable flip flop.
- System reset or an interrupt disable the interrupt process.

#### DI (Disable Interrupt) :-

- It is 1 byte instruction
- It reset the interrupt enable flip flop & disable the interrupt.
- It include in a program segment where an interrupt from an outside source cannot be tolerated.



# Poornima

COLLEGE OF ENGINEERING

DETAILED LECTURE NOTES

PAGE NO. ....

## 8085 Vectored Interrupt :-

8085 has 5 interrupt input. One is called INTR, three one called RST 5.5, 6.5, 7.5 the fifth is called TRAP a non-maskable interrupt. They do not require the INTA signal or an input port.

| <u>Interrupt</u> | <u>Call duration (address)</u> |
|------------------|--------------------------------|
| TRAP             | 0024 H. (One quest)            |
| RST 7.5 X 8      | 003C H.                        |
| RST 6.5          | 0034 H.                        |
| RST 5.5          | 002CH                          |

TRAP has the highest priority followed by RST 7.5, 6.5, 5.5 and INTR.

TRAP is a non-maskable interrupt known as NMI. It has the highest priority interrupt signals.

it need not be enabled & it cannot be disabled. It is level & edge sensitive, input should be high & stay high to be acknowledged. It cannot be acknowledged again until it makes a transition from high to low to high.

RST 7.5, 6.5 and 5.5 :-

These maskable interrupt are enabled for the program & controlled by 2 instruction EI, SIM.

SIM: Set Interrupt Mask :-

It is a 1 byte instruction can be used for three different function -

- ① To set mask for RST 7.5, 6.5 and 5.5 interrupt. The instruction Read the content of the accumulator Bit D<sub>3</sub> is a control bit of the flip flop bit D<sub>4</sub> is additional. control for RST 7.5. If D<sub>4</sub>=1, RST 7.5 is reset.
- ② To implement serial I/O Bit D<sub>7</sub> and D<sub>6</sub> of the accumulator used for serial I/O & it do not affect the interrupt.



# POORNIMA

COLLEGE OF ENGINEERING

## DETAILED LECTURE NOTES

PAGE NO. ....



## TRIGGERING LEVELS :-

### (RIM (Read Interrupt mask)) -

It is one byte instruction that can be used for the following functions

- ① To read Interrupt mask.
- ② This instruction load the accumulator with 8 bit the current status of the interrupt mask.
- ③ To identify pending interrupt.
- ④ To receive serial Data . Bit D9 is used to receive serial data.



### RIM Instruction