



## CSE341: Microprocessor



**Quiz - 4**

**Section:**

**Marks: 15**

**Duration: 30 minutes**

**Name:**

**ID:**

**Question-1:** An 8086 microprocessor has the following segment addresses: **DS = 2000h**, **CS = 3000h**, **SS = 4000h** and while program X was executing, an **interrupt N** occurred. To handle this interrupt, the processor must jump to the **ISR** located at **386A9h**, which resides within the same code segment. Before fetching the ISR, the stack top offset was **3509h**. Some portions of memory are provided below:

|                |        |        |        |        |        |        |
|----------------|--------|--------|--------|--------|--------|--------|
| <b>Address</b> | 43509h | 43508h | 43507h | 43506h | 43505h | 43504h |
| <b>Data</b>    | 57h    | 76h    | 32h    | 32h    | 70h    | 28h    |

|                |        |       |       |       |       |       |
|----------------|--------|-------|-------|-------|-------|-------|
| <b>Address</b> | 43503h | 03AFh | 03AEh | 03ADh | 03ACh | 03ABh |
| <b>Data</b>    | 56h    | 30h   | 00h   | 86h   | A9h   | 98h   |

- Deduce the value of CS and IP of program X. [3]
- Deduce the memory addresses or locations of the IVT table where the CS and IP of Interrupt N is situated. [3]
- Deduce the Interrupt Type N. [3]

a)  $(SS \times 10) + (SP - 3) = \text{Mem loc of CSH}$   
 $(4000 \times 10) + (3509 - 3) = 43506 = \text{Mem loc of CSH}$

$\therefore CSH = 32h$   
 $[43503] CSL = 70h$   
 $[43504] IPH = 28h$   
 $[43503] IPL = 56h$

$CS = 3270h$   
 $IP = 2856h$

IVT Table:

|     |        |
|-----|--------|
| IPL | 03AC h |
| IPH | 03AD h |
| CSL | 03AE h |
| CSH | 03AF h |

SP = 3509h

b)  $(CS \times 10) + IP = 386A9$   
 $3000 \times 10 + IP = 386A9$   
 $IP = 386A9 - 30000$   
 $\therefore IP = \underline{\underline{86A9}} h$  [IP of the starting address of ISR in IVT]  
 $\therefore \text{Memory Address} = 03AC h \rightarrow IPL$   
 $03AD h \rightarrow IPH$   
 $03AE h \rightarrow CSL$   
 $03AF h \rightarrow CSH$

c) Starting address of ISR = INT type  $\times 4$   
 $03AC h = \text{INT type} \times 4$   
 $940 = \text{INT type} \times 4$

$\text{INT type} = \frac{940}{4}$   
 $\text{INT type} = 235$

**Question-2:** Illustrate the way DMA operates. Draw a diagram and explain how it operates. [6]



1. CPU invokes a read/write command to the peripherals.
2. The peripherals when ready sends a DMA request (DREQ) signal to the DMA controller.
3. The DMA controller sends a Hold Request (HRQ) signal to the CPU to gain control of the system bus.
4. The CPU replies with a Hold Acknowledgement signal to the DMA giving the DMA controller total control over the system bus.
5. The DMA controller then sends a DMA Acknowledgement signal to the peripherals in reply to the previous DMA request signal.
6. Data can now be transferred between Memory and I/O with the help of the DMA controller.
7. DMA controller sends interrupt signal to the CPU when finished with data transfer.
8. The DMA disables the DMA Acknowledgement signal and the CPU disables the Hold Acknowledgement signal taking back control of the system bus.

## CSE341: Microprocessor



**Quiz - 3**

**Section:**

**Marks: 15**

**Duration: 25 minutes**

**Name:**

**ID:**

**Question-1:** Suppose an 8086 wants to read **2 bytes** of **data** from an **odd memory location**. Now the memory is working at a **slower rate** than the 8086. Hence when reading the **1st byte of data**, the 8086 has to wait for an **additional 2 clock pulses**. But the **2nd byte** was read **without any delay**. Now assuming the 8086 is working at a **frequency of 10MHz** calculate the following:

- The value of the Instruction Cycle (in nanoseconds). [3]
- The values of A0 and BHE' pins while transferring the 2 bytes of data. [3]
- The value of TON and TOFF assuming the 8086 is running at a duty cycle of 40%. [3]
- Draw the timing diagram for the operation described in Question. [6]

a) At 1st BC

$$\text{no of Tstates} = 4 + 2 = 6$$

$$1 \text{ Tstate} = 100 \text{ ns}$$

$$\therefore 6 \text{ Tstate} = (6 \times 100 \text{ ns}) = 600 \text{ ns}$$

~~At 1st BC~~  $f = 10 \text{ MHz} = 10 \times 10^6 \text{ Hz}$

$$T = \frac{1}{f} = \frac{1}{10 \times 10^6} \text{ s} = \frac{10^9}{10 \times 10^6} \text{ ns}$$

$$\therefore T = 100 \text{ ns}$$

→ Reading 2 bytes (16 bits) from odd address (unaligned word)

b) At 1st BC :  $A0 = 1, \overline{BHE} = 0$

2nd BC :  $A0 = 0, \overline{BHE} = 1$

c) DC = 40%

$$DC = \frac{TON}{TON + TOFF} \times 100\% = \frac{TON}{T} \times 100\%$$

$$\Rightarrow 40\% = \frac{TON}{T} \times 100\%$$

$$\Rightarrow TON = T \times \frac{40\%}{100\%} = 100 \times \frac{40\%}{100\%} = 40 \text{ ns}$$

$$\therefore TOFF = T - TON = (100 - 40) \text{ ns} = 60 \text{ ns}$$

