# Calcolatori Elettronici T Ing. Informatica

Traccia soluzione 9 Febbraio 2023

#### Dispositivi e segnali presenti nel sistema.

### Dispositivi di memoria:

| RAM_H_512 | E0000000h:FFFFFFFh,  | 4 | banchi | da | 128 | MB |
|-----------|----------------------|---|--------|----|-----|----|
| RAM_L_512 | C0000000h:DFFFFFFh,  | 4 | banchi | da | 128 | MB |
| EPROM_OPT | 40000000h:7fffffffh, | 4 | banchi | da | 256 | MB |
| EPROM_1GB | 00000000h:3FFFFFFh,  | 4 | banchi | da | 256 | MB |

Porte di input, output e altri chip-select e/o segnali:

| CS_ | _INPUT  | 8000000h  |
|-----|---------|-----------|
| CS_ | OUTPUT  | 8000001h  |
| CS_ | _STATUS | 80000002h |

#### Segnali di decodifica di memorie, periferiche e segnali:

```
CS_RAM_H_512_0 = BA31 \cdot BA30 \cdot BA29 \cdot BE0
CS RAM H 512 1 = BA31 \cdot BA30 \cdot BA29 \cdot BE1
CS_RAM_H_512_2 = BA31 · BA30 · BA29 · BE2
CS_RAM_H_512_3 = BA31 · BA30 · BA29 · BE3
CS_RAM_L_512_0 = BA31 · BA30 · BA29* · BE0
CS_RAM_L_512_1 = BA31 · BA30 · BA29* · BE1
CS_RAM_L_512_2 = BA31 \cdot BA30 \cdot BA29 * \cdot BE2
CS RAM L 512 3 = BA31 \cdot BA30 \cdot BA29 * \cdot BE3
           = BA31 \cdot BA30 * \cdot BE0
CS INPUT
CS_OUTPUT = BA31 · BA30 * · BE1
CS_STATUS = BA31 · BA30 * · BE2
CS_EPROM_OPT_0 = BA31*·BA30·BE0·ACTIVE
CS_EPROM_OPT_1 = BA31*·BA30·BE1·ACTIVE
CS EPROM_OPT_2 = BA31*·BA30·BE2·ACTIVE
CS EPROM OPT 3 = BA31*·BA30·BE3·ACTIVE
CS\_EPROM\_1GB\_0 = BA31*\cdot BA30*\cdot BE0
CS\_EPROM\_1GB\_1 = BA31*\cdot BA30*\cdot BE1
CS\_EPROM\_1GB\_2 = BA31*\cdot BA30*\cdot BE2
CS EPROM 1GB 3 = BA31*\cdot BA30*\cdot BE3
```

Nel sistema sono presenti una porta in input, INPUT\_PORT, e una porta in output, OUTPUT PORT.



Un contatore modulo 4 consente di tenere traccia dei trasferimenti dalla porta in input. Il segnale **DIV\_8** codifica se il dato è divisibile per 8 e non il valore zero:

 $DIV_8 = BD2**BD1**BD0**(BD7+BD6+BD5+BD4+BD3)$ 



Un FFD, opportunamente inizializzato all'avvio, consente di generare il segnale ACTIVE che condiziona la presenza di EPROM\_OPT:



Il segnale INT\_INPUT\_SYNC, ottenuto campionando sul fronte di salita di MEMRD il segnale INT\_INPUT, è letto all'indirizzo CS\_STATUS per determinare se l'interrupt di INPUT\_PORT, maggiormente prioritario, è asserito.



Il segnale di interrupt inviato al DLX risulta:

INT\_DLX = INT\_INPUT + INT\_OUTPUT

Codice dell'interrupt handler (si omette per semplicità rete/procedura di avvio):

Il valore della label **OUTPUT** risulta:  $12_{10} = 0 \times C$ 

# Interfacciamento RAM\_H\_512



# Interfacciamento RAM\_L\_512



# Interfacciamento EPROM OPT



# Interfacciamento EPROM 1GB

