

## Assignment No. 8

Ques-1

Draw the Pin and block diagram of 8255 PPI and explain the same.

Ans -

### Block Diagram of 8255



Data bus buffer is a bidirectional buffer. It connects the system data bus to the 8 bit internal data bus of 8255. It transfers or receives data or instructions to or from the microprocessor. Read / Write control logic block controls the internal and external transfer.

of data. The signals RD, ADO, AD1, A0, A1, CS and reset are associated with this block. Group A control block receives commands from Read / Write control logic unit depending upon the control word. It controls the operation of Port A (8 bit) and Port C (upper) 4 bit. Group B control unit receives the commands from Read / write control logic and control the operations of the 8 bit port B and 4 bit Port C (lower). Port A and Port B are of 8 bit port whereas Port C (upper) and Port C (lower) are of 4 bits ports.

### Pin Diagram of 8255 PPI -



### Pin Names -

|                                  |                        |
|----------------------------------|------------------------|
| D <sub>7</sub> -D <sub>0</sub>   | → Data Bus             |
| CS                               | → Chip Select          |
| Reset                            | → Reset Input          |
| A <sub>0</sub> , A <sub>1</sub>  | → Port Address         |
| RD                               | → Read input           |
| WR                               | → Write input          |
| PA <sub>7</sub> -PA <sub>0</sub> | → 8 bit Port A         |
| PC <sub>4</sub> -PC <sub>7</sub> | → 4 bit Port C (upper) |
| PC <sub>0</sub> -PC <sub>3</sub> | → 4 bit Port C (lower) |
| PB <sub>0</sub> -PB <sub>7</sub> | → 8 bit Port B         |
| V <sub>cc</sub>                  | → +5V                  |
| GND                              | → 0V                   |

Ques-2 Draw the Pin and Block diagram of 8253 PIT and explain the same.

Ans -

Block Diagram of 8253 PIT -  
 (Programmable  
 Interval Counter Timer)

The block diagram of 8253 programmable counter/interval timer. It has three independent negative edge triggered, presetable 16 bit down counters (counter 0, counter 1 and counter 2), a data bus buffer, read/write control logic and a control word register. Each counter has two input signals, (clock and gate) and

one output signal.



Pin Diagram of 8253 PIT -



$D_0 - D_7$

→ Bidirectional data bus

$\overline{CS}$

→ Chip Select

$A_0, A_1$

→ These pins are connected to the address bus. These are also used to address the control word register for mode selection.

$\overline{RD}$

→ When the signal on this pin is low, the CPU reads data.

$\overline{WR}$

→ When the signal on this pin is low, the CPU writes data or loads the counters.

$CLK_0, CLK_1, CLK_2$  → There are clock input for the counter 0, counter 1 and counter 2.

$Gate_0, Gate_1, Gate_2$  → These are the gate terminals of counter 0, counter 1 and counter 2.

$Out_0, Out_1, Out_2$  → These are the outputs of counter 0, counter 1 and counter 2.

8257

Ques-3 Draw the Pin and block diagram of ~~8255~~ DMA and explain the same.

Ans -

Block Diagram of 8257 DMA Controller -

The 8257 is a programmable 4 channel DMA controller (Direct Memory Access) Controller which allows upto four I/O devices to access memory without involving the microprocessor. It is designed simply to

transfer the data at high speed for the microprocessor system. It can be interfaced with slow or fast peripherals.

channel 0



Channel 1



Channel 2



Channel 3



## Pin Diagram of 8257 DMA Controller -

|                         |    |      |                         |
|-------------------------|----|------|-------------------------|
| <u>IOR</u>              | 1  | 40   | A <sub>7</sub>          |
| <u>IOW</u>              | 2  | 39   | A <sub>6</sub>          |
| <u>MEMR</u>             | 3  | 38   | A <sub>5</sub>          |
| <u>MEMW</u>             | 4  | 37   | A <sub>4</sub>          |
| MARK                    | 5  | 36   | T <sub>C</sub>          |
| READY                   | 6  | 35   | A <sub>3</sub>          |
| HLDA                    | 7  | 34   | A <sub>2</sub>          |
| AD STB                  | 8  | 33   | A <sub>1</sub>          |
| ACN                     | 9  | 32   | A <sub>0</sub>          |
| HREQ                    | 10 | 8257 | Vcc                     |
| <u>CS</u>               | 11 | 31   | D <sub>0</sub>          |
| CLK                     | 12 | 29   | D <sub>1</sub>          |
| Reset                   | 13 | 28   | D <sub>2</sub>          |
| <u>DACK<sub>2</sub></u> | 14 | 27   | D <sub>3</sub>          |
| <u>DACK<sub>3</sub></u> | 15 | 26   | D <sub>4</sub>          |
| <u>DRQ<sub>3</sub></u>  | 16 | 25   | <u>DACK<sub>0</sub></u> |
| <u>DRQ<sub>2</sub></u>  | 17 | 24   | <u>DACK<sub>1</sub></u> |
| <u>DRQ<sub>1</sub></u>  | 18 | 23   | D <sub>5</sub>          |
| <u>DRQ<sub>0</sub></u>  | 19 | 22   | D <sub>6</sub>          |
| GND                     | 20 | 21   | D <sub>7</sub>          |

IOR → I/O Read

IOW → I/O Write

MEMR → Memory read

MEMW → Memory write

MARK → This output notifies the selected

peripheral that the current DMA cycle is the 28<sup>th</sup> cycle since the previous mark output.

READY → Ready signal

HLDA → Hold Acknowledge

AD STB → Address strobe

ACN → Address Enable

HRQ → Hold Request

CS → Chip Select

CLK → Clock input

Reset → Input signal which disables all DMA channels by clearing the mode register and tristates all control lines.

DACK<sub>3</sub> - DACK<sub>0</sub> → DMA Acknowledge

DRQ<sub>3</sub> DRQ<sub>3</sub> - DRQ<sub>0</sub> → DMA request input

D<sub>7</sub> - D<sub>0</sub> → Data bus

A<sub>7</sub> - A<sub>0</sub> → Address bus

TC → Terminal count.