

# **Input und Output**

→ Verbindung zur Außenwelt!

Aufgaben sind z.B.:

- Laden von Programmen und Daten in Speicher
- Ausgabe von Resultaten auf Bildschirm, Drucker, Festplatte, Diskette...

## **Ansteuerung**

Ansteuerung von Ein-/Ausgabeeinheiten (= I/O-Einheiten, Peripheriegeräte)

#### z.B. durch:

- Viedeocontroller (Bildschirm)
- Plattencontroller (Festplatte)
- Tastatur-Prozessoren
- Netzwerkschnittstellen usw.



#### **Schnittstellen**

Bausteine zum Ansteuern einer I/O-Einheit = Schnittstellen oder Interfaces

BB - TI II 15.1/5

# Kontaktaufnahme zwischen CPU und Interfaces

- Von der CPU aus gesehen wie Datenaustausch mit Speicher!
- Der Datenaustausch mit verschiedenen Interfaces erfolgt nach verschiedenen festgelegten Schemata (=Protokollen).

Dies wird durch Software zum Ansteuern der Interfaces geregelt *(Treiber).* 

# Vorgehen

- Interfaces, UART, EPROM, Memory Map
- Busprotokolle, Zustandsdiagramme



# I/O-Ports

Interfaces werden von der CPU wie Speicher mit s Adressen angesprochen.

Adressen bei Interface-Einheiten = I/O-Ports Für Interface mit s I/O-Ports:

- /write Signal



## **Beispiel (ff)**

- R<sub>0</sub>: Data in (Peripherie-Einheit schreibt nach R<sub>0</sub>, CPU liest)
- R<sub>1</sub>: Data out (CPU schreibt nach R<sub>1</sub>, Peripherie-Einheit liest)
- R<sub>2</sub>: Status (Peripherie-Einheit schreibt Statusinformationen, CPU liest)
- R<sub>3</sub>: Command (CPU schreibt Kommandos für Peripherie-Einheit, Peripherie-Einheit liest)

BB - TI II 💄 15.1/11

#### **UART**

RETI-II mit nur 1 Interface-Baustein:

SIO = Serielle Input/Output-Schnittstelle,

wird zur Verfügung gestellt durch einen speziellen Chip UART

(Universal Asynchronous Receiver and Transmitter)

## Eigenschaften der UART

- 8 8 Bit Register, selektiert durch 3 Adressleitungen
- Wie SRAM mit gemeinsamem Datenein-

und -ausgang

 $\rightarrow$ 

Output enable – Signal /œ

und

Schreibsignal /w



# **UART XR-16C450: Lesezugriff**

| Bezeichnung              | min | max |
|--------------------------|-----|-----|
| Setup-Zeit von A bis /oe | 10  |     |
| Output enable Zeit       |     | 75  |
| Output disable Zeit      |     | 50  |

■ Zusatzbedingungen an Timing:

Lesezykluszeit:

nach Deaktivieren von /œ dürfen

/œ und /w mindestens 60 ns nicht aktiviert werden

# **UART XR-16C450: Schreibzugriff**

| Bezeichnung                         | min | max |
|-------------------------------------|-----|-----|
| Setup-Zeit von A bis /w             | 25  |     |
| Hold-Zeit von A nach<br>Ende von /w | 5   |     |
| Pulsweite                           | 50  |     |
| Setup-Zeit von D bis<br>Ende von /w | 10  |     |
| Hold-Zeit von D nach<br>Ende von /w | 25  |     |

# **Zusatzbedingungen an Timing:**

#### ■ Schreibzykluszeit:

Nach Deaktivieren von /w dürfen /œ und /w mindestens 85 ns nicht aktiviert werden

#### **EPROM**

Nach Einschalten des Rechners soll ein festes Programm ausgeführt werden, das über die UART Daten und ein Programm lädt, das dann ausgeführt wird.

→ festes Programm
in EPROM gespeichert



## **Datenpfade und Memory Map**

Verbinde UART und EPROM mit Daten- und Adressbus.

( UART mit D[7:0] verbunden )

(siehe folgende Abbildung)



## Schalten der Treiber

■ Permanent enabled: ASMd, AEd, AUd, DSMd

- Zu erzeugende Signale:
  - Output enable von
    Treibern SMDd, EDd, UDd, DUd
  - Output enable /Uœ und Schreibsignal /Uw von UART
  - Schreibsignal /SMw von SRAM



**Datenpfade (graphisch)** 

## **Memory Map**

Festlegung, welcher Speicher unter welcher Adresse angesprochen wird durch Memory Map.

| A[31:30] | Einheit |
|----------|---------|
| 1 *      | SRAM    |
| 0 1      | UART    |
| 0 0      | EPROM   |
|          |         |

Wenn nach Reset Befehlszähler auf 0 gesetzt wird, wird 1. Befehl aus EPROM geladen!

BB - TI II 15.1/21

## **Problem:**

24 - Bit - Konstanten von LOAD, STORE dürfen nicht mehr einfach durch 08 ergänzt werden !

Abhilfe:

Segmentregister SEG mit 8 Bit SEG[7:0]!



## Zu beachten:

 Bei Segmentwechsel, d.h. Änderung der obersten 8 Bit einer Adresse für LOAD bzw. STORE, muß das Register SEG neu geladen werden!



# Zu beachten (ff)

- Laden in Segmentregister bei I[26] = 1! ( Laden in D = ACC jetzt z.B. bei / I[26] \* I[25] \* I[24] = 1)
- SEG spielt auch eine Rolle, wenn SRAM mehr als 24 Adressbits hat!

### Noch zu lösende Probleme:

- 1. EPROM (120 ns) und UART (85 ns) haben viel größere Zugriffszeiten als SRAM (45 ns).
  - → Erhöhung der Zykluszeit ??
- 2. Kontrollsignale für verschiedene *Arten von Speicher* sind zu erzeugen.

BB - TI II 🔓 15.1/27

#### zu 1.:

Mache die Länge der Fetch- bzw. Execute-Phase variabel in Abhängigkeit vom Speicher, auf den zugegriffen wird.

schneller Speicher (SRAM): wie bisher

langsamer Speicher: Einfügen zusätzlicher Zyklen

(Wait-Zyklen)

#### zu 2.:

#### Ziel:

Vermeide komplexe Kontrollogik der CPU. Speicherzugriffe sollen aus CPU-Sicht uniform behandelt werden.

#### Lösung:

Auftrennen in mehrere Kontrolleinheiten

BB - TI II 15.1/29

## zur Lösung:

- eigene Kontrolleinheiten für verschiedene Speicher, hier sind speicherspezifische Eigenschaften versteckt (Bsp.: unterschiedliche Zugriffszeiten, spezielle Leseund Schreibzykluszeit wie z.B. bei UART)
- uniforme Behandlung auf CPU-Seite,
   Kommunikation mit Speicher über Anlegen von
   Adressen und Daten und über bestimmte
   Kontrollsignale

# zur Lösung (ff)

- /mreq zum Ansprechen von Speicher
   (Adresse A bestimmt, um welchen Speicher es sich handelt)
- /mw zum Initiieren eines Schreibzugriffs auf A
- Acknowledge-Signal /ack, das die Kontrolle des Speichers an die CPU schickt, um das Einfügen von Wait-Zyklen zu steuern.
   Solange /ack inaktiv ist, werden noch Wait-Zyklen eingefügt.
   (genauer: pro Speicher i gibt es ein individuelles Signal /ack<sub>i</sub>

```
ack = \bigvee ack_i)
```