

#### **OUTLINE:**

- Designing an external 3 Byte Memory
- De-multiplexing the ATmega103 PORTS in to more devices



# **Computer Bus**

- The processor of a computer communicates with the other computer modules via a device called: <u>Bus.</u>
- Several Bus architectures exist in the market such as PCI; cPCI; VME....
- All bus architectures include a <u>control bus</u>, a <u>data bus</u> and an <u>address bus</u>.



# The BUS of a computer:





# **Typical Write Sequence**

- The master places the address of the memory where the data is to be written on the bus and qualifies it using the control lines.
- The master signals using the control lines that this is a write sequence.
- The master places the data to be written on the bus and qualifies them using the control lines
- The slave compares the address on the bus with its own address. If the write refers to him, he takes the data and signals using the control lines that he is done (acknowledges the data)



# **Typical Read Sequence**

- The master places the address of the memory from where the data is to be red on the bus and qualifies it using the control lines.
- The master signals using the control lines that this is a read sequence.
- The master signals that he is ready to accept data using the control lines.
- The slave compares the address on the bus with its own address. If the read refers to him, he places the data on the bus and signals using the control lines that he is done (acknowledges the data). At the end the Master Latches the data.



# **Parallel** Transfer

- In a bus all bits of a byte or word are transferred simultaneously.
- If we have a byte wide bus and a transfer frequency of 1MHz then we have a bus speed of 1Mbytes/sec

 Hence, this is called <u>Parallel Data</u> <u>Transfer</u> (oppose to <u>Serial Data</u> <u>Transfer</u> that we will learn next)



#### **Electronics** Exercise

#### Make a 3 Byte memory (SRAM) that you can read and write from the ATmega103 board.



Costas Foudas, Imperial College, Rm: 508, x47590



# High Level Design :2 Byte Memory



Rm: 508, x47590



# Guess what is the 1 Byte memory?

#### • It exists in one package :





### The data sheets of the 74F574



Costas Foudas, Imperial College, Rm: 508, x47590

1/31/2006



# What does the 74F574 do?



The outputs of the 574 are tri-state : They Can be high '1', low '0', and DISCONNECTED (HIGH IMPEDANCE STATE).

> Costas Foudas, Imperial College, Rm: 508, x47590

1/31/2006



# The 74F574 Truth Table

#### FUNCTION TABLE, 74F574

| INPUTS |        |                     | INTERNAL            | OUTPUTS                         |                        |  |  |  |  |
|--------|--------|---------------------|---------------------|---------------------------------|------------------------|--|--|--|--|
| ŌĒ     | СР     | D <sub>n</sub>      | REGISTER            | Q <sub>0</sub> - Q <sub>7</sub> | OPERATING MODE         |  |  |  |  |
| L      | ↑<br>↑ | l<br>h              | L<br>H              | L<br>H                          | Load and read register |  |  |  |  |
| L      | ¢      | X                   | NC                  | NC                              | Hold                   |  |  |  |  |
| H<br>H | 1<br>X | D <sub>n</sub><br>X | D <sub>n</sub><br>X | Z<br>Z                          | Disable outputs        |  |  |  |  |

H = High voltage level

h = High voltage level one set-up time prior to the Low-to-High clock transition

L = Low voltage level

= Low voltage level one set-up time prior to the Low-to-High clock transition

- NC = No change
- X = Don't care
- Z = High impedance "off" state
- 1 = Low-to-High clock transition
- 1 = Not a Low-to-High clock transition



Costas Foudas, Imperial College, Rm: 508, x47590



# The Data Sheets of the 74F574 I





## The Data Sheets of the 74F574 II





# The data sheet for the 74F138

#### Address Decoder



Costas Foudas, Imperial College, Rm: 508, x47590

1/31/2006



# What does the 74F138 do (II)?



| INPUTS |    |    |   |    |    | OUTPUTS |    |                  |                  |                             |      |                             |            |
|--------|----|----|---|----|----|---------|----|------------------|------------------|-----------------------------|------|-----------------------------|------------|
| 0      | Ē, | E2 | A | A, | A2 | ā,      | ā, | $\overline{Q}_2$ | $\overline{Q}_3$ | $\overline{\mathbf{Q}}_{4}$ | ā,   | $\overline{\mathbf{Q}}_{6}$ | <u>a</u> , |
| +      | x  | x  | х | x  | x  | н       | н  | н                | H                | H                           | н    | н                           | н          |
| x      | н  | x  | х | x  | ×  | н       | н  | н                | н                | н                           | н    | н                           | н          |
| x      | x  | L  | x | ×  | ×  | н       | н  | н                | н                | н                           | н    | н                           | н          |
|        | L  | н  | L | L  | L  | L       | н  | н                | н                | н                           | н    | н                           | н          |
| -      | L  | н  | н | L  | L  | н       | L  | н                | H                | н                           | н    | н                           | н          |
|        | L  | н  | L | н  | L  | н       | н  | L                | н                | н                           | н    | н                           | н          |
| L      | Ĺ  | н  | н | н  | L  | н       | н  | н                | L                | н                           | н    | н                           | н          |
| L      | L  | н  | L | L  | н  | н       | н  | н                | н                | L                           | н    | н                           | н          |
| L      | L  | H  | н | L  | н  | н       | H  | н                | н                | Н                           | SFIE | н                           | н          |
| L      | L  | н  | L | н  | н  | н       | н  | н                | н                | H                           | н    | L                           | н          |
| L      | L  | н  | H | н  | н  | н       | н  | н                | н                | н                           | н    | н                           | L          |

Costas Foudas, Imperial College, Rm: 508, x47590

1/31/2006

16



# **Basic** Design idea





#### **Control Bus**





#### **Control Block and Bus**





The Registers



Rm: 508, x47590



# **Timing Diagram:**





# The Memory Test Program





# Task Plan:

(1) Construct the 3 byte memory and connect it to your ATmage103 Board (always through the special cable-resistor-pack unit). (2) Do it in steps: First the Control, then the first byte and second and finally third. (3)Write a program with a main section and driver subroutines that read, write and loop data through your memory board.



# Some Comments:

 Make a detailed schematic of your device with all ICs (logic diagrams) and the IC pin assignments.

(2) Make sure that you understand your design <u>BEFORE</u> you start building it.

(3) Build the device in pieces which you can check using your software. Don't build the entire design before testing.

(4) If it does not work use the oscilloscope and the DVM to check what is going on and debug your device.



# How to Draw Schematics:





Costas Foudas, Imperial College, Rm: 508, x47590



# The 138 funny output pulses:





## Some Comments:

(1) If you try to clock your registers with a pulse that looks like:



Write Pulse Accidental glitches due to the 138

Then you should expect that you will write 3 times (once when you want) and twice more when/where you DON'T want.

> Costas Foudas, Imperial College, Rm: 508, x47590

1/31/2006



#### More Comments:

- (1) Start by setting the Address Strobe\* high and the R\*/W high .
- (2) Set the correct address and data on your bus.
- (3) Bring \*R/W for 250 nsec High and then back Low.
- (4) Before you connect the outputs together perhaps use LED/Resistors to check if the data is there...

(5) Try reading the data with the ATMEL.

This should result to a successful write of your data at the register you want them