# Inhaltsverzeichnis

| 1.        | Aufbau des alphatronic-PC                                      | 1           |
|-----------|----------------------------------------------------------------|-------------|
| 1.1       | Uffnen und Schließen des alphatronic-PC<br>Leichte Reparaturen | 5<br>6<br>6 |
| 1.2.1     | Austausch der Sicherung<br>Austausch der Netzteileinheit       | 6           |
| 1.2.3     | Austausch des Netzsteckers oder -schalters                     | 7           |
| 1.2.4     | Austausch der Keyboardplatine                                  | 7           |
| 1.2.5     | Austausch eines Steckers                                       | 8           |
| 1.2.6     | Austausch eines gesockelten IC                                 | 9           |
| 2.        | Blockschaltbild                                                |             |
| 2.1       | Beschreibung am Blockschaltbild                                | 10          |
| 2.2       | Bestückungsplan der Hauptplatine                               | 13          |
|           |                                                                |             |
| 3.        | Microprozessor Z 80 A                                          |             |
| 3.1       | Architektur des Z 80 A                                         | 14          |
| 3.2       | Befehlssatz des Z 80 A                                         | 19          |
|           |                                                                |             |
| 4.        | Memory Mapping                                                 |             |
| 4.1       | Memory Mapping                                                 | 32          |
| 4.2       | I/O Adressen                                                   | 33          |
|           |                                                                |             |
| <u>5.</u> | Schnittstellenbeschreibungen                                   |             |
| 5.1       | SPORT (System Port)                                            | 35          |
| 5.2       | Tastatur                                                       | 39          |
| 5.3       | Serielle Schnittstelle                                         | 43<br>58    |
| 5.4       | Cassettenschnittstelle Parallelschnittstelle (Centronics)      | 64          |
| 5.6       | Systembus - Schnittstelle                                      | 71          |
| 5.7       | Videoschnittstellen RGB und BAS                                | 88          |
| 5.8       | ROM PACK                                                       | 104         |
|           |                                                                |             |

| 6.                                                           | Software                                                                                                                                                                        | 100                                           |
|--------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|
| 6.1<br>6.2<br>6.3                                            | Kurzbeschreibung des IPL Monitors<br>CP/M Betriebssystem<br>BASIC                                                                                                               | 109<br>115<br>118                             |
| 7.1<br>7.1<br>7.2<br>7.3<br>7.3.1                            | Betrieb eines Floppydisk  Allgemeine Hinweise Sicherungswechsel Controller Aufzeichnungsformat                                                                                  | 120<br>127<br>128<br>128                      |
| 8.1<br>8.2<br>8.3                                            | Drucker Gabriele 8008 V.24 TRD 7020 V.24 Epson MX 80 FT3                                                                                                                        | 133<br>134<br>135                             |
| 9.                                                           | Stichwortregister                                                                                                                                                               | 136                                           |
| 10.1<br>10.1<br>10.2<br>10.3<br>10.4<br>10.5<br>10.6<br>10.7 | Anhang Liste der IC's Bezugsquellenangabe für Datenblätter Befehlsliste Z 80 A Literaturverzeichnis Schnittstellen-Steckverbinder ESCAPE-Sequenzen Monitor-Listing Weitere Tips | 141<br>142<br>143<br>168<br>169<br>170<br>175 |
|                                                              |                                                                                                                                                                                 |                                               |

# 1. Aufbau des alphatronic-PC

Der Aufbau des alphatronic-PC ist nach neuestem Fertigungsstandard erstellt.

Sein Gehäuse besteht aus zwei Kunststoffhalbschalen, die zur Abschirmung der entstehenden Störstrahlung des Rechners innen elektrisch leitend lackiert sind. Zur Verbindung der beiden Halbschalen zu einem geschlossenen Gehäuse sind im vorderen Teil des Oberteiles drei "Haltenasen" angebracht, die in entsprechende Üsen im Unterteil greifen. Geschlossen wird das Gehäuse mit drei Schrauben, die von unten durch das Unterteil in angespritzte Zapfen des Oberteils eingeschraubt werden.

# Unterseite des PC



\* = Schrauben

Das Unterteil trägt in seinem Inneren die "Hauptplatine". Sie ist ebenfalls auf angespritzten Sockeln verschraubt. Auf der Hauptplatine sind, bis auf Netzteil, Netzfilter, Trafo und Tastatur (Keyboard), alle Baugruppen des alphatronic-PC vereint.

Alle Verbindungen zwischen der Hauptplatine und anderen Baugruppen sind gesteckt.







Oberhalb der Hauptplatine (siehe Abb. 1.3) befindet sich rechterhand das Netzfilter und der Netztrafo. Das Netzteil (mit Spannungsregler etc.) wurde aus Platzgründen über die Hauptplatine auf Kunststoffhalter gesetzt.

In das Oberteil des Gehäuses ist die Tastaturplatine eingebaut. Auf ihr sind alle Tasten sowie die Leuchtanzeigen montiert. Zur mechanischen Stabilisierung ist diese Platine mit zusätzlichen Verstärkungen versehen. Die obere Kunststoffschale enthält Justierzapfen, die als Montagehilfe in die Tastaturplatine ragen (Abb. 1.2).

Der ebenfalls im Oberteil angeordnete "ROM-PACK"-Schacht wird durch einen ohne Werkzeug entfernbaren Kunststoffdeckel verschlossen. Die Geometrie des Schachtes ist so ausgelegt, daß eine Verpolung des ROM-PACK-Modules vermieden wird.

Die Steckverbinder für das parallele Ausgabeport, die Systembus- Schnittstelle, die serielle Schnittstelle, sowie der Resettaster befinden sich an der Gehäuserückseite (Abb. 5.16). Die Anschlüsse für monochrome und Farbmonitore, sowie für einen Cassettenrecorder sind auf der linken Gehäuseseite zugänglich.

Für die vielpoligen Verbinder der parallelen, seriellen und der Systembus-Schnittstelle sind zusätzliche Befestigungen vorgesehen. An diesen werden die alphatronic Steckverbinder mit ihren Schrauben befestigt.

# ACHTUNG

Garantieverlust bei unbefugtem Öffnen des Gerätes !

# 1.1 Offnen und Schließen des alphatronic-PC

- 1. Netzleitung vom Gerät lösen
- 2. Alle Leitungen zu weiteren Geräten lösen
- 3. Das Gerät mit der Tastatur nach unten auf eine ebene Unterlage legen.
- 4. Die in Abbildung 1.1 markierten Schrauben mit einem passenden Kreuzschlitzschraubendreher herausdrehen.
- 5. Das Gerät wieder auf die Unterseite drehen, dabei das Ober- und Unterteil verbunden halten.
- 6, Jetzt das Oberteil am hinteren Ende des Gerätes etwa l cm anheben und nach vorne von den am Unterteil angespritzten Haken abschieben.
- 7. Das Oberteil (Tastatur) kann nun nach rechts neben das Unterteil geschwenkt werden (Die Öffnung des Oberteils zeigt nach oben).

# 1.1.2 Zusammenbau

Der Zusammenbau geschieht in umgekehrter Reihenfolge. Es ist darauf zu achten, daß kein Kabel eingeklemmt wird.

# Anmerkung:

Da die verwendeten Schrauben selbstgewindeschneidend sind und das Plastik abgenutzt wird, ist häufiges Üffnen des. Gerätes zu vermeiden.

# 1.2 Leichte Reparaturen

#### ACHTUNG

Vor der Ausführung von Arbeiten an Baugruppen oder Bauteilen des PC ist unbedingt sicherzustellen, daß keine elektrostatische Ladung des Körpers oder der Werkzeuge an die Bauteile abfließen kann! (z.B. durch Verbinden des Körpers mit Masse (GND) des PC über einen Widerstand von <= 10 MOhm und einer flexiblen Leitung).

# 1.2.1 Austausch der Netzsicherung

- 1. Öffnen des Gerätes wie in 1.1. beschrieben.
- Auf der Netzfilterplatine ist nun die Sicherung zugänglich (Abb. 1.3). Der Austausch darf nur gegen eine Sicherung mit der Bezeichnung T 0,5 A erfolgen.
- 3. Schließen des Gerätes wie in 1.1.2 beschrieben.

# 1.2,2 Austausch der Netzteilplatine

- 1. Offnen des Gerätes wie in 1.1. beschrieben.
- 2. Lösen des Steckverbinders con 108-4 auf der Hauptplatine (Abb 2.2).
- 3. Lösen des Steckverbinders con 301 auf der Netzteilplatine (Abb 1.3).
- 4. Mit einer Flachzange nacheinander die Sicherungsrasen der 4 Halteklammern (Abb 1.3) zusammendrücken und die Netzplatine leicht über die Sicherungsnasen heben.
- 5. Nun die Platine vorsichtig nach oben abheben.
- 6. Aufsetzen der neuen Platine in umgekehrter Reihenfolge bis zum sicheren Einrasten der Sicherungsnasen.

- 7. Aufstecken der Verbinder con 108-4 und con 301 unter Beachtung ihrer Polaritätshilfen.
- 8. Schließen des Gerätes wie in 1.1.2 beschrieben.

# 1.2.3 Austausch des Netzsteckers oder -schalters

- 1. Uffnen des Gerätes wie in 1.1. beschrieben.
- Beachtung der elektrostatischen Ladung des Körpers (Hinweise in 1.2.2).
- Lösen der mit @ bezeichneten Schrauben mit einem Kreuzschlitzschraubendreher.
- 4. Nach dem Abnehmen der Platine sind der in Gehäuseaussparungen liegende Netzsteckerbuchse und Netzschalter zugänglich.

Typ: 3-polige EUROPA NORM-Gerätesteckerbuchse

- 5. Wiedereinbau in umgekehrter Reihenfolge.
- 6. Schließen des Gerätes wie in 1.1.2 beschrieben.

# 1.2.4 Austausch des Keyboards

- 1. Offnen wie in 1.1. beschrieben
- Lösen des Steckverbinders auf der Hauptplatine. Dabei vorsichtig, während man die Haltenase des Steckers anhebt, diesen von den Steckerstiften schieben.
- Erst jetzt die Masseverbindung zur Hauptplatine lösen.
- 4. Mit @ bezeichnete Schrauben (Abb. 1.2) mit einem passenden Kreuzschlitzschraubendreher herausdrehen.

- 5. Das Keyboard mit den Tasten nach unten belassen.
- Die Keyboardplatine jetzt vorsichtig nach oben entnehmen.

V O R S I C H T : Die auf der Oberseite sichtbaren LED's werden leicht verbogen.

- 7. Einbau
- 7.1 Die Platine ohne Gewaltanwendung in den Sitz legen.
- 7.2 Jetzt die Platine mit den Fingern im Sitz festhalten, das Gehäuseoberteil drehen und den richtigen Sitz der Tasten und LED's kontrollieren. Ggf. Platine neu in den Sitz stecken oder durch verschieben die Tasten mittig ausrichten.
- 7.3 Alle Schrauben wieder (nicht zu fest) anziehen, dabei nicht vergessen, die Masseleitung unterzulegen.
- 7.4 Masseverbindung zur Hauptplatine des TA PC herstellen.
- 7.5 Jetzt den Vielfachsteckverbinder mit seiner Sicherungsnase nach oben auf den dazugehörenden Stecker auf der Hauptplatine stecken.
- 8. Schließen des Gerätes wie in 1.1.2 beschrieben.

# 1.2.5 Austausch eines Steckers

Zum Austausch eines Steckers ist es erforderlich, die Hauptplatine auszubauen. Hiervon raten wir dringend ab, da auch schon leichtes Verbiegen der Platine wegen der angewandten "Feinleitertechnik" unweigerlich zu Leiterbahnrissen führen kann.

Von Lötarbeiten an den Baugruppen ohne spezielles Auslötwerkzeug raten wir ebenfalls wegen der sehr großen Beschädigungsgefahr dringend ab.

# 1.2.6 Austausch gesteckter IC's

#### Antistatikvorschriften beachten!

IC's nicht an den Beinchen berühren und nur auf eine geerdete Unterlage ablegen.

Falls kein kombiniertes Einsetz-/Ausziehwerkzeug zur Verfügung steht, ist das IC in möglichst vielen kleinen Schritten beidseitig hebelnd aus dem Sockel zu entnehmen. Als Hebel eignet sich notfalls eine gekröpfte Pinzette.

Es ist darauf zu achten, den Hebel nicht auf der Hauptplatine abzustützen um Leiterbahnrisse zu vermeiden.

Das Einsetzen eines IC erfolgt unter Berücksichtigung der Punkte 1 bis 4:

- Pin 1 der IC's gehört in den Kontakt unten links des Sockels, wenn das Netzteil oben rechts ist.
- 2. IC-Beinchen einer Reihe in dem Sockel ansetzen.
- Zweite Beinchenreihe parallel in Richtung erste Reihe drücken, bis die Beinchen direkt über den Kontaktfedern stehen.
- Nun des IC gleichmäßig und vorsichtig in den Sockel drücken.

### ACHTUNG:

Bei zu starkem Druck auf das IC besteht Gefahr von Leiterbahnrissen, da sich die Hauptplatine verbiegt.

#### 2. Blockschaltbild

# 2.1 Erläuterungen zum Blockschaltbild

Das Blockschaltbild (Abb. 2.1) gibt einen Einblick in die logische Konfiguration des alphatronic-PC. Funktionsblöcke sind hier als Kästen dargestellt. Steuersignale, Treiberstufen und Versorgungsspannungen sind nicht eingezeichnet. Alle Funktionsblöcke sind um das Bussystem gruppiert. Das Bussystem besteht aus einem 8 Bit breiten Datenbus und einem 16 Bit breiten Adressbus. Jeder PC-interne Datenverkehr wird über den Datenbus abgewickelt. Die jeweils dazugehörende Adresse steht auf dem Adressbus. Aus der 16 Bit Breite des Adressbusses ergibt sich ein direkt adressierbarer Speicherbereich von 2°16 = 65536 Speicherworten. Dies wird oft mit dem Kürzel "64 kByte Adressbereich" angegeben. 1k (k sprich: ka) ist die Abkürzung für 1024 = 2°10 . "Byte" kennzeichnet eine 8 Bit breite Information.

Da der alphatronic-PC jedoch über 64 k Byte RAM (Random Access Memory = Speicher mit wahlfreiem Zugriff, Schreib-/ Lesespeicher) und 32 kByte BASIC bzw. Monitor ROM (Read Only Memory = nur Lesespeicher; Festwertspeicher) verfügt, reicht der direkte Adressbereich nicht mehr aus. Aus diesem Grund wird nach dem Einschalten des PC (sofern kein Floppydisklaufwerk angeschlossen bzw. kein ROM-PACK eingesteckt ist) der Inhalt der ROM-Speicher in den RAM-Speicherbereich kopiert. Der Anwender hat hiernach nicht mehr 64 kByte RAM, sondern nur noch ca. 28 k Byte zur freien Verfügung (ca. 4 kByte RAM werden vom BASC bzw. vom Monitor für Verwaltungsaufgaben benötigt).

Im Regelfall legt der Microprozessor Z80A die Adresse des als Quelle oder als Ziel angesprochenen Speicherwortes auf den Adressbus. Der Microprozessor (MPU = Micro Processor Unit) steuert das gesamte System und arbeitet die Progamme ab. Der Prozessor Z80A ist im Kapitel 3 näher beschrieben.



Die Bildschirmsteuerung wird von folgenden Funktionsblöcken Übernommen:

CRT-Controller (Cathode Ray Tube Controller = Bild-schirmsteuerbaustein); er übernimmt die gesamte zeitliche Steuerung des/der angeschlossenen Monitore(s).

Video-RAM; hier werden die vom Monitor darzustellenden Zeichen als 8 Bit Informationen in Speicherbytes abgelegt.

Attribut-RAM; hier werden zusätzliche Farbinformationen zu den im Video-RAM gespeicherten Zeichen abgelegt.

Zeichengenerator (Character-Generator); hierbei handelt es sich auch um einen Festwertspeicher. Er wandelt die 8 Bit Zeicheninformation mit Hilfe einer vom CRT-Controller erzeugten Zeileninformation in eine 8 \* 10 Bit Zeichenmatrix, die der graphischen Darstellung des Zeichens entspricht.

P / S (parallel/seriell-Wandlung); hier wird die jeweils 8 Bit breite Zeicheninformation in einen seriellen Datenstrom gewandelt.

Mit "Sync" sind die für den Monitorbetrieb erforderlichen Synchronisationssignale angedeutet.

Nähere Informationen finden sich in Kapitel 5.

Die weiteren Schnittstellen des PC (serielle Ein-/Ausgabe, paralleles Ausgabeport, Systembus-Schnittstelle, Tastatur) sind ebenfalls in Kapitel 5. beschrieben.

Der Unterbrechungsanforderungen bearbeitende Interruptcontroller und der DMA- (Direct Memory Access) Controller – er steuert den direkten Zugriff eines peripheren Gerätes auf den Speicher des PC; der Z80A Prozessor ist hierbei nicht aktiv – sind in Kapitel 5.6 erläutert.

Die tatsächliche Anordnung der Funktionsblöcke auf der Hauptplatine des PC ist in Abb. 2.2 dargestellt.



# 3. Mikroprozessor Z 80 A

# 3.1 Architektur des Z 80

Kernstück der Zentraleinheit (CPU) des alphatronic-PC ist der Mikroprozessor (MPU) Z 80 A von Zilog (Zweithersteller z.B. Mostek, NEC). Der Z 80 A entspricht in der Struktur und seinem Befehlssatz dem Z 80. Der einzige Unterschied ist in der Verarbeitungsgeschwindigkeit zu finden. Im PC kommt der Z 80 A zum Einsatz. Er arbeitet mit einem 4 MHz Taktgenerator.

Er ist ein 8-bit Mikroprozessor, das heißt der Datenbus, über den der Prozessor Daten mit Speicherbausteinen oder Ein-/Ausgabebausteinen austauscht, ist 8 bit breit. Ferner verfügt der Prozessor über einen Adressbus und einen Steuerbus. Der Adressbus ist 16 bit breit. Er überträgt im Regelfall eine vom Prozessor erzeugte Adresse, die ein Speicherwort oder Ein-/Ausgaberegister anwählt. Der direkt adressierbare Speicherbereich beträgt also 2°16= 65536 Speicherworte (1 Wort = 1 Byte). Der Steuerbus überträgt Signale, die zur Synchronisation des Systems erforderlich sind. Zum Beispiel bestimmt der Zustand des Steuerbusses, ob das über den Adressbus angewählte Datenwort Quelle oder Ziel der Datenbusinformation ist. In Abb. 3.1 ist die interne Struktur des Z80A schematisch dargestellt.



# Erläuterungen zur Blockstruktur:

# 1. ALU (arithmetic logic unit), Rechenwerk

Das Rechenwerk übernimmt die Durchführung von arithmetischen und logischen Operationen. Hier werden Additionen, Subtraktionen (in 2er-Komplementarithmetik) und logische Grundverknüpfungen von Eingangsdaten durchgeführt. Ferner kann die ALU auch den Inhalt von 8-bit Datenworten verschieben bzw. rotieren lassen. Einzelne Bits eines Wortes können gesetzt. gelöscht oder gezielt abgefragt werden.

#### Registersatz

Der Z80 besitzt folgende Register:

A, F, B, C, D, E, H, L, IX, IY, die für den Anwender zur Verfügung stehen.

Für die Register A bis L existiert parallel ein Hintergrundregistersatz A' bis L'. Die Registersätze können nur komplett ausgetauscht werden.

2. A (Accumulator), Rechenregister

Das Rechenregister arbeitet direkt mit dem Rechenwerk zusammen.

3. B, C, D, E, H, L Universalregister, jeweils 8 bit breit

Sie können beliebige Daten beinhalten und ermöglichen eine schnelle Datenverknüpfung mit Hilfe des Rechenwerkes. Diese Register können auch paarweise angesprochen werden und zwar in den Paarungen BC, DE, HL, um 16 bit breite Informationen zu speichern.

4. Flagregister, Signalregister

Die Bits dieses Registers signalisieren den Zustand des Akku-

Es ist wie folgt aufgebaut: nicht benutzt

mulators bzw das Ergebnis der letzten Rechenoperation.

```
Ubertrag (≘ 1) (Carry-flag)
                      nur intern von der MPU bei BCD-
                      Subtraktion benutzt
            . Paritäts- oder Überlaufbit, je nach Operation
          . . nicht 8080-kompatibel, da hier ein Überlauf
          . . bei 2er - Komplementoperationen signalisiert
          . . wird. Weiterhin wird dieses Bit von der MPU
          . . bei Blocktransfer und -Vergleichsoperationen
            . benutzt.
          . nicht benutzt
         Halbübertrag (BCD-Arithmetik) (Halfcarry)
    Zero (1 = Null, 0 = ungleich Null)
Vorzeichen (1 ≜ Minus, 0 ≜ Plus)
```

# 5. A', F' Hintergrundregistersatz

Mit diesen können das Rechenregister A oder das Flagregister F ausgetauscht werden. Zugriff auf diese Register ist nur mit Hilfe des Austausches möglich.

# 6. BC', DE', HL' Hintergrundregistersatz

Zugriff auf diesen Registersatz ist wie bei A' F' nur möglich, wenn er zuvor mit den Registern B bis L ausgetauscht wurde. Der Austausch aller 3 Paare ist mit nur einem Befehl (EXX) möglich.

### 1. Direkte (Absolute) Adressierung

Der Befehl gibt die Adresse(n) des Speicherwortes, mit der die Operation durchgeführt werden soll, an.

Beispiel: LD (2345), A

A > (2345)

### 2. Indirekte Adressierung

Der Befehl gibt ein Registerpaar an, dessen Inhalt auf den Operanden zeigt, der bearbeitet werden soll.

Beispiel: LD A, (HL)

(HL) > A

### 3. Implizite Adressierung

Der Befehlscode wirkt nur auf definierte Register, deren Abkürzungen nicht im Befehl auftauchen. z.B. EXX (Austausch von BC, DE, HL mit den Hintergrundregistern BC', DE', HL')

Beispiel: LD A,B

B > A

# Klammern () in der Mnemonik bedeuten immer "Inhalt von"!

# 4. Relative Adressierung

Vergleiche Punkt 11 der Befehlstypen.

Beispiel: JR C2

# 5. Unmittelbare (immediate) Adressierung

Das Datenwort steht direkt im Befehl.

Beispiel: LD A.O3H

03 > A

# 6. Indizierte Adressierung

Erweiterung der indirekten Adressierung. Der Adressregisterinhalt bleibt unverändert, es wird jedoch eine direkt im Befehl stehende Distanz (Displacement) bei der Adressenausgabe berücksichtigt.

Beispiel: SET 1,(IX+3)

#### Mischformen

Indirekt, unmittelbar: LD (HL), 22H
Indiziert, unmittelbar: LD (IX+5) 22H

# 3.2.2 Befehlstypen

Der Prozessor Z 80 A verfügt über folgende Typen von Befehlen:

1. Datentransferbefehle (sowohl 8- als auch 16 bit-Transfer)

Diese Ladebefehle haben folgendes Format:

LD Ziel, Quelle

Nach Ausführung eines solchen Befehls (8 Bit-Transfer) befinden sich in Ziel und Quelle die ursprünglichen Quelldaten. Von dieser Mnemonik weichen 2 Befehle ab (16 Bit):

PUSH Registerpaar

und

# POP Registerpaar

PUSH legt den Registerinhalt auf den Datenstapel im Speicher; POP holt den letzten Eintrag vom Stapel. In beiden Fällen wird der Stapelzeiger automatisch angepaßt. Die Austauschbefehle EX Operand 1, Operand 2 (Exchange) tauschen die Inhalte der im Argument stehenden Operanden aus. Ausnahme: EXX, hier werden die Register BC, DE, HL. mit ihren Hintergrundregistern ausgetauscht.

#### 2. 8-bit Rechenbefehle

Fast alle dieser Befehle benötigen 2 Operanden. Der erste ist immer das A (Rechen-) -Register oder eine "1" (vergleiche implizierte Adressierung). Das in der Befehlserläuterung verwendete Zeichen ":=" bedeutet "ergibt sich aus", x entspricht dem 2ten Operanden und ü (oder c) ist das Übertragsbit (Carrybit) des Flagregisters.

| MNEMONIK | BEFEHL           | ANMERKUNG           |
|----------|------------------|---------------------|
| ADD X    | A := A + X       |                     |
| ADC X    | A := A+X+ü       | (Add with Carry)    |
| SUB X    | A := A - X       |                     |
| SBC X    | A := A-X-ü       | (Substr.with Carry) |
| AND X    | Ai:= Ai ^ Xi     | logisches UND       |
| OR X     | Ai:= Ai v Xi     | logisches ODER      |
| XOR X    | Ai:= AiXi v AiXi | " ENTWEDER          |
|          |                  | -oder               |
|          |                  | (Exclusive OR)      |
| - CP X   | A - X            | Veränderung des     |
|          |                  | Flag Registers      |
|          |                  | (Compare)           |
| INC X    | X := X+1         | (Increment)         |
| DEC X    | X := X-1         | (Decrement)         |
|          |                  |                     |

Der Index i bedeutet: hier werden die Bits gleicher Wertigkeit verknüpft.

#### 3. 16 bit Arithmetik

In den hier aufgeführten Befehlen bedeutet XX ein 16 bit Register(paar) der MPU. HL meint z.B. das Paar HL.

| ADD | XX1,XX2 | XX1:=XX1+XX2 | nicht alle    |
|-----|---------|--------------|---------------|
| ADC | HL,XX   | HL:=HL+XX+ü  | Kombinationen |
| SBC | HL,XX   | HL:=HL-XX-ü  | von Register- |
| INC | XX      | XX := XX + 1 | paaren sind   |
| DEC | XX      | XX:=XX - 1   | zulässig.     |

### 4. Bitmanipulation und Test

Diese Befehle nutzen als Operanden ein Bit i eines Registers oder eines indirekt adressierten Speicherwortes X (Z ist das Null (Zero)bit des Flagregisters).

| BITi,X | Z := Xi | (Bit Test)  |
|--------|---------|-------------|
| SETi,X | Xi = 1  | (Set Bit)   |
| RESi.X | Xi = 0  | (Reset Bit) |

# 5. Speicher-Block-Verschiebe Befehle

Die hier aufgeführten Befehle dienen der Bearbeitung von Datenblöcken. Es handelt sich um 4 Befehle:

LDI, LDIR, LDD, LDDR.

Der Befehl LDI (Load with Increment) bewirkt folgendes:

Der Inhalt des Speicherwortes (1 Byte), auf das HL zeigt, wird in das von DE adressierte Wort transferriert. Anschlie-Bend wird der Inhalt der Registerpaare HL und DE um 1 erhöht. Der Inhalt des Registerpaares BC wird um 1 erniedrigt.

Der Befehl LDIR (Load with Increment and Repeat) unterscheidet sich vom vorhergehenden wie folgt:

Der Befchl LDIR führt ein LDI aus bis der Inhalt des Registers BC = 0 ist.

Der Befehl LDD (Load with Decrement) unterscheidet sich vom Befehl LDI nur dadurch, daß die Registerpaare HL, DE und BC um 1 erniedrigt werden.

Der Befehl LDDR (Load with Decrement and Repeat) arbeitet analog zum Befehl LDIR; hier werden wie beim Befehl LDD die Inhalte der Registerpaare erniedrigt bis die Abbruchbedingung BC = 0 erreicht ist.

# 6. Block-Vergleichs-Befehle

Auch hier gibt es 4 Befehle:

CPI (Compare with Increment),

CPIR (Compare with Increment and Repeat),

CPD (Compare with Decrement) und

CPDR (Compare with Derement and Repeat).

Hierbei wird jeweils der Inhalt des vom Registerpaar HL adressierten Speicherwortes vom Inhalt des Akkumulators subtrahiert und das Flagregister entsprechend beeinflußt. Die weitere Ausführung (z.B. Beeinflußung des Registerpaares BC) erfolgt analog zu den Block-Verschiebe-Befehlen.

# 7. Rotations- und Verschiebebefehle

Die Funktion dieser Befehle wird durch die nachfolgend aufgeführten Schaubilder deutlich. Der dargestellte 8 bit Block ist entweder eines der MPU Register oder ein durch HL, IX bzw. IY adressiertes Speicherwort S.



ten Befehls im 2er Komplement. Das heißt, relative Sprünge sind im Bereich +127 und -128 Bytes möglich, da sich die Distanz (Displacement) zu dem Befehlszählerstand nach Ausführung des Sprungbefehls addiert.

JP XX = unbedingter Sprung zur Adresse XX, bzw. Sprung zur Adresse die von einem Registerpaar übergeben wird.

JR X = unbedingter Sprung zur Programmzähleradresse + X.

Bedingte Sprünge:

JP b,XX JR br.X

Bei Ausführung dieser Befehle wird nur ein Sprung stattfinden, wenn die Bedingung b bzw. br wahr ist.

b kann sein:

NZ (= No Zero, nicht 0)

Z (= Zero , 0)

NC (= No Carry, kein Ubertrag )

C (= Carry, Ubertrag )

PO (= Parity Odd, Parität ungerade )

PE (= Parity Even, Parität gerade )

P (= Plus )
M (= Minus )

bzw. br kann sein NZ, Z, NC, C

Der letzte, noch nicht erwähnte Sprungbefehl lautet:

DJNZ X (Decrement and Jump if Note Zero)

Hierbei handelt es sich um einen relativen Sprungbefehl. Bei der Ausführung dieses Befehls wird zunächst der Inhalt des B-Registers der MPU um 1 verringert (dekrementiert). Ist danach der Inhalt von B ungleich Null, wird ein relativer Sprung ausgeführt. Ansonsten wird der nächste Befehl abgefragt. 12. Unterprogrammaufruf und Rückkehr zum Hauptprogramm.

Bei der Erstellung von Programmen muß häufig in verschiedenen Bearbeitungsphasen eine gleiche Befehlssequenz durchlaufen werden. Derartige Befehlsblöcke können mit einem Namen versehen und außerhalb des eigentlichen Programmes (=Haupt-programm) als "Unterprogramm" abgespeichert werden. Erreicht das Hauptprogramm einen Punkt (CALL), an dem die häufig benötigte Sequenz durchlaufen werden muß, wird die Startadresse des Unterprogramms in den Befehlszähler geladen.

Weiterhin muß sich das System die Rücksprungadresse merken, um nach Ausführung der Unterprogrammsequenz zu dem Befehl hinter den Programmaufruf zurückfinden zu können. Bei Z 80-Systemen wird bei Ausführung eines Unterprogrammaufrufes der Befehlszählerinhalt auf den Datenstapel gelegt und der Stapelzeiger entsprechend angepaßt.

Es gibt zwei Unterprogrammaufrufe:

CALL XX = unbedingter Unterprogrammaufruf

CALL b, XX = bedingter Unterprogrammaufruf, b entspricht

den bei den bedingten, absoluten Sprüngen aufgelisteten Bedingungen, die zur Ausführung des

Befehls wahr sein müssen.

Die Unterprogramme enden mit einem Rücksprungbefehl, der die Rücksprungadresse wieder vom Datenstapel in den Befehlszähler lädt ( $\underline{V}$  O R S I C H I bei Stapelmanipulationen innerhalb von Unterprogrammen!).

Die Rückkehrbefehle lauten:

RET = (Return) unbedingte Rückkehr zum Hauptprogramm

RET b = bedingte Rückkehr zum Hauptprogramm, b entspricht ebenfalls den oben genannten Bedingungen, die zur Ausführung wahr sein müssen. 13. Rückkehr von Interrupt bearbeitenden Routinen.

Bricht die MPU die Bearbeitung eines Programmes durch einen Interrupt (= Anforderung an die Programmsteuerung, Unterbrechungsanforderung) ab, wird der Befehlszählerstand ebenfalls auf dem Datenstapel abgelegt. Durch die Befehle "RETI" (Return from Interrupt ) bzw. "REIN" (Return from nonmaskable Interrupt) kann nach Ausführung der den Interrupt behandelnden Routine wieder zurück zum unterbrochenen Programm gesprungen werden.

Diese Befehle arbeiten analog zu dem in 12. erläuterten Befehl "RET".

#### 14. Restart-Befehl

Dieser Befehl belegt nur 1 Byte. Er bewirkt den Sprung zu einer von 8 Speicheradressen, nachdem er den Inhalt des Befehlszählers auf den Stapel gelegt hat (wie bei CALL oder PUSH beschrieben). Die möglichen Speicheradressen sind folgende: 0, 8, 16, 24, 32, 40, 48, und 56 (dezimal). Der Befehl wirkt wie ein schneller CALL-Befehl zu einer dieser speziellen Adressen.

# 15. Ein-/Ausgabebefehle

Im Folgenden werden Ein- und Ausgabebefehle, deren Funktion analog ist, gemeinsam erläutert.

IN A,(n) / OUT A,(n)

Das periphere Gerät mit der Portadresse n wird ausgewählt. Die Daten werden mit dem Register A ausgetauscht. IN lädt die Daten von der Peripherie in den Akkumulator, OUT gibt die im Akkumulator stehenden Daten aus. Flags werden bei der Ausführung dieses Befehls nicht beeinflußt.

|        | -                    | 31 -                                                                                                                                                                                                                                                                                                                            |
|--------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | IN r,(C) / OUT r,(C) | Hier wird das periphere Gerät durch<br>Inhalt des C-Registers der MPU<br>adressiert. Der Datenaustausch ge-<br>schieht mit dem Register R.                                                                                                                                                                                      |
|        | INI / OUTI           | (IN / OUT, Increment) Auch hier wird die Peripherie durch den Inhalt des C-Registers der MPU adressiert. Der Datenaustausch ge- schieht mit dem durch das Register- paar HL ausgewähltem Speicherwort. Anschließend wird HL inkrementiert und das Register B dekrementiert. Das Flagregisterbit Z (Null) wird von B beeinflußt. |
|        | INIR / OTIR          | (IN / OUI, Increment and Repeat<br>Diese Befehle arbeiten zunächst wie<br>die zuvor beschriebenen Befehle INI/<br>OUII. Sie werden jedoch so lange<br>wiederholt, bis der Inhalt des B -<br>Registers gleich Null ist.                                                                                                          |
|        | IND / OUTD           | (IN / OUT and Decrement) Diese Befehle unterscheiden sich von INI und OUTI dadurch, daß das Regis- terpaar HL nicht erhöht, sondern um l erniedrigt wird.                                                                                                                                                                       |
|        | INDR / OTDR          | (IN / OUT, Decrement and Repeat) Hier wird analog INIR / OTIR ver- fahren, jedoch HL wie bei IND dekre- mentiert.                                                                                                                                                                                                               |
|        |                      |                                                                                                                                                                                                                                                                                                                                 |
|        |                      |                                                                                                                                                                                                                                                                                                                                 |
| pm 15: |                      |                                                                                                                                                                                                                                                                                                                                 |

# 4. Memory Mapping

### 4.1 Speicher-Belegung

Nachstehend die grundsätzliche Speicherbelegung, die sich nach einem Hardwarereset oder dem Einschalten des alphatronic-PC ergibt, wenn kein Floppy-Disc-Laufwerk angeschlossen ist:

Adresse

: Inhalt

0000 bis 1FFF

: Basic ROM 1

2000 bis 3FFF 4000 bis 5FFF

: Basic ROM 2 : Basic ROM 3

A000 bis BFFF

: ROM PACK 1 (falls

COOO bis DFFF

: ROM PACK 2 (vorhanden

F000 bis FFFF

: Monitor ROM

(je nach

F000 bis FFFF

: Video und Attribut RAM (Auswahl

(durch

(SPORT

0000 bis FFFF : RAM

Wird der alphatronic-PC mit einer (oder zwei) Floppy-Disk-Station(en) und der Disk-Basic-Diskette betrieben, so wird der Basic-Interpreter nicht vom ROM sondern von der Diskette geladen. Das Ende des Interpreter kann dann aber nicht fest mit 5FFF angegeben werden, da je nach Eingabe bei "How many files" mehr oder weniger Pufferspeicher benötigt wird.

Bei Betrieb mit einem CP/M Betriebssystem sind die Bereiche CCP, BIOS und BDOS wie folgt verteilt:

#### Adresse

C300 bis C3AF : CCP CB00 bis D8FF : BDOS D900 bis E3FF : BIOS

# 4.2 I/O Adressen

Die nachstehende Liste beinhaltet die sedezimalen Adressen der im alphatronic-PC vergebenen I/O Adressen.

Adresse : belegt für

10 : Systemadresse

20

30 : Parallelschnittstelle (Centronics)

40 : Serielle Schnittstelle (V24, RS 232C)

11 41

50 : Video Controller

51

60

68

: DMA Controller

70 : Interrupt Controller

71

FO : Floppy Disc Controller

F8

\* Bemerkung: Diese Adressen sind nur über die Adressen A3H bis A7H und AO dekodiert

Nachträgliche Erweiterungen:

Adresse : : Erweiterung



# 5. Schnittstellenbeschreibungen

# 5.1 System Port (SPORT)

Zur Steuerung des Ein-/Ausgabeverkehrs wird das System Port benutzt. Es wird z.B. durch den Assembler-Befehl OUT 10H angesprochen. Die Bits des 1 Byte breiten Ports haben folgende Bedeutung:

| Bit O (LSB) | Zeilenlänge ( | des | Bildschirms |
|-------------|---------------|-----|-------------|
|-------------|---------------|-----|-------------|

1 = 80 Zeichen / Zeile 0 = 40 Zeichen / Zeile

Bit 1 Bildschirmdarstellung

1 = ausgeschaltet
0 = eingeschaltet

Bit 2 Cassettenrecorder oder V24

1 = V24

O = Cassettenrecorder

Bit 3 Cassettenrecorder-Fernsteuerung

1 = Motor ein
0 = Motor aus

Bit 4 Buzzer (Summer)

1 = ein

0 = aus

Bit 5 muß immer O sein

Bit 6 ROM-PACK Freigabe (enable)

1 = ROM-PACK freigegeben (enabled)
 (nur wonn Bit 7 auf 0 gesetzt ist)

0 = ROM-Pack gesperrt (disabled)

Bit 7 (MSB) Freignbe des ROM Zugriffs

1 = Zugriff auf die ROM's ist gesperrt; die MPU arbeitet mit den in das RAM kopierten Daten/Befehlen

O = Zugriff auf die ROM's ist freigegeben

T-

\_\_\_

L.

Der Inhalt dieses aus zwei 4-Bit D-Flip Flops (74 LS 175) bestehenden Registers kann von der MPU nicht gelesen werden. Der Befehl IN 10H fragt ein anderes Register ab (siehe unten). Um den ausgegebenen Status kontrollieren bzw. ändern zu können, wird nach jeder Ausgabe eine Kopie des ausgegebenen Bytes in das RAM-Wort mit der Adresse E46BH geschrieben (SFFO-Byte). Nach dem Kaltstart des alphatronic-PC wird 00 an das Sytem Port ausgegeben und eine Kopie in dem SFFO-Byte abgelegt.

Mit dem Befehl IN 10H wird ein 8 Bit Port abgefragt, das den vorgegebenen Status (z.B. durch DIP-Schalter Abb. 5.1) beschreibt.

### Bedeutung der Bits:

| Bit O (LSB) | Floppy-Disk Laufwerk       |
|-------------|----------------------------|
|             | l = Laufwerk ist verfügbar |
|             | 0 = " ist nicht verfügbar  |

### Bit 1 reserviert

Bit 2, 3, 4 Auswahl des über die Tastatur zugänglichen Zeichensatzes (über den DIP Schalter wählbar)

| 0 | 0 | 0 | internationaler | Zeichensatz |
|---|---|---|-----------------|-------------|
| 0 | 0 | 1 | deutscher       | H           |
| 0 | 1 | 0 | USA             | *1          |
| 0 | 1 | 1 | französischer   | H           |
| 1 | 0 | 0 | englischer      | 11          |
| 1 | 0 | 1 | italienischer   | 11          |
| 1 | 1 | 0 | spanischer      | *1          |
| 1 | 1 | 1 | reserviert      |             |

| Bit | 5 | Druckerauswahl |
|-----|---|----------------|
|     |   |                |

- 1 = Drucker mit serieller Schnittstelle, Datenausgabe über V24 Schnittstelle
- O = Drucker mit Centronicskompatibler Schnittstelle, Datenausgabe über das Parallelport
- Bit 6 Auswahl der TV-Norm
  - 1 = NTSC, hierbei muß der Taktgenerator des CRT-Controller Bausteins mit einem 14,318 MHZ Schwingquarz bestückt sein
  - 0 = PAL, hierzu ist ein 17,72 MHZ Schwingquarz notwendig

Bit 7 (MSB) Bildschirmperiodenüberwachung

theor.
12 us!

1 = Austastlücke

0 = es wird gerade auf dem Bildschirm geschrieben

# \* Hinweis:

Die Ländervarianten-Angaben beziehen sich auf einen Monitorstand mit der Bezeichnung B4 – 7 und größer. Soll ein Gerät auf eine andere Ländervariante umgestellt werden, so ist auch ein Austausch des Zeichengeneratorproms notwendig. Bei Mitnahme in andere Länder ist auf die unterschiedlichen Netzspannungen zu achten (ggf. muß ein entsprechender Transformator evtl. mit Frequenzumsetzer dazwischengeschaltet werden).

# DIF-Schalter (SW 102)

Im Gerät befindet sich auf der Platine ein DIP-Schalter mit sechs Einstellmöglichkeiten:

Schalter 1 - 3

dient zur Einstellung von Ländervarianten der Tastatur

Schalter 4

Auswahl der Druckerschnittstelle (parallel, seriell)

Schalter 5

Schalter 6

JV-Farbsystem (PAL, NTSC)
ohne Funktion

### Schaltervoreinstellung:

| 1         | 2        | 3        |                                                                                                                          |
|-----------|----------|----------|--------------------------------------------------------------------------------------------------------------------------|
| ON<br>OFF | ON<br>ON | ON<br>ON | Internat. Tastatur<br>Deutsche Tastatur                                                                                  |
|           |          | 4        |                                                                                                                          |
|           |          | OFF      | V.24 (seriell): Voreinstellung                                                                                           |
|           |          | ON       | für den europäischen Bereich<br><u>Centronics</u> (perallel): Vorein-<br>stellung für den außereuropä-<br>ischen Bereich |
|           |          | 5        |                                                                                                                          |
|           |          | OFF      | NTSC                                                                                                                     |
|           |          | ON       | PAL                                                                                                                      |



Dip-Schalter Abb. 5.1

# 5.2 Tastaturschnittstelle

Die in das Gehäuse des alphatronic-PC integrierte Tastatur ist als Schaltermatrix aufgebaut.

Die Tastaturplatine ist über ein Kabel mit der Hauptplatine verbunden. Folgende Leitungen stellen die Verbindung her:

Versorgungsspannung (5V, GND)

- 1 Steuerleitung für die GRAPH-LED
- 1 Steuerleitung für die SHIFT-LED
- 12 Steuerleitungen zur Tastaturmatrix (SCO SC11)
- 8 Antwortleitungen von der Matrix (RTO RT7)

Aus der Anzahl der Leitungen geht hervor, das es sich hier um eine 12 x 8 Matrix mit maximal 96 Tasten handelt, die sich an den "Schnittpunkten" der Matrix befinden (das heißt: eine der Leitungen SCO – 11 wird durch Betätigung einer Taste mit einer der Leitungen RTO – RT7 verbunden werden).

Nun wird ein 10.3 msec Abfragepuls (scan time) nacneinander an jede der Leitungen SCO – SC11 gelegt und währenddessen die Antwortleitungen gelesen. Ist eine Taste gedrückt, gelangt der Puls also wieder zurück zur MPU. Die entsprechende Taste wird als betätigt erkannt. Die Antwortleitungen werden über die Portadressen 20H-2BH abgefragt. Die Steuerleitungen SCO-SC11 verbergen sich in den niederwertigen 4 Bit der Portadresse (O-B = O-11 dezimal).

#### Anmerkung:

In alphatronic-PC's mit niedrigerer Seriennummer beträgt die Abfragezeit 20.7 msec. Der Unterschied zu neueren ist in einem Monitorprogramm zu finden. Die Zeitkonstante für diese Softwareverzögerung steht in den Speicherbytes mit den sedezimalen Adressen E5F1 und E5F2:

> E5F1: DO (niederwertiges Byte) E5F2: OA (höherwertiges Byte)

Hier ist die Konstante ADO (sedezimal) = 2768 (dezimal) für die 20.7 msec maßgeblich; eine 7.5 microsec dauernde Schleife wird 2768 mal durchlaufen.



|   | Ø              | 1   | 2        | 3 | 4 | 5 | 6 | 7   | 8            | 9               | A | В | C | D   | E        | F |
|---|----------------|-----|----------|---|---|---|---|-----|--------------|-----------------|---|---|---|-----|----------|---|
| Ø |                | I   | SP       | 9 | 6 | P | ` | Р   |              |                 |   |   |   |     | г        |   |
| 1 |                |     | !        | 1 | A | Q | a | q   | 1            |                 |   |   |   |     | ٦        |   |
| 2 |                | INS | -        | 2 | 8 | R | Ь | r   | 2            |                 |   |   |   | 500 | L        |   |
| 3 | BRK            |     | ,        | 3 | С | S | С | s   | 3            |                 |   |   |   |     | ١        |   |
| 4 |                |     | S        | 4 | D | T | d | t   | 4            |                 |   |   |   |     | _        |   |
| 5 |                |     | 2        | 5 | Ε | U | e | U   | (3)          |                 |   |   |   |     | 1        |   |
| 6 |                |     | 8        | 6 | F | ٧ | f | ٧   | 6            |                 |   |   |   |     | +        |   |
| 7 | BEL            |     | -        | 7 | 6 | W | g | w   | SHILI        |                 |   |   |   |     | +        |   |
| 8 | <b>®</b><br>BS |     | (        | 8 | н | χ | h | ×   | 34JF1        |                 |   |   |   |     | F        |   |
| 9 | TAB            |     | )        | 9 | 1 | Y | 1 | У   | SHJГТ        | 9₹              |   |   |   |     | 4        |   |
| A | ⊕<br>LF        |     | (x)      | : | J | Z | j | z   | (a)          | 0.1<br>145<br>0 |   |   |   |     | <b>-</b> |   |
| В | HOME           | ESC | +        | ; | К | X | k | ä   | SHIFT        | 0               |   |   |   |     | _        |   |
| С | CLR            | -   | ,        | < | Ĺ | ۵ | 1 | 0   | SHIFT<br>(6) |                 |   |   |   |     | 0        |   |
| D | CR             | -   | -        | • | н | 0 | m | Ü   |              |                 |   |   |   |     | •        |   |
| Ε |                | 1   |          | , | N | ^ | n | В   |              |                 |   |   |   |     | 8        |   |
| F |                | 1   | /<br>(÷) | ? | 0 |   | 0 | DEL |              |                 |   |   |   | GR  |          |   |

Abb. 5.3 Deutscher Zeichen-Code (ROM-BASIC)

Anmerkung: (\*) = keine Taste auf der Tastatur



# 5.3 Serielle Schnittstelle

Der alphatronic-PC ist mit einer seriellen Schnittstelle nach DIN 66020 bzw. EIA RS 232C bzw. CCIIT V.24 ausgerüstet. Die serielle Schnittstelle ist durch den integrierten Schaltkreis 8251A (Siemens, Intel, Nec, ...) mit nachgeschalteten pegelanpassenden Schaltkreisen SN 75150, SN 75154 und SN 75189 (Texas Instruments) realisiert. Das Übertragungsverfahren ist durch Voreinstellung von dem PC-internen Rangiersteckverbinder und die Initialisierung des Ein-/Ausgabebausteins 8251A von der Start-Routine in folgenden Modus gesetzt:

A Synch 16
PBit
No Parity
2 Stopphits

asynchrone serielle Datenübertragung nach V24 (RS 232C) mit 4800 Bd (Baud, nach Baudot); jedes Wort besteht aus 1 Startbit, 2 Stoppbits; zwischen Start und Stopbits befinden sich jeweils 7 Datenbits sowie 1 Paritätsbit (gerade Parität, even Parity)

Der USART (universal synchronous/asynchronous receiver and transmitter) 8251A bietet im Zusammenhang mit dem Baud-Rate-Generator und dessen Rangiersteckverbinder jedoch eine Vielzahl weiterer Übertragungsprotokolle.

1. Ubertragene Pegel

Bei dem hier angewandten Verfahren wird eine logische Ø als Spannung von ca +10 V gesendet; eine logische 1 entspricht einer Spannung von ca -10 V. Ein Empfänger erwartet laut den Datenblättern der Treiber-IC's für eine Ø, eine Spannung die größer ist als +3 V und für eine 1 eine Spannung die zwischen -3V und -12V liegt.

2. Asynchrone Datenübertragung

In diesem Betriebsmodus sendet bzw. empfängt der USART Baustein serielle Daten, deren Format durch Steuerregister festgelegt ist. Jedes zu sendende Datenwort wird, nachdem es vom parallelen Datenbus des Prozessors in das Senderegister geladen wurde, seriell ausgesendet. Die Länge eines seriellen Datenwortes ist durch die Programmierung eines Steuerregisters

vorgegeben. Sie kann 5, 6, 7 oder 8 bit betragen. (Werden z.B. 5 Bit Datenworte gesendet, sind die 3 höherwertigen Bits der 8 Bit Datenbusinformation verloren). Jedem gesendeten Wort wird ein Startbit vorangestellt. Hierbei wird nach einer Pause oder einem Stoppbit (logisch Ø) eine 1 gesendet. Es folgen die Datenbits. Nach den Datenbits kann ein Paritätsbit gesendet werden. Man unterscheidet gerade (even) und ungerade Parität (odd parity). Gerade Parität heißt, daß in jedem Datenwort die Quersumme aller gesendeten Bits gerade ist; bei ungerader Parität ist die Summe ungerade. Dieses Paritätsbit ermöglicht dem Empfänger das Erkennen von Übertragungsstörungen. Den Abschluß eines übertragenen Datenwortes bildet die Stoppinformation. Sie kann 1, 1,5 oder 2 Bit lang sein.

Als Empfänger kann der USART serielle Datenworte entsprechend der eingestellten Baudrate, Datenwortlänge und Parität erkennen und dem Prozessor parallel anbieten. Vom PC gesendete Daten können am Pin 2 des Schnittstellenverbinders abgegriffen werden (TxD); vom PC zu empfangende Daten können an den Pin 3 (RxD) gelegt werden. Das Bezugspotential (Masse) liegt an Pin 7.



Bei synchroner Datenübertragung entfallen Start- und Stopbits.

Sowohl Sender als auch Empfänger sind mit einem eigenen Taktgeber ausgerüstet. Beide Seiten müssen auf die gleiche Übertragungsgeschwindigkeit eingestellt sein; eine Synchronisation der beiden Takte ist nicht erforderlich. Der Abtastzeitpunkt für die beiden Takte wird digital bestimmt. Zu diesem Zweck ist es erforderlich, daß die Taktgeberfrequenz ein Vielfaches (progammierbar 16 oder 64) der Baudrate ist. Typische Zusammenschaltung von 2 Datenendeinrichtungen (DEE):



# 3. Synchrone Datenübertragung

Der Unterschied zu asynchronen Datenübertragung besteht darin, daß der als Sender arbeitende USART-Baustein nach der Initialisierung und, falls kein zu sendendes Zeichen im Baustein vorhanden ist, Synchronisationszeichen (SYNC-Zeichen) automatisch sendet. Zum Empfangsbetrieb muß der USART-Baustein nach Übergabe der Modus- und Sync-Worte in den Suchmodus geschaltet werden. Nach Wahl der internen Zeichensynchronisation testet der Empfänger das Signal am Dateneingang (RxD) jeweils mit den steigenden Flanken des Empfangstaktes (RxC) ab und vergleicht nach Empfang eines Bits die zuletzt empfangenen Bits mit dem festgelegten Sync-Zeichen. (Ein Doppel-Sync-Modus kann programmiert werden. In diesem Modus werden 2 aufeinanderfolgende Worte untersucht. Diese Wortfolge muß den Bitkombinationen der Worte SYNC1 und SYNC2 entsprechen). Ist ein solches Zeichen (oder Doppelzeichen) empfangen worden, wird dies durch den H-Pegel des SYNDET/BD-Bits im Statusregister des USART markiert und der Suchmodus beendet. Dieses Bit wird auch bei Empfang eines Sync-Wortes (bzw. Doppelwortes) außerhalb des Suchmodus gesetzt.

Der programmierbare Modus der externen Zeichensynchronisation des USART-Bausteins kann beim PC durch Umlöten der Lötbrücken (Abb. 5.5) 1 - 2 und 4 - 5 verwendet werden.



Rangierverbinder zur Einstellung der Ausgangsspannung an PIN 1 und 4 der Cassettenrecorderschnittstelle

Abb. 5.5

Lötbrücken zur Verbindung des USART mit dem 2 vom Steckverbinder Empfangs- bzw. zum USART vom internen Sendetakt Baudrale generator

Baudrate Rangierverbinder 1200 600 300

Auslieferungszustand



Blockschaltbild USART

mild Kompatibel mil

Abb. 5.6 Skokverbindeg

Im Blockschaltbild ist die interne Struktur des USARI-Bausteines schematisch dargestellt. In der Mitte befindet sich der interne Bus. Auf der linken Seite erkennt man die MPU-orientierten Funktionsblöcke und die von ihnen zum Prozessor verdrahteten Leitungen. Auf der rechten Seite sind die zur Kommunikation mit der Peripherie arbeitenden Strukturblöcke mit ihren erforderlichen Anschlüssen dargestellt. Eine Ausnahme bilden die Leitungen TxRDY und RxRDY. Diese beiden Signale sind zum Interruptcontroller geführt. Hierdurch wird eine interruptgesteuerte Ein-/Ausgabe, z.B. im Hintergrundbetrieb, ermöglicht.

Anzumerken ist, daß alle MPU bzw. PC-internen Bussignale ohne Einfluß auf den USART sind, solange der CS-Eingang inaktiv ist, d.h. solange er nicht durch ein Programm über den Z 80-Prozessor adressiert wurde.

Die Funktion des 8251A wird durch Software festgelegt. Dies erfolgt durch die Übergabe von Steuerworten (Modus-, Kommando- und ggf. Syncl- und Sync2- Wort), die in Registern des USART gespeichert werden. Diese Register legen den Betrieb des Bausteins fest, bis sie durch neue Instruktionen verändert werden. Der Prozessor kann jederzeit den Status des Bausteins durch Einlesen eines der Statusworte abfragen.

# Programmierung des USART

Um nach dem Empfang eines Reset-Pulses (z.B. nach dem Einschalten) die gewünschten Funktionen wahrnehmen zu können, muß der USART Baustein zunächst durch die Übergabe von 2 (asynchroner Datentransfer), 3 oder 4 (synchroner Datentransfer mit 1 oder 2 Sync-Zeichen) Steuerworten initialisiert werden. Die beiden immer zu übertragenden Worte sind das Moduswort und das Kommandowort. Bei der Programmierung des Bausteins wird nur eine Adresse verwendet; die Programmierung muß daher in einer definierten Reihenfolge vonstatten gehen, um zu gewährleisten, daß die Steuerinformationen in dem richtigen Steuerregister abgelegt werden. Die Adresse des Steuerregisters lautet im PC: 41 (Sedezimal).

Der Ablauf einer Initialisierung des USART ist in den nachfolgenden Flußdiagrammen dargestellt. Die Reihenfolge der Steuerinformationen ist bindend.

# 1. Asynchronbetrieb:





Aus den folgenden Tabellen ist der Aufbau der erforderlichen Steuerworte zu entnehmen. Mit dem Moduswort wird die Betriebsart und auch das Datenformat festgelegt.

|    |     |     |      |      |       |     |     | •   |     |       |         |      |      |        |     |
|----|-----|-----|------|------|-------|-----|-----|-----|-----|-------|---------|------|------|--------|-----|
| D7 | D6  | D5  | D4   | D3   | D2    | D1  | Đ   | 0   |     |       |         |      |      |        |     |
| 52 | Sl  | EP  | PE   | L2   | L1    | B2  | Е   | 31  |     |       |         |      |      |        |     |
| •  | •   |     |      | •    |       | •   |     |     | Be  | trieb | sart    |      | Free | qu.Tei | ler |
|    |     |     | •    |      | •     | 0   | 0   |     | Syı | nc.Be | trieb   |      |      | 1      |     |
| •  |     |     | •    |      | •     | 0   | 1   |     | As  | ync.  | 4.5     |      | 9    | 1      |     |
|    |     |     | •    | •    | •     | 1   | 0   |     | As  | ync.  | 11      |      |      | 16     |     |
|    |     |     | •    | •    | •     | 1   | 1   |     | As  | ync.  | 79      |      |      | 64     |     |
|    | •   | •   |      | •    | •     |     |     |     |     |       |         |      |      |        |     |
| •  | •   | •   |      |      | •     | Ze: | ich | en. | län | ge    |         |      |      |        |     |
|    |     |     | •    | 0    | 0     | 5   | Вi  | .t  |     |       |         |      |      |        |     |
|    | •   |     |      | 0    | 1     | 6   | Вi  | t   |     |       |         |      |      |        |     |
|    |     | •   | •    | 1    | 0     | 7   | Bi  | t   |     |       |         |      |      |        |     |
| •  | •   |     | •    | 1    | 1     | 8   | Вi  | t   |     |       |         |      |      |        |     |
| •  |     |     | •    |      |       |     |     |     |     |       |         |      |      |        |     |
| •  |     |     | •    | Pa   | rität | sbi | t   |     |     |       |         |      |      |        |     |
| •  |     |     | 0    | ohi  | ne    |     |     |     |     |       |         |      |      |        |     |
| •  |     |     | 1    | mii  | t e   |     |     |     |     |       |         |      |      |        |     |
| •  |     |     |      |      |       |     |     |     |     |       |         |      |      |        |     |
|    |     |     | Par  | itä  | tsart |     |     |     |     |       |         |      |      |        |     |
|    |     | 0   | unc  | jera | de    |     |     |     |     |       |         |      |      |        |     |
|    |     | 1   | _    | ade  |       |     |     |     |     |       |         |      |      |        |     |
|    |     |     |      |      |       |     |     |     | •   |       |         |      |      |        |     |
|    |     |     |      |      |       |     |     |     |     |       |         |      |      |        |     |
|    |     |     |      |      |       |     |     | = . | •   | •     |         |      |      |        |     |
|    |     | Asy | nc.E | etr: | ieb   |     |     |     |     | . 5   | Sync.Be | etri | .eb  |        |     |
|    |     |     |      |      | pbits | ;   |     |     |     | . 7   | eicher  | nsyc | hron | isatio | n   |
| 0  | 0   |     |      |      | ssig  |     |     |     |     | 0 i   | intern  |      |      |        |     |
| D  | 1   | 1   | Bit  |      |       |     |     |     |     | 1 6   | extern  | (ni  | cht  | PC)    |     |
| 1  | 0   | 1.5 | Bit  |      |       |     |     |     |     |       |         |      |      |        |     |
| 1  | 1   | 2   | Bit  |      |       |     |     |     |     | SYNO  | -Zeich  | nen  |      |        |     |
| _  | 0.0 |     |      |      |       |     |     |     | 0   | Dopp  | oel Sy  | nc.  | Zeic | hen    |     |
|    |     |     |      |      |       |     |     |     | 1   | Einf  |         | 19   | **   |        |     |
|    |     |     |      |      |       |     |     |     |     |       |         |      |      |        |     |

| EH | IR   | RTS | ER   | SBRK   | R×EN   | DTR   | TxEN    |                         |
|----|------|-----|------|--------|--------|-------|---------|-------------------------|
| •  | •    | •   | 7    |        | •      | •     | •       |                         |
| •  | •    | •   | •    | •      |        |       | •       | Sender freigeben        |
| •  |      | •   | •    | •      |        | •     | 0       | nein                    |
|    | •    | •   | •    |        |        | •     | 1       | ja                      |
|    |      |     | •    | •      |        | •     |         |                         |
|    |      | •   | •    |        | •      | •     | Ausg    | ang DTR setzen          |
| •  | •    | •   | •    |        | •      | 0     | H-Pe    | gel                     |
| •  | •    | •   | •    | •      | •      | 1     | L-Pe    | gel                     |
| •  | •    | •   |      | •      | •      |       |         |                         |
|    | •    | •   | •    | •      | •      | Empf  | änger   | freigeben               |
| •  | •    | •   | •    | •      | 0      | nein  | 151     |                         |
| •  | •    | •   | •    | •      | 1      | ja    |         |                         |
| •  | •    | •   | •    | •      |        |       |         |                         |
| •  | •    | •   | •    | •      | Bre    | ak-Zu | stand   | (L-Pegel) senden        |
| •  | •    | •   | •    | 0      | nei    | n     |         |                         |
| •  | •    | •   | •    | 1      | ja     |       |         |                         |
| •  | •    | •   | •    |        |        |       |         |                         |
| •  | •    | •   | •    | Fehle  | rbits  | (FE,  | OE, PE  | ) Stat.Reg zurücksetzen |
| •  | •    | •   | 0    | nein   |        |       |         |                         |
| •  | •    | •   | 1    | ja     |        |       |         |                         |
| •  | •    | •   |      |        |        |       |         |                         |
| ٠  | •    | •   |      | gang R | TS set | zen   |         |                         |
| ٠  | •    | 0   | H-P  | egel   |        |       |         |                         |
| •  | •    | 1   | L-P  | egel   |        |       |         | 30.7                    |
| •  | •    |     |      |        |        |       |         |                         |
| •  | •    | näc | hste | s Steu | erwort | ist   | Modus_l | wort -                  |
| •  | 0    | nei | n    |        |        |       |         |                         |
| •  | 1    | ja  |      |        |        |       |         |                         |
| •  |      |     |      |        |        |       |         |                         |
| •  |      |     | us s | tarten | ? (nu  | r im  | Synchr  | onbetrieb)              |
| 0  | neir | 1   |      |        |        |       |         |                         |
| 1  | ja   |     |      |        |        |       |         |                         |
|    |      |     |      |        |        |       |         |                         |

Das Statuswort erlaubt dem Prozessor das Erkennen einer Reihe von Zuständen der peripherieorientierten Steuerpins und das Auftreten von Übertragungsfehlern auf dem seriellen Übertragungsweg. Der Inhalt des Statuswortes wird während des Auslesens vom Prozessor nicht geändert.

```
D2
                          D1
                                  DO
              PE TXEMTY RXEMPTY TXRDY
                                      Sende Register frei
                                      nein
                                      ja
                              Zeichen im Empfangsregister
                              nein
                              ja
                        beide Senderegister leer
                        nein
                        ja
                  Paritätsfehler beim Empfang
                  nein
              0
                  ja
              Uberlauffehler beim Empfang
              nein
              ja
         Rahmen nicht erkannt
         nein
         ja
     Sync- Zeichen oder Break erkannt
     nein
     ja
Pegel am Eingang DSR
H-Pegel
L-Pegel
```

Über den Baud-Rate Generator können dem USART Baustein je nach Stellung des Rangiersteckers (siehe Abb. 2.2 u. 5.5) verschiedene Frequenzen angeboten werden. Diese Frequenzen entsprechen jeweils einer bestimmten Baudrate (denn per Programm wurde schon der Teilungsfaktor 16 für den USART eingestellt).

| Rangi | erstecker | Frequenz | Baudrate  |
|-------|-----------|----------|-----------|
|       | 1         | 153600 H | z 9600 Bd |
| ×     | 2         | 76800 H  | z 4800 Bd |
|       | 3         | 38400 H  | z 2400 Bd |
|       | 4         | 19200 H  | z 1200 Bd |
|       | 5         | 9600 H   | z 600 Bd  |
|       | 6         | 4800 H   | z 300 Bd  |
|       |           |          |           |

x = Werkseitige Einstellung

Würde der programmierbare Teilungsfaktor 64 gewählt, erstreckte sich der durch den Rangierstecker einstellbare Bereich von 75 bis 2400 Bd; wird der Faktor 1 programmiert, ist ein externer Taktgenerator erforderlich. Hierbei wird im Synchronbetrieb oder im ISO-Synchronbetrieb übertragen. Ist der ISO-Synchronbetrieb gewählt worden, muß ein Baudrategenerator an beide Datenendgeräte angeschloßen werden. Die Verbindung des externen Taktgenerators mit dem PC erfolgt an den Anschlußpins 15 (TxC) und 17 (RxC) des V24 Steckers. Außerdem müssen auf der Hauptplatine des PC zwei Lötbrücken geändert werden. Die Position der Lötbrücken auf der Hauptplatine ist aus Abb. 2.2 ersichtlich, die jeweiligen Verbindungen gehen aus Abb. 5.5 hervor.

Die Schaltung der seriellen Schnittstelle ist in Abb. 5.9 dargestellt. Neben dem USART-Baustein erkennt man die pegelanpassenden IC's der SN 75-Serie. Der Multiplexer des Typs 74 LS 157 wird vom SPORT angesteuert. Er schaltet zwischen Cassettenrecorderbetrieb und serieller Schnittstelle um (siehe auch Kapitel 5.1. und 5.4).



Die Adressen des USART-Bausteins sind im PC: 41 H für Modus-, Kommando- und Statuswort und 40 H für die zu sendenden bzw. zu empfangenden Daten. Der Baustein wird vom Monitorprogramm des PC (Version 2.0/25. Juli 83) wie folgt initialisiert (kein Cassettenrecorderbetrieb, hierzu siehe Kap. 5.4).

| Befehlsadresse (H) | OP-Code  | Mnemonik      | Anmerkung |
|--------------------|----------|---------------|-----------|
| EF34               | 3E FA    | LD A,OFAH     | 1         |
| EF36               | D3 41    | OUT 41H,A     |           |
| EF38               | 3E 37    | LD A,037H     | 2         |
| EF3A               | D3 41    | OUT 41H,A     |           |
| EF3C               | 3A E4 68 | LD A,(SFFO)   | 3         |
| EF3F               | CB 07    | SET 2,A       |           |
| EF41               | DE 10    | OUT (SPORT),A |           |
| EF43               | 32 E4 68 | LD (SFFO),A   |           |

# Anmerkungen:

- Das Moduswort FA wird in des A-Register der MPU geladen und dann an den USART ausgegeben. Das Moduswort bewirkt folgende Einstellungen:
  - 2 Stoppbits je Wort
  - gerade Parität
  - das Paritätsbit wird Übertragen (die MPU hat hierauf keinen Zugriff)
  - 7 Datenbits werden pro Datenwort übertragen
  - Asynchronbetrieb mit einem Teilerverhältnis Taktfrequenz zu Baudrate von 16
- Das Kommandowort 37(H) wird in das A-Register der MPU geladen und dann an den USART ausgegeben. Es bewirkt folgende Einstellungen:

das nächste Steuerwort wird wieder ein Kommandowort sein

der Ausgang RTS wird auf L-Pegel gelegt die Fehlerbits des Statuswortes (PE, OE, FE) werden gelöscht

der Empfänger des USART wird freigegeben

der Ausgang DTR wird auf L-Pegel geschaltet der Sender wird freigegeben

3. Das A-Register wird mit dem SFFO-Byte geladen. Dieses Byte enthält die zuletzt an das die Peripherie steuernde System-Port (SPORT) ausgegebene Information. Dieses Port schaltet z.B. den seriellen Datenstrom vom USART entweder zu den pegelanpassenden IC's der V24 Schnittstelle oder zu dem FSK Modulator der Cassettenschnittstelle (siehe weiter unten). Der nächste Befehl setzt das Bit 2 des A-Registers und gibt das Byte an das System Port aus und speichert diesen neuen Status auch im SFFO-Byte. Dieses gesetzte Bit 2 bewirkt, das serieller Datenstrom nun über die V24 Schnittstelle abgewickelt wird.

Belegung des 25-poligen Steckers:

| Pi       | <u>n Si</u> | gnal |           | Bedeutung                                         |
|----------|-------------|------|-----------|---------------------------------------------------|
|          | RS 23       | 2C   | V-24      |                                                   |
| 1        |             | NC   |           |                                                   |
| out 2    | TxD         |      | Dl        | Transmit Data, Sendedaten                         |
| PN 3     | R×D         |      | D2        | Receive Data, Empfangsdaten                       |
| DUT 4    | RTS         |      | <b>S2</b> | Request to Send, Sendeteil ein                    |
| /N 5     |             |      | M2        | Clear to Send, Sendebereitschaft                  |
| 1W 6     | DSR         |      | Ml        | Data Set Ready, Emfangsbereitschaft               |
| ground 7 | GND         |      | E2        | Signal Ground, Betriebserde                       |
| 9 -      | 14          | NC   |           |                                                   |
| 15       | TxC         |      | 12        | Transmit Clock, Sendetakt                         |
| 16       |             | NC   |           |                                                   |
| 17       | RxC         |      | T4        | Receiver Clock, Empfangstakt                      |
| 18       |             | NC   |           |                                                   |
| 19       |             | NC   |           |                                                   |
| 041 20   | DTR         |      | 51.2      | Data Terminal Ready, Endgerät be-<br>triebsbereit |

NC = nicht belegt

8 Courier Delect

# 5.4 Cassettenschnittstelle

Der alphatronic-PC besitzt für das Laden und Speichern von Programmen eine Cassettenschnittstelle. Zum Anschluß eines handelsüblichen Recorders befindet sich an der linken Seite des PC, neben der RGB-Buchse, eine 8-polige DIN-Buchse zum Anschluß eine Recorders.

Für einwandfreie Funktion des Basic "CLOAD"-Befehls ist der Anschluß "Ear" (2 Kopfhöhrer) eines Cassettengerätes erforderlich. Das Cassettenrecorderkabel des PC sieht diesen Anschluß schon vor.

Zur Aufzeichnung auf Compactcassetten wird der vom USART Baustein 8251A (siehe Kapitel "Serielle Schnittstellen") parallel/seriell gewandelte Datenstrom zu einem FSK-Modulator geleitet (FSK = Frequency Shift Keying). Bei diesem Verfahren wird jedem der beiden logischen Pegel eine Frequenz zuge-ordnet.

Der USART ist durch die Programmierung auf ein Teilungsverhältnis f/Bd-Rate von 16 eingestellt. Der Rangiersteckverbinder ist hier ohne Einfluß, als Sende- bzw. Empfangsfrequenz wird dem USART eine Frequenz von 19200 Hz angeboten. Somit ist eine Übertragungsrate von 1200 Bd eingestellt.

Durch die Programmierung des USART auf den Teilungsfaktor 64 kann die Aufzeichnungsgeschwindigkeit auf 300 Bd reduziert werden.

Die vom PC aufgezeichneten Frequenzen sind 2400 Hz (H-Pegel  $\stackrel{\circ}{=}$  logisch 1) und 1200 Hz (L-Pegel  $\stackrel{\circ}{=}$  logisch 0). Diese Frequenzen sind nicht frei wählbar (im Gegensatz zur Baudrate der seriellen Schnittstelle).



# Cassettenrecorder - Schnittstelle



Abb. 5.10

Die FSK-Modulation (siehe Abb. 5.10) übernimmt ein D-Flip flop (SN 74 LS 74, Texas Instruments) in Zusammenarbeit mit zwei NAND-Gattern und ausgangsseitigem Widerstands-Kondensator-(RC) Netzwerk zur Pulsverrundung und Pegelanpassung. Der Ausgangspegel beträgt je nach Einstellung der Steckbrücke (Abb. 2.3) ca. 700 mV oder 25 mV (siehe Handbuch des PC).

Der Schaltungsaufwand für das Lesen der auf einer Cassette gespeicherten Information ist größer (Abb. 5.10, 5.11). Das auf einer Cassette gespeicherte frequenzcodierte Signal wird einer Begrenzerstufe (bestehend aus Dioden und Widerständen) zugeführt. Das so auf maximal 1,4 Vss begrenzte Signal wird von einem Komparator-IC (LM 311) den Logikpegeln angepaßt. Mit dem nachgeschalteten Differenzierer werden aus den fallenden Flanken des FSK-Signals positive Nadeln erzeugt. Diese werden zur weiteren Verarbeitung dem Demodulator (Abb. 5.12) zugeführt.



Aus dem nachfolgenden Zeitablaufdiagramm ist die Wirkung der Schaltung, die das empfangene Signal dekodiert, zu ersehen. Die Messpunkte sind in Abbildung 5.10 und 5.11 zu finden.

FSK-Demodulator, CC-Schnittstelle



Die Initialisierung des Cassettenschreib/-lesebetriebes erfolgt <u>nicht</u> von der Initialisierungsroutine des PC. Die Umschaltung des seriellen I/O Betriebes auf Cassettenbetrieb muß entweder vom Basic-Betriebssystem oder vom Benutzer selbst erfolgen.

Das Basic nutzt folgende Routine:

| Befehls Adresse | OP-Code | Mnemonik    |
|-----------------|---------|-------------|
| EB4A            | 3E FE   | LD A,OFEH   |
| EB4C            | D3 41   | OUT 41H,A   |
| EB4E            | 3E 37   | LD A,37H    |
| EB50            | D3 41   | OUT 41H,A   |
| EB52            | 3A E468 | LD A,(SFFO) |
| EB55            | CB 97   | RES 2,A     |
| EB57            | C3 EF41 | JMP PTSET   |
|                 |         |             |

Im Unterschied zur Initialisierung des seriellen Bausteins zum V.24 Modus ist hier lediglich die Zeichenlänge verändert. Sie beträgt hier 8 Bit. Alle anderen Eigenschaften des Datentransfers sind identisch. Weiterhin setzt diese Routine das 2-er Bit des SPORT-Bytes zurück. Dann wird, wie in Kapitel 5.3 beschrieben, zur Ausgabe dieses Byte gesprungen. Pin-Belegung der Kassettenrecorder-Schnittstelle

Ein-/Ausgabe-Signale

Pin-Belegung, Abb. 5.13



(von der Lötseite aus gesehen)

| Nr. | Signal | Bedeutung             | Richtung |
|-----|--------|-----------------------|----------|
| 1   | REC    | verbunden mit 4       |          |
| 2   | GND    | Signal Ground (Masse) | Ausgang  |
| 3   | MON    | verbunden mit 5       |          |
| 4   | REC    | Schreibsignal         | Ausgang  |
|     |        | TTL-Pegel             |          |
| 5   | MON    | Lesesignal            | Eingang  |
|     |        | TTL-Pegel             |          |
| 6   | REMI   | Fernsteuerung         | Ausgang  |
| 7   | REM2   | Fernsteuerung         | Ausgang  |
| 8   | GND    | Signal Ground         |          |
|     |        |                       |          |

# 5.5 Parallelschnittstelle

Der alphatronic-PC verfügt über eine 8 Bit-breite Parallelschnittstelle zur Ausgabe von Daten.

Der Datentransfer erfolgt in einem "Handshake"-Verfahren. Die Pegel und Schaltzeiten sind Centronics-kompatibel. Hierbei wird der Datensenke (-Empfänger, z.B. ein Drucker) von der Datenquelle (in diesem Fall der PC) durch einen Puls auf der "Strobe"-Leitung mitgeteilt, daß ein neues 8 Bit-Wort am parallelen Ausgang bereit steht. Sobald die Senke das Wort übernommen hat, teilt sie dies über die "Acknowledge"-Leitung der Quelle mit. Kann die Senke keine Zeichen übernehmen, wird das der Quelle über die "Busy"-Leitung mitgeteilt. Ferner kann das periphere Gerät über die Resetleitung zurückgesetzt werden.







\*Der PC ändert die Daten erst nach ACK=0

# Centronics-Schnittstelle



Die Ausgabe der 8 Bit-Datenworte erfolgt über das IC 74 LS 374. Ein im A-Register der MPU stehendes Datenbyte wird durch den Befehl OUT 30H an das Register ausgegeben. Das Senden bzw. Empfangen der Steuersignale STROBE, ACK, BUSY, und RESET erfolgt über einen Baustein des Typs 74 LS 367. Das Einlesen der Steuersignale ACK und BUSY erfolgt über den Befehl IN 30H. Der Inhalt des Steuerwortes sieht wie folgt aus:

Bit 2 Centronics ACK

1 = aktiv, Datenwort wurde übernommen

0 = inaktiv

Bit 3 Centronics BUSY

1 = Peripheriegerät ist beschäftigt und kann zur
Zeit keine Daten übernehmen

0 = Datenübernahme möglich

Die Ausgabe des Strobe- und Resetpulses erfolgt über OUT 20H. Als Ausgaberegister dienen 2 Bausteine des Typs 74 LS 175 (je 4 D-Flip Flops).

Bit 1 Centronics RESET

1 = Rücksetzen

0 = nicht Rücksetzen

Bit 2 Centronics STROBE

1 = Strobe aktiv

O = Strobe inaktiv

Es ist zu empfehlen, diese Bits nur mit den Bitmanipulationsbefehlen der Z 80 MPU (BIT, RES, SET) abzufragen bzw. zu ändern.

Der Strobepuls kann zum Beispiel durch folgende Sequenz erzeugt werden:

3A E469 LD A,(SFF1)
CB D7 SET 2,A
D3 20 OUT 20H,A
00 NOP

; die Anzahl der NOP ; (no operation) Befehle ; richtet sich nach der ; gewünschten Pulsdauer, ; für einen 4,5 us Puls ist ; kein NOP-Befehl erforder-; lich. Pro NOP-Befehl wird

; die Pulsdauer um 1 us ver-

; längert (Z 80 A,4 MHz)

00 NOP

CB 97 RES 2,A

D3 20 OUT 20H, A

Von den 6 verbleibenden Bits des Statusport 2, Adresse 20H werden 5 für andere Aufgaben genutzt:

Bit 0 CRISI, CRI-Controller RESET 1 = CRT-Controller zurücksetzen

0 = nicht zurücksetzen

Bit 3 MONINH, Umschaltung zwischen Monitor-ROM und Video-RAM

1 = Video-RAM angewählt

0 = Monitor-ROM angewählt

Bit 4 GLED

1 = Graphik-LED der Tastatur einschalten

0 = ausschalten

Bit 5 SLED

1 = Shift-Locked-LED ein

0 = aus

Monitor ROM/Video RAM Adressbereich

l = Freigabe der 4 kByte Speicher mit den höheren Adressen

O = Freigabe der niederen Adressen

Eine Kopie des am Ausgabeport 20H gegebenen Datenwortes befindet sich in dem SFF1-Byte, Adresse E469H. Während der Initialisierung wird 00 in SFFl geladen.

Die Zählweise der Steckerpins des Verbinders ist aus Abbildung 5.16 ersichtlich.







Die Signalbelegung ist aus der nachstehenden Tabelle zu entnehmen.

# Ein-/Ausgabe-Signale

| Nr.      | Signal           | Bedeutung                                                                                                                                           | Richtung                      |
|----------|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|
| 1        | STB              | Freigabesignal für das<br>Senden der Daten zum<br>Drucker; negative Logik,                                                                          | Ausgang<br>Ausgang<br>Ausgang |
|          | DATA .           | TTL-Pegel                                                                                                                                           | Ausgang                       |
| 3<br>5   | DATA-1           |                                                                                                                                                     | Ausgang                       |
| 7        | DATA-2           | Die Signale Data-1 bis                                                                                                                              | Ausgang                       |
| 9        | DATA-3           | DATA-8 enthalten Informa-                                                                                                                           | Ausgang                       |
| -11      | DATA-4           | tionen über das jeweils                                                                                                                             | Ausgang                       |
| 13       | DATA-5           | 1. bis 8. Bit der parallel                                                                                                                          | Ausgang                       |
| 15       | DATA-6<br>DATA-7 | zu übertragenden Daten.:                                                                                                                            | Ausgang                       |
| 17       | DATA-8           | positive Logik, TTL-Pegel                                                                                                                           | Ausgang                       |
| 19       | ACK              | Dan Computer askille                                                                                                                                | _ 12                          |
| 21       |                  | Der Computer erhält das<br>Quittungssignal vom Drucker:<br>dieser hat Daten empfangen<br>und ist erneut empfangsbereit<br>Negative Logik, TTL-Pegel | Eingang                       |
|          | BSY              | Signal an PC vom Drucker<br>Er ist empfangsbereit, sein<br>Puffer ist leer.<br>Negative Logik, TT1-Level                                            | Eingang                       |
| 23       | NC               | Nicht belegt                                                                                                                                        |                               |
| 25       | NC               | Nicht belegt                                                                                                                                        |                               |
| 27       | GND              | Masse                                                                                                                                               |                               |
| 29       | NC               | Nicht belegt                                                                                                                                        |                               |
| 31       | GND              | Masse                                                                                                                                               |                               |
| 33       | NC               | Nicht belegt                                                                                                                                        |                               |
| 2        | GND              | Masse                                                                                                                                               |                               |
| 4        | GND              | Masse                                                                                                                                               |                               |
| 6        | GND              | Masse                                                                                                                                               |                               |
| 8        | GND              | Masse *                                                                                                                                             |                               |
| 10       | GND              | Masse                                                                                                                                               |                               |
| 12       | GND              | Masse                                                                                                                                               |                               |
| 14       | GND .            | Masse                                                                                                                                               |                               |
| 16<br>18 | GND              | Masse                                                                                                                                               |                               |
| 20       | GND              | Masse                                                                                                                                               |                               |
| 22       | GND              | Masse                                                                                                                                               |                               |
| 24       | GND              | Masse                                                                                                                                               |                               |
| 26       | GND              | Masse                                                                                                                                               |                               |
| 20       | Reset            | Der PC leitet das System-<br>RESET-Signal an den Drucker<br>weiter. Negative Logik,<br>TTL-Pegel                                                    |                               |
| 28       | NC               | Nicht belegt                                                                                                                                        | Ausgang                       |
| 30       | GND .            | Masse                                                                                                                                               |                               |
| 32       | NC "             | Nicht belegt                                                                                                                                        |                               |
| 34       | NC               | Nicht belegt                                                                                                                                        |                               |

# 5.6 Systembusschnittstelle

Die Systembusschnittstelle schafft die Möglichkeit, komplexe periphere Geräte (Floppydisc-Laufwerke, Expansion-Box usw.) an den alphatronic-PC anzuschließen. Über einen bidirektionalen Bustreiber IC ist der 8 bit Datenbus herausgeführt; der PC kann als Datenquelle und als Datensenke arbeiten. Außerdem ist der 16 bit Adressbus über eine Treiberstufe auf den Systembussteckverbinder gelegt. Die Steuerung der Schnittstelle erfolgt mit Hilfe des DMA (Direct Memory Access) Controller-Bausteins Typ 8257 und den beiden Unterbrechungsanforderungsleitungen EXINT1 und EXINT2 zum Interruptcontroller Typ 8259.



# a) DMA Controller Typ 8257

Der hier eingesetzte DMA Controller ist ein 4 Kanal Steuerungsbaustein für direkten Speicherzugriff. Er vereinfacht Datenübertragungen mit hoher Geschwindigkeit. Die Hauptfunktionen des Bausteins bestehen darin, aufgrund einer von einem peripheren Gerät stammenden Anforderung, aufeinanderfolgende Speicherwortadressen zu erzeugen und auf den Adressbus zu legen. Dies ermöglicht dem angeschlossenen Gerät, Daten direkt in den Speicher zu schreiben bzw. Daten zu lesen. Währenddessen ist die MPU Z80 inaktiv. Die Systembussteuerung wird vom DMA Controller übernommen, nachdem die MPU das Anforderungssignal HRQ (Hold Request) des DMA Controllers quittiert hat (Hold). Weiter besitzt der Controller-Baustein eine Prioritätslogik. Diese Logik ermittelt die Priorität (= Plätze in einer Reihenfolge) der DMA Anforderung der externen Geräte und richtet ein gemeinsames Anforderungssignal an die MPU. Außerdem zählt er die DMA-Zyklen für jeden DMA-Kanal und gibt ein Steuersignal (TC) aus, das dem angeschlossenen Gerät mitteilt, daß die programmierte maximale Anzahl der DMA Zyklen erreicht ist.

Trifft eine DMA Anforderung ein, führt der Baustein folgendes aus:

- 1. Übernahme der Systembussteuerung
- 2. Ausgabe einer Quittung an das anfordernde Gerät
- 3. Setzen der niederwertigen 8 Adressleitungen AO A7 und über den Datenbus Laden des Adresslatch IC 25 (SN 74 LS373) mit den höherwertigen 8 Adressleitungen, sowie Freischalten des Latch-IC's.
- Erzeugung der Schreib-/Lesesignale für den Speicher und das externe Gerät.

Der DMA Controller Baustein wiederholt die Transfersequenz, solange die Anforderung vom peripheren Gerät aufrecht erhalten wird. Dadurch kann ein Datenblock von bzw. zu einem Gerät in einem Zuge übertragen werden ("Burst").

# Der Baustein bietet 3 Betriebsarten:

- Lesezyklus, Daten werden vom Speicher zum peripheren Gerät übertragen.
- Schreibzyklus, Daten werden von der Peripherie in den Speicher transferiert.
- Prüfzyklus, hier verhält sich der Baustein wie vor, erzeugt jedoch keine Speicherschreib-/lesesignale, d. h. eine tatsächliche Datenübertragung findet nicht statt.



Blockschaltbild DMA - Steuerbaustein

Abb. 5.18

Wie im Blockschaltbild dargestellt, enthält der DMA-Controller 8257 vier voneinander unabhängige Kanäle, die Kanäle O bis 3. Der Kanal 3 ist im PC nicht vorgesehen und ohne Hardwareänderungen nicht nutzbar. Jeder DMA-Kanal besitzt 2 16-bit Register: ein Adressregister und ein Blocklängenregister. Das Adressregister wird mit der ersten aufzurufenden Adresse geladen. Die Zahl, die in die niederwertigen 14 bit des Blocklängenregisters geschrieben wird, gibt die Anzahl der DMA-Zyklen minus 1 an, nach denen die Blockendemeldung auf der Leitung TC zum peripheren Gerät gesendet wird. Die beiden höchstwertigen Bits geben die gewünschte Betriebsart des Kanals an:

| Bit 15 | Bit 14 | Betriebsart     |
|--------|--------|-----------------|
| 0      | 0      | DMA Prüfzyklus  |
| 0      | 1      | " Schreibzyklus |
| 1      | 0      | " Lesezyklus    |
| 1      | 1      | nicht zulässig  |

Beide Register müssen vor der Freigabe des Kanals geladen sein. Jeder Kanal besitzt einen Anforderungseingang DRQ und einen Quittungsausgang DACK. DRQD hat die höchste und DRQ3 die niedrigste Priorität (Ausnahme: Betriebsart rotierende Priorität). Eine Anforderung wird durch einen H-Pegel (logisch 1), der bis zum Erscheinen des Quittungssignals angelegt wird, erzeugt. Ein L-Pegel auf der Quittungsleitung DACK zeigt dem externen Gerät, daß es für einen DMA Zyklus ausgewählt ist. Nach jedem übertragenen Byte wird vom Controller ein H-Pegel auf die Leitung gelegt.

Durch Setzen von Bits im Betriebsartenregister können die DMA-Kanäle freigegeben werden, sowie Betriebsvarianten ausgewählt werden:

#### Bit 7 6 5 4 3 2 1 0

. . . . . . . .

. . . . . . DMA Kanal O freigeben

. . . . DMA Kanal 1 freigeben

. . . DMA Kanal 2 freigeben

. . . DMA Kanal 3 freigeben

. . rotierende Priorität freigeben

verlängertes Schreiben freigeben

• TC Stop freigeben

Automatisches Laden freigeben

Nach dem Einschalten oder Rücksetzen des PC sind alle Kanäle und Betriebsvarianten gesperrt. Nach dem Laden der Blocklängenregister mit gültigen Daten können die gewünschten Kanäle freigegeben werden. Die 4 Betriebsvarianten sind anschließend beschrieben:

#### Rotierende Priorität

In dieser Betriebsart wird die Priorität eines Kanals einer zyklischen Vertauschung unterworfen. Nach jedem DMA-Zyklus ändert sich die Priorität aller 4 Kanäle. Der zuletzt bediente Kanal erhält dabei die niedrigste Priorität, die Prioritäten der anderen Kanäle erhöhen sich. Diese Betriebsart verhindert, daß ein Kanal den DMA-Betrieb für sich monopolisiert, also andere Kanäle nicht zum Zuge kommen können. Ist dieses Bit nicht gesetzt (O in Bit 4 des Registers geschrieben), gelten folgende feste Prioritäten: Kanal O (höchste Priorität), 1, 2, 3 (niedrigste Priorität).

#### Verlängertes Schreiben

Diese Option kann beim PC ohne Hardwareänderungen nicht genutzt werden.

#### TC Stop Bit

Ist dieses Bit gesetzt, wird der betreffende Kanal gesperrt nachdem der Blockendeausgang (am Schnittstellenverbinder IC) aktiv wurde. Das Freigabebit dieses Kanals muß neu programmiert werden, bevor ein weiterer DMA über diesen Kanal stattfinden kann. Ist das IC Stop Bit nicht gesetzt, hat das Blockendesignal keinen Einfluß auf das Freigabebit des Kanals.

#### Automatisches Laden

Ist dieses Bit gesetzt, wird der Kanal 2 für Blockwiederholungsoperationen eingesetzt. Die MPU muß zwischen Blökken nicht unmittelbar eingreifen. Das Adressregister und
das Blocklängenregister des Kanals 2 wird wie auch sonst
für den ersten Block initialisiert; die Register des
Kanals 3 werden zur Speicherung der Parameter für den
2ten Datenblock benutzt. Nach Aussendung des ersten Datenblocks bis zur Übernahme der in den Registern des Kanals
3 abgelegten Parameter in den Kanal 2, nach der nächsten
Anforderung ist das "Update"-Bit des Statuswortes gesetzt. Dies ermöglicht der MPU zwischen Datenblocktransferoperationen die gezielte Übergabe von Blockparametern
für den 3., 4. usw. Block.

Das Statusregister registriert, welche Kanäle die Blockendebedingung erreicht haben und enthält ebenso den Zustand des oben erläuterten "Update"-Bits. Die Blockende-Bits werden gesetzt, wenn der betreffende Kanal seine Blockendemeldung über die IC-Leitung erhält. Rückgesetzt werden diese Bits von einer Statusregister-Leseoperation oder einem RESET (Rücksetzen) des PC.



#### Adressierung der 8257-Register

Da die jedem Kanal zugeordneten Adress- und Blocklängenregister eine Länge von 16 Bit haben, werden zum Laden bzw.
Lesen eines ganzen Registers 2 Befehlszyklen benötigt.
Der Baustein 8257 enthält ein F/L (first/last = erstes/
letztes) Flipflop, das nach einer Schreib- oder Leseoperation seinen Zustand wechselt. Dieses Flipflop wählt das
höher- oder niederwertige Byte des adressierten 16 Bit-Registers aus. Dieses Flipflop wird von einem Reset oder
dem Beschreiben des Betriebsartenregisters zurückgesetzt.
Auf die Kanalregister sollte also grundsätzlich paarweise
zugegriffen werden, um eine definierte Ausgangssituation
des F/L Flipflop zu schaffen.

| sedezima | ale A | dresse F/  | L |        |      |               |       |
|----------|-------|------------|---|--------|------|---------------|-------|
| 60       |       | 0          |   | Kanal  | 0,   | DMA Adresse   | (LSB) |
| 60       |       | 1          |   |        |      | 11            | (MSB) |
| 61       |       | 0          |   | Kanal  | 0,   | Blocklänge    | (LSB) |
| 61       |       | 1          |   |        |      | 11            | (MSB) |
| 62       |       | 0          |   | Kanal  | ı,   | DMA Adresse   | (LSB) |
| 62       |       | 1          |   |        |      | 11            | (MSB) |
| 63       |       | 0          |   | Kanal  | 1,   | Blocklänge    | (LSB) |
| 63       |       | 1          |   |        |      | 11            | (MSB) |
| 64       |       | 0          |   | Kanal  | 2,   | DMA Adresse   | (LSB) |
| 64       |       | 1          |   |        |      | **            | (MSB) |
| 65       |       | 0          |   | Kanal  | 2,   | Blocklänge    | (LSB) |
| 65       |       | 1          |   |        |      | н             | (MSB) |
| 66       |       | 0          |   | Kanal  | 3,   | DMA Adresse   | (LSB) |
| 66       |       | 1          |   |        |      | **            | (MSB) |
| 67       |       | 0          |   | Kanal  | 3,   | Blocklänge    | (LSB) |
| 67       |       | 1          |   |        |      | **            | (MSB) |
| 68       | _     | schreiben) | 0 | Betrie | ebsa | ertenregister | •     |
| 68       | (nur  | lesen)     | 0 | Status | rec  | gister        |       |

#### Anmerkung:

Die Adressen 66 und 67 (sedezimal) sind beim PC nur in Verbindung mit dem Modus "Automatisches Laden" zu programmieren, da die Anforderungs- und Quittungsleitungen des Kanals 3 nicht benutzt werden.

b) Interrupt-Controller, PIC (programmierbarer Unterbrechungs Steuerbaustein), Typ 8259.

Der alphatronic-PC ist mit einem Interruptcontroller des Typs 8259 augestattet. Die zu dem PC gehörende Standardsoftware (das eingebaute ROM Basic 5.11, das Disc-Basic 5.26, das CP/M Betriebssystem) nutzt keine Unterbrechungsbearbeitung (von einem Reset-Signal, das eine besondere Form der Unterbrechungsanforderung darstellt, abgesehen).

Unterbrechungsanforderung meint folgendes:

Ein peripheres Gerät meldet mit einem asynchronen (in Bezug auf die Programmbearbeitung des PC) Signal, daß es Service durch die MPU Z80A wünscht. Sind zuvor von dem zur Zeit bearbeiteten Programm Unterbrechungen zugelassen, (Befehl: EI = Enable Interrupts, Unterbrechungen freigeben), wird nach Beendigung des momentan ausgeführten Befehls die Programmausführung abgebrochen und eine Serviceroutine abgearbeitet (in Abhängigkeit vom zuvor gewählten Modus). Nach Erledigung des Service (diese Programme enden mit einem der Befehle RETI oder RETN) nimmt die MPU die Bearbeitung des zuvor abgebrochenen Programmes wieder auf.



Der Steuerbaustein 8259 verwaltet acht Unterbrechungsebenen bzw. Anforderungen verschiedener Priorität. Es stehen dem Programmierer verschiedene Prioritätsarten zur Verfügung. Die anfordernden Geräte können an die Leitungen IRO bis IR7 angeschlossen werden. Im PC ist die Belegung wie folgt:

- IRO 24 msec Timer \*1
  IR1 RxRDY des Steuerbausteins der seriellen \*2
  Schnittstelle
  IR2 TxRDY wie vor \*2
  IR3 EXTINT2 von der Systembusschnittstelle \*3
  IR4 EXTINT1 " " \*3
  IR5 nicht benutzt
  IR6 nicht benutzt
  IR7 VINT (vom Videointerface)
- \*l ermöglicht z.B. die Programmierung einer Software-Uhr
- \*2 " z.B. ein Hintergrundprogramm zur Ausgabe von Daten an einen Drucker
- \*3 kann z.B. von einer externen Graphikerweiterung genutzt werden.

Der Baustein 8259 muß, bevor er Unterbrechungsanforderungen bearbeiten kann, initialisiert werden (d.h. sein Betriebsmodus muß vom Anwender definiert worden sein). Dies geschieht beim alphatronic-PC durch das Laden von 2 Byte; da nur ein Steuerbaustein im PC vorhanden ist.

Format des ersten Steuerwortes, das unter der Ausgabeadresse 70H angesprochen wird:

# Bit 7 6 5 4 3 2 1 0

70 A7 A6 A5 1 0 ADI 1 0

. . . . . . muß immer O sein
. . . . . . Anzahl der Controller
. . . . . (im PC = 1)

1 > 4 Byte Intervall

. . . muß immer O sein

Bits 5 bis 7 der Speicheradresse, unter der die Unterbrechungsroutine beginnt

\* bei PC's, die mit dem Baustein 8259 A ausgerüstet sind, gilt für Bit 3:

O: eine Unterbrechungsanforderung wird bei Empfang einer 1 (bzw. H-Peqel) ausgelöst

l: eine Unterbrechungsanforderung wird bei Empfang einer steigenden Flanke ausgelöst

Das zweite Steuerwort, Adresse 71H, hat folgendes Format:

#### Bit 7 6 5 4 3 2 1 0 OUT 71 A15 A14 A13 A12 A11 A10 A 9 A 8

BIT 8 bis 15 der Speicheradresse der Interruptserviceroutine (vectored interrupt)

Nach der Initialisierung mit den oben erläuterten Datenworten kann der Baustein Unterbrechungsanforderungen bearbeiten. Werden jedoch zuvor Steuerworte an den Baustein gesandt, kann die Betriebsart modifiziert werden.

Der Inhalt des Steuerwortes 1 (OCW 1 ≜ Operational Comand Word) läßt Unterbrechungsanforderungen von den 8 möglichen verschiedenen peripheren Einheiten zu bzw. sperrt sie:

OUT 71 M7 M6 M5 M4 M3 M2 M1 MO

M = 0 gibt die Unterbrechungsanforderung frei M = 1 sperrt die Anforderungen (maskiert sie)

#### Steuerwort 2:

Mit diesen Bits wird die aktuelle Priorität eines jeden Anschlusses bestimmt.

# D7 6 5 4 3 2 1 0 OUT 70 R SEOI EOI 0 0 L2 L1 L0

Binäre Darstellung der

Lurückzusetzenden

Ebene bzw. der Ebene

die die niedrigste

Priorität erhalten

Soll

Kanal 0 1 2 3 4 5 6 7

Common 0 1 0 1 0 1 0 1

0 0 1 Nichtspezifisches Unterbrechungsende

0 1 1 Spezifisches Unterbrechungsende, der. . . LO + L2 Code bestimmt das Bit,

. . . das im Unterbrechungsbedienungsre-

. . . gister rückgesetzt wird

1 0 1 Automatisches Rotieren bei Unter-

. . brechungsende (Betriebsart : A)

1 1 1 Rotieren bei Unterbrechungsende,

. . Ebene LO + L2 bekommt die neue

. . niedrigste Priorität

1 0 0 Setze Betriebsart A-Flip Flop

0 0 0 Lösche " "

1 1 0 Rotiere Priorität (Betriebsart B)

0 1 0 keine Operation

Steuerwort 3 (OCW 3):

Steuerwort 3 wird ebenfalls über die Ausgabeadresse 70H angesprochen. Der Baustein erkennt an den Bits D3 und D4 des angegebenen Datums ob es sich um OCW 2 oder OCW 3 handelt:

**OUT 70** 

bei nachfolgendem

IN 70 Befehl:

keine Aktion

O Lesen des Unter-

brechungsanforde-

rungsregister \*

1 Lesen des Unter-

brechungsbedienungs-

register \*

Abfragebetrieb (Polling), eine

1 gibt das Lesen des Binärcodes

der höchsten unterbrechungsan-

fordernden Ebene bei dem nächs-

ten IN 70 Befehl frei

Maskenbetriebsart, hierauf wird nicht näher

eingegangen

- Unterbrechungsanforderungen (Interrupts) von den IR-Leitungen werden von 2 hintereinander geschalteten Registern aufgenommen.
- 1) Unterbrechungsanforderungsregister (IRR, Interrupt Request Register): Hier wird die eine Bedienung anfordernde Unterbrechungsebene gespeichert.
- 2) Unterbrechungsbedienungsregister (ISR, Interrupt re Register): Hier wird die gerade bediente Ebene pespeichert.

Für jede Unterbrechungsanforderung ist ein "CALL-Address-Intervall" von 4 bestimmt, das bedeutet, für jeden Vektor (Zeiger) stehen 4 Bytes zur Verfügung. Der Vektor-Adressbereich beginnt bei EFOOH; es werden 8 x 4 = 32 Bytes benötigt.

Im alphatronic-PC wird kein Unterbrechungsvektor verwendet. Falls der Steuerbaustein 8259 verwendet werden soll, muß der Inhalt im Vektoradressbereich den entsprechenden Aufgaben angepaßt werden. Um die Funktion des Bausteins zu überprüfen, kann folgendes Programm benutzt werden (Die Eingabe geschieht hier mit der Monitorroutine "C"):

\* C EF00 3E 20 DB 70 C9

\* C 8000 3E FE D3 71 FB 76

Die Mnemonik hierzu lautet:

ab Adresse EF00:

LD A, 20

IN A. (70)

RET

ab Adresse 8000:

LD A, FE

; Unterbrechungsanforderung O im

OUT 71

; Steuerbaustein freigeben

ΕÏ

: Unterbrechungsanforderung an Z80

freigeben

HALT

: Stoppt die Z80A MPU

#### 5.7 Videoschnittstelle

#### 5.7.1 Allgemeines

Als Anzeigeeinheit für ein- oder ausgegebene Informationen vom oder zum Rechner können beim alphatronic-PC folgende Geräte angeschlossen werden:

- über den HF-Modulator: Schwarz-Weiß oder Farbfernsehgerät (der Anschluß erfolgt an der Buchse "RGB")
- über die Buchse "RCB" ein Farbmonitor oder ein Farbfernsehgerät, das über eine SCART-Buchse verfügt (Spezialkabel erforderlich)
- über die Buchse "BAS" ein Monitor mit einfarbiger Darstellung

Die Buchsen befinden sich an der linken Seite des PC (siehe Abb. 2.2, Seite 13).

#### 5.7.2 Funktion

(vergleiche Blockschaltbild Abb. 2.1, Seite 11).

Ein darzustellendes Zeichen wird im ASCII-Format von der MPU in das Video RAM geschrieben. Die zu jedem Zeichen gehörenden Attribute wie Hintergrundfarbe, Zeichenfarbe, blinkend oder invers werden im Attribut RAM abgespeichert (siehe Tabelle Kap. 5.7.3, Adressen des Video- und Attribut RAM, Seite 102).

Die Weitergabe der Zeichen an den Monitor, sowie die Umwandlung in ein von einem Monitor verarbeitbares Signal und die Erzeugung der für ein stillstehendes Bild erforderlichen Synchronisationssignale übernimmt im alphatronic-PC ein CRI-Controller (CRI = Cathode Ray Tube = Kathodenstrahlröhre). Dieser generiert, von einem Quarzoszillator mit einer Arbeitsfrequenz versorgt, laufend die Adressen des Video RAM und des Attribut RAM. Jeder Inhalt einer Speicheradresse des Video RAM wird einem Zeichengenerator zugeführt. Dieses ist



Beispiel einer Zeichenmatrix im Zeichengenerator:

Inhalt des Video RAM: 41 Hexadezimal; 65 Dezimal; ASCII A Inhalt des Zeichengenerators:

| Adresse  | sedezimaler<br>Wert | D76543210 |
|----------|---------------------|-----------|
| 16 × 41H | 18                  | 00        |
| 41H + 1  | 24                  | 00        |
| 41H + 2  | 42                  | .00.      |
| 41H + 3  | 7E                  | .000000.  |
| 41H + 4  | 42                  | .00.      |
| 41H + 5  | 42                  | .00.      |
| 41H + 6  | 42                  | .00.      |
| 41H + 7  | 00                  |           |
| 41H + 8  | 00                  |           |
| 41H + 9  | 00                  |           |
|          |                     |           |

Es bedeutet: . = Punkt leuchtet nicht

o = Punkt leuchtet

Die 8 höherwertigen Leitungen beinhalten das ASCII-Zeichen, die vier niederwertigeren werden vom Controller erzeugt.

Mit Unterstützung einiger weiterer im Video Interface erzeugter Signale wird nun diese Punktmatrix in eine serielle Punktfolge aller einzelnen Punktzeilen gewandelt (Vorstellbar als Einschaltbefehl für den Kathodenstrahl wenn ein "o" eintrifft, damit also Sichtbarmachen der einzelnen Punkte der Zeichenmatrix). Die ebenfalls ausgegebenen Attribute Blinken und Invers werden nun in den "Punktstrom" für jedes Zeichen synchron eingemischt.

Mit den Signalen für horizontale und vertikale Synchronisation versehen und in einer nachfolgenden Transistorstufe auf eine Impedanz von 75 Ohm gewandelt ergibt sich so das Video-Signal "BAS" (Bild-Austast-Synchronsignal) für die Zeichendarstellung auf einem Monitor mit einfarbiger Darstellung (Amplitude und Zusammensetzung siehe Abb. 5.14).

Der Schaltungsauszug für die BAS-Schnittstelle ist in Abbildung 5.20 dargestellt.







Für die Erzeugung der Signale zur farbigen Darstellung eines Bildes ist etwas mehr Aufwand erforderlich.

Das seriell gewandelte Zeichensignal wird auf einen Umschalter (Multiplexer) geleitet. Dort schaltet dieses Signal entsprechend der Punktfolge des im Video RAM abgespeicherten ASCII-Zeichens zwischen der im Attribut RAM abgespeicherten Information für Hintergrund- und Vordergrundfarbe um. So entsteht nun eine Information, jeweils für Rot, Grün und Blau, die in einem Farbmonitor die einzelnen Kanäle für RGB einoder ausschalten kann. Die noch fehlenden Attribute für blinkende oder inverse Darstellung werden nun noch, wie beim BAS-Signal, hinzugemischt. Damit alle entstandenen Farbinformationen im zeitlich richtigen Rahmen ausgegeben werden können, ist eine Synchronisationsstufe vor der Ausgabe eingefügt.

Abweichend vom BAS-Signal werden bei der Übergabe der Farbsignale die Synchronsignale separat übergeben. Die Burstfreqenz (BSTCLCK), die vom HF-Modulator benötigt wird, liegt ebenfalls auf einem separaten Steckerstift.

Alle Ausgangssignale werden mit TTL-Pegeln ausgegeben (Stekkerbelegung und Schaltungsauszug siehe Abb. 5.21).

#### 5.7.3 CRT Controller

Beim PC wird der CRT Controller HD 4650 S (Hersteller Hitachi) eingesetzt. Er leitet aus einer Quarzfrequenz von 17,73447 MHz (bei Einstellung als Gerät für PAL-Betrieb) folgende Signale ab:

HSYNC : Signal zur Synchronisation der Zeilenfrequenz des angeschlossenen Monitors.

VSYNC : Signal zur Synchronisation der Bildfrequenz.

DISPTIM : Ein Signal welches den Controllerzugriff auf das Video RAM mitteilt. CUDISP

: Dieses Signal steuert die Darstellung des Cursor.

MAO +

MA13

: Adressen für das Video RAM. Beim PC werden nur die Leitungen MAO → MA1O (≘ 2048 Adressen) ausgenutzt. Unter diesen Adressen ist das darzustellende Zeichen als 8 bit Information abgelegt.

RAO +

RA4

: Rasterzeilenadresse, (= ROW-Address)
mit Hilfe dieser Adressen wird die Zerlegung
der unter der Adresse MAO + MAl3 vorgefundenen Zeichen in eine beim PC 10-zeilige
Darstellung vorgenommen (siehe Darstellung
des Zeichens "A" oben).

Die Adressen MAO + MA13 und RAO + RA4 werden vom CRT- Controller linear erzeugt und ausgegeben. Damit wird über die immer wieder ausgegebenen Zeichen das Bild auf dem Bildschirm ständig aufgefrischt.

LPSTB

Lightpen Strobe (beim PC nicht benutzt) Mit Hilfe dieses Signals kann über einen "Lightpen" (Lichtgriffel) eine auf dem Bildschirm ausgewählteStelle vom CRT-Controller lokalisiert und angegeben werden.

Zur Eingabe der Arbeitsweise hat der CRT-Controller HD 4650S die Steuerregister RO + R17, sowie das Adressregister AR. Eine Veränderung der vom Monitor des PC vorgenommene Progemmierung ist über diese Register möglich.

Dazu ist als erstes in das Adressregister AR (50H) die Adresse des zu verändernden Registers einzutragen. Dann kann entsprechend I/O Adresstabelle eine Veränderung des Inhaltes über die Adresse 51H erfolgen. Zu beachten ist dabei, daß zum einwandfreien Arbeiten einiger Sequenzen die Änderung mehrerer Register erforderlich sein kann. Näheres bitte dem Datenbuch entnehmen.

In die Register RO + Rll kann nur geschrieben werden, die Register R12 + R15 sind zusätzlich lesbar, die Register R16 und R17 können nur gelesen werden.

Eintragungen in das über AR (50H) ausgewählte Register können z.B. mit der nachstehenden Sequenz erfolgen:

LD A,Adresse OUT A,50H LD A,Wort ; Adresse des zu beeinflussen-

; den Registers ausgeben : Steuerwort über den AKKU

OUT A.51H ; ausgeben

Funktion der einzelnen Register (die Ziffer entspricht der dezimalen Adresse im AR):

- AR Adress Register; im AR wird das zu beeinflussende Register festgelegt
- enthält die Anzahl der möglichen Zeichen pro Text-RO zeile minus 1 einschließlich der Zeilensynchronisationsdauer. Im 40 x 24 Zeichen Modus des PC wird RO mit 46H geladen, im 80 x 24 Modus mit 7EH.
- R1 enthält die Anzahl der maximal dargestellten Zeichen pro Textzeile, also entweder 28H (= 40 dez.) oder 50H (= 80 dez.). Der Inhalt von R1 muß immer kleiner als der von RO sein.
- R2 enthält die Position des Zeilensynchronisationspulses. Mit diesem Byte kann das Bild nach rechts oder links verschoben werden. Im 40 Zeichenmodus befindet sich die Ziffer 34H in R2 (80 x 24 : 5FH). Schreibt man eine kleinere Zahl in dieses Register, verschiebt sich das Bild nach rechts, eine größere Zahl verschiebt das Bild nach links.
- R3 Der Inhalt dieses Registers legt die Länge des Bildsynchronisationspulses fest. Die höherwertigen 4 Bit legen die Pulsbreite des vertikalen (= Bild-) -Synchronisationssignals als vielfaches einer Rasterperiode fest. Die Bitkombination 0000 wird als Faktor 16 interpretiert. Die niederwertigen 4 Bit bestimmen die Länge des Horizontalpulses (= Zeilensynchronisation) als Vielfache von Zeichentaktperioden. Die Bitkombination 0000 ist hier nicht zulässig. Im PC finden die Konstanten 56H (40x24) bzw. 5C (80 x 24) Verwendung.
- R4 Enhält die Anzahl der möglichen Textzeilen minus l pro Bild, einschließlich der Zeilen während des Bildsynchronisationspulses. Der PC lädt nach dem Einschalten 1EH in R4.

enthält die Anzahl von leeren Bildschirmzeilen, die R5 dem gewählten Bildschirmformat hinzugefügt werden müssen, um eine optimale Anpassung an die vom Monitor bzw. Fernseher vorgegebene Bildwechselfrequenz zu erreichen. Im 40 x 24 Modus wird hier eine 2, im 80 x 24 Modus eine 4 gespeichert.

Hier wird die Anzahl der darzustellenden Textzeilen R6 festgelegt. Sie muß kleiner als die in R4 abgelegte Gesamtzeilenzahl sein. Der PC setzt dieses Register auf 18H für 24 Textzeilen.

enthält die Position des Bildsynchronisationspul-R7 ses. Durch Veränderung dieses Bytes kann das Bild nach oben (Vergrößern des Inhaltes) bzw. nach unten (Verkleinern des Inhaltes) verschoben werden. Nach dem Einschalten wird vom PC 1BH in R7 geschrieben.

In diese Register wird eine O geschrieben. Auf die R8 Bedeutung der einzelnen Bits soll hier nicht eingegangen werden, da die Programmierung von der Schaltung des gesamten Videoteils abhängig ist.

Hier wird die Anzahl der Rasterzeilen für die Zei-R9 chen minus l gespeichert. Wie oben erwähnt, ist der Zeichengenerator für 10 Rasterzeilen ausgelegt, es muß also eine 9 in R9 abgespeichert werden.

Cursor Startzeile R10:

R11: Cursor Endzeile

> In diesen beiden Registern wird das Format sowie die Darstellung des Cursor festgelegt.

(R10) = 9 ; (R11) = 9Beispiel 1:

7eile 1 .....

Cursor nicht blinkend Zeile 9 ooooooo

" 10 ......

R12 + R13

R14

R15

| <u>Beispiel 2:</u> (R10) = 1 ; (R11) = 4                                                                                                                                                                                                                                                             |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Zeile 1 00000000 " 2 00000000 " 3 00000000 " 4 00000000 " 5 " 10                                                                                                                                                                                                                                     |
| Aufbau des Bytes für R10 und R11:                                                                                                                                                                                                                                                                    |
| D7 6 5 4 3 2 1 0 Cursor:  x 0 0 II nicht blinkend  x 0 1 II nicht dargestellt  x 1 0 II blinkend 16  x 1 1 II blinkend 32  x immer 0  16 \( \frac{1}{2}\) schnelles Blinken  32 \( \frac{1}{2}\) langsames Blinken  II \( \frac{1}{2}\) Zeilennummer Sedezimal innerhalb  eines Feldes von 10 Zeilen |
| Startadressregister, in diesem Registerpaar steht<br>die Video-RAM-Adresse, aus der das erste darzu-<br>stellende Zeichen eines Bildes zu holen ist. Im PC<br>ist die Startadresse immer O.<br>Register 12 enhält den höherwertigen Adressteil.                                                      |
| Cursoradresse L,<br>In diesen Registern ist die aktuelle Cursoradresse<br>angegeben.                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                                                                                      |

R16 Light Pen H

R17 Light Pen L,
Diese Register beinhalten die Adresse des Lichtpunktes, der mit dem "Lightpen" erfaßt wurde. Beim
PC ist der Lightpen Anschluß des CRT Controllers
jedoch nicht beschaltet.

Beispiel für die Cursorbeeinflussung im Basic:

| 10 OUT &H50,10 | O REGISTER 10 AUS  | WÄHLEN |
|----------------|--------------------|--------|
| 20 OUT &H51,64 | 4 'STARTZEILE O, B | LINKEN |
| 30 OUT &H50,13 | 1 REGISTER 11 AUS  | WÄHLEN |
| 40 OUT &H51,73 | 3 'ENDZEILE 10, BL | INKEN  |
| 50 END         |                    |        |

Mit dieser Sequenz wird der Cursor als blinkendes Vollfeld dargestellt.

| PORT | 50 | H/5 | <u>1 H</u> |
|------|----|-----|------------|
|      |    |     |            |

Bildschirm-Controller HD46505S

OUT 50H

DATA BUS --- HD46505 DATA (Nummer des internen Registers)

BIT

7 6 5 4 3 2 1 0 --- --- RA4 RA3 RA2 RA1 RA0

OUT 51H

DATA BUS --- HD46505 DATA (DATA nach internem Register)

für Register 0 bis 15

BIT

7 6 5 4 3 2 1 0

DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0

IN 51H

HD46505 inter. Reg. DATA --→ DATA BUS für Register 12 bis 15

BIT

7 6 5 4 3 2 1 0

DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0

Abb. 5.22

PORT 50 H / 51 H
Bildschirm-Controller HD 46505S
Interpregister

Abb. 5.23

|                  | _           | _        |                  | _                |                      | -                |               |                |                 |                    |                  |                | -                  | -            |            |                   |                   | -          |            | _             | _             |
|------------------|-------------|----------|------------------|------------------|----------------------|------------------|---------------|----------------|-----------------|--------------------|------------------|----------------|--------------------|--------------|------------|-------------------|-------------------|------------|------------|---------------|---------------|
|                  | 0           | Λ        |                  | l                |                      |                  |               | 1              |                 |                    |                  |                |                    |              |            |                   |                   |            |            |               |               |
|                  | -           | abla     |                  | _                |                      | Т                | ⇈             | Г              |                 |                    | $\vdash$         | Г              |                    |              | Γ          |                   | Г                 |            | Г          |               |               |
| S                | 2           | abla     |                  |                  | -                    |                  | 1             |                | Τ               | Τ                  | -                | K              | Г                  |              | Г          |                   | $\top$            | 1          | 1          |               | Г             |
| m l              | 3           | 7        | -                | -                |                      |                  |               |                |                 |                    |                  | K              |                    |              | Γ          | ┢                 | Τ                 | Т          | Τ          | 1             |               |
| ō.               | 4           | 7        | -                | Г                |                      | -                |               | Г              |                 | Γ                  |                  | 1              |                    |              |            |                   | Γ                 | Г          | Γ          | Г             | Г             |
| ē                | 2           | 1        | 1                |                  |                      |                  | Z             | 1              | K               | Г                  | Г                | K              | V                  | a.           | 1          |                   |                   |            |            |               |               |
| Number of Bits   | 7 6 5 4 3 2 | $\angle$ | 7                |                  | Г                    |                  | Z             |                | K               |                    | Г                | V              | Z                  | m            | 7          | 1                 |                   | N          |            | K             |               |
| 2                | 7           | 7        | 7                |                  |                      |                  | K             |                | K               | K                  |                  | $\setminus$    | Z,                 |              |            |                   |                   |            |            | 7             |               |
|                  |             |          | ١.,              |                  |                      |                  | Γ             | Г              | Γ               |                    | Г                |                | Г                  | Г            |            |                   |                   | Г          | Γ          | Г             |               |
|                  |             |          |                  |                  |                      |                  |               |                |                 |                    |                  |                |                    |              |            |                   |                   |            |            |               |               |
| Program Unit     |             |          |                  |                  |                      |                  |               | 3              |                 | 3                  | 3                |                |                    |              |            |                   |                   |            |            |               |               |
| ٤                |             |          |                  |                  |                      |                  |               | 2              | Ĕ               | 0                  | 20               |                | Ĕ                  | Ĕ            | Ĕ          | ١,                | ١.                | ١.         | ١.         | ١,            | ١.            |
| gra              |             |          | '                |                  | ٥                    | ٤                | ٤             | 3              | 2               | 2                  | 3                | 1              |                    | 2            | 1          | ١.                | Ι'                | 1          |            | ١.            | '             |
| 2                |             |          |                  | Char.            | Char.                | Char.            | Char.         | Char. Row      | Scan Line       | Char. Row          | Char. Row        |                | Scan Line          | Scan Line    | Scan Line  |                   |                   |            |            |               |               |
|                  |             |          | L                | _                | ۰                    |                  | Ľ             | $\square$      | S               | Ľ                  | $\square$        | _              | (V)                | 01           | S          | _                 | _                 | L          | L          | L             | _             |
|                  |             |          |                  |                  | Horizontal Displayed |                  |               |                |                 | _                  |                  |                | Max Scan Line Add. |              | -          |                   |                   |            |            |               |               |
|                  |             |          | e                | _                | a                    | ڃ                |               |                |                 | Vertical Displayed | c                |                | ĕ                  |              |            | Î                 |                   |            |            |               |               |
|                  | į           |          | Address Register | Horizontal total | isp                  | H. Sync Position | 드             | -              | V. Total Adjust | <u>ē</u>           | V. Sync Position | Interface Mode | ne                 |              |            | Start Address (H) | Start Address (L. |            |            | Ç             | _             |
| ₩                |             |          | Şec              | =                |                      | 208              | 몽             | ote            | ē               | ISP                | Sos              | ž              | ٦                  | art          | ō          | res               | res               |            |            | 는             | 닏             |
| -                |             |          | S                | nta              | nta                  | U                | U             | _              | 7               |                    | 5                | 9              | Sar                | S            | 띱          | P                 | B                 | E          | ۳          | en            | ē             |
| Register File    |             | 1        | res              | 20               | 20                   | 7                | H. Sync Width | Vertical Total | ote             | Ca                 | 5                | 10             | Ň                  | Cursor Start | Cursor End | +                 | _                 | Cursor (H) | Cursor (L) | Light Pen (H) | Light Pen (L) |
| eg               |             |          | PP               | ō                | o.                   | S                | S             | ert            | ۲.              | eri                | S                | te             | ax                 | 5            | 5          | tar               | ar                | 5          | 5          | lg<br>H       | 6             |
|                  |             |          | _                | I                | I                    | I                | I             | >              | >               | >                  | >                | =              | 2                  | 0            |            | S                 | S                 | 0          | 0          | 1             | _             |
| Register         |             |          |                  |                  |                      |                  |               |                |                 |                    |                  |                |                    |              |            |                   |                   |            |            |               |               |
| gis              | h           | ×        | ×                | 80               | -                    | R2               | 83            | 74             | RS              | R6                 | R7               | R8             | R9                 | R 10         | R11        | R12               | R13               | R14        | R 15       | R16           | R17           |
| Ω.               |             |          |                  | α                | ű                    | æ                | a             | α              | α               | α                  | α                | Œ              | α                  | Œ.           | α          | Œ                 | α                 | Œ          | α          | α             | ď             |
|                  |             |          |                  |                  |                      |                  |               |                |                 |                    |                  |                |                    |              |            |                   |                   |            |            |               |               |
| Address Register | _           |          |                  | _                | _                    | _                |               | _              | _               | _                  | -                | _              |                    | _            |            | _                 | -                 | _          | _          | _             | -             |
| egl              | 1 0         | XXXX     | ×                | 0 0 0 0          | Ë                    | 0 0 0 1 0        | =             | 0              | 0 0 1 0 1       | 0                  |                  | 0 1 0 0 0      | =                  | 0 1 0        | 1          | 0                 |                   | E          | =          | 1 0 0 0 0     | E             |
| α .              | 2 1         | Ä        | X                |                  | 0                    | Ξ                | E             | 13             | 13              | Ξ                  | -                | 5              | 0 0                | E            | 0          | 0                 | 0                 |            | =          | -             | 1 0 0 0       |
| S S              | . 7         | Ä        | ×                | 2                | 0                    | 0                | 0 0 0         | E              | =               | =                  | E                | 0              | 0                  | -            | _          | _                 | Ξ                 |            | _          | _             | 2             |
| Ď,               | <u>س</u>    | ×        |                  | 0                | 0                    | 0                | 0             | 0              | -               | 0                  | 0                |                | 0                  | 0   1        |            | 0                 | 1                 | _          | _          | 0             | 0             |
| ¥.               | 4           | ×        | ×                | 0                | 0                    | 0                | 0             | 0              | 0               |                    | 0                | 0              | 0                  | 0            | 0          | 0                 | 0                 | 0          | 0          |               |               |

Adressen des Video- und Attribut RAM in Bezug zur Position auf dem Bildschirm:

#### 1. Format des Bildschirms: 40 Zeichen/Zeile

| Attr. | F | 300 | ) |  |  |   |   |  |   |   |   |   |   |  |   |   |  |  |  | F | 8 | B |
|-------|---|-----|---|--|--|---|---|--|---|---|---|---|---|--|---|---|--|--|--|---|---|---|
| Video | F | 000 | ) |  |  |   |   |  |   |   |   |   |   |  |   |   |  |  |  | F | 0 | 2 |
| Zeile | 0 | χ.  |   |  |  | • | • |  |   | • |   |   | • |  | • |   |  |  |  |   | Х |   |
|       | 1 |     |   |  |  | ۰ |   |  | • |   |   |   |   |  |   |   |  |  |  |   |   |   |
|       | 2 | • • |   |  |  |   | • |  |   |   | • |   |   |  |   | ٠ |  |  |  |   |   |   |
|       |   |     |   |  |  |   |   |  |   |   |   | • |   |  |   |   |  |  |  |   |   |   |
|       |   |     |   |  |  |   |   |  |   |   |   |   |   |  |   |   |  |  |  |   |   |   |

Zeile 23 X......X
Video F398 F3BF
Attr. F898 FBBF

# 2. Format des Bildschirms: 80 Zeichen/Zeile

| Attr. | F8 | 80 | 0 | 1 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | F | 8 | 4F |
|-------|----|----|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|----|
| Video | F( | 00 | 0 |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   | F | 0 | 4F |
| Zeile | 0  | X  |   | • | • | • | • |   |   |   |   |   |   |   |   | • |   | • | • | • |   |   |   |   |   |   |   |   | X |    |
|       | 1  |    | • | • | • |   | • |   | • |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |   |    |
|       | 2  | •  | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • | • |   | • |    |

Zeile 23 X......X
Video F730 F77F
Attr. FF30 FF7F

#### Aufbau des Attribut-Byte:

| DO (LSB) |                                   |
|----------|-----------------------------------|
| D1       | : Vordergrundfarbe Rot Of V. Weiß |
| D2       | : Vordergrundfarbe Grün           |
| D3       | : Hintergrundfarbe Blau           |
| D4       | : Hintergrundfarbe Rot T          |
| D5       | : Hintergrundfarbe Grün           |
| D6       | : blinkendes Zeichen              |
| D7 (MSB) | : inverses Zeichen (dunkle        |
|          | Schrift auf hellem Hintergrund)   |

Eine logische "l" an der jeweiligen Bitposition setzt das zugehörende Attribut. Aus den Farben Rot, Grün und Blau entsteht eine der nachfolgenden Farben. Sie sind vom Basic über den Befehl COLOR a,b,c oder CLS a,b,c (a= Zeichenfarbe; b= Hintergrundfarbe, c= Attribut) setzbar. Ab dem Befehl CLS oder COLOR werden jedoch alle nachfolgenden Zeichen bis zur nächsten Änderung des Befehls gleich dargestellt.

#### zusammengesetzt aus :

| U | = | schwarz  |  |
|---|---|----------|--|
| 9 |   | 1 1 31 3 |  |

| 1 | = | dunkelblau | blau |
|---|---|------------|------|
| 2 | = | rot        | rot  |

3 = purpur blau und rot

4 = grün grün

5 = hellblau grün und blau 6 = gelb grün und rot

7 = weiβ rot und grün und blau

#### Die Attribute für diese Befehle sind:

|     | blinken | invers |
|-----|---------|--------|
| 0 = | nein    | nein   |
| 1 = | ja      | nein   |
| 2 = | nein    | ja     |
| 3 = | ja      | ja     |

#### 5.8 ROM PACK

Der alphatronic-PC verfügt über eine "ROM PACK" Schnittstelle, um die mit entsprechenden Anwenderprogrammen angebotenen Steckmodule (PACK's) betreiben zu können. Der zum Anschluß erforderliche 30-polige Stecksockel befindet sich links oberhalb der Tastatur unter einer ohne Werkzeug abnehmbaren Abdeckung (Abb. 5.3). Das Modul enthält maximal 2 EPROMs des Typs 2764. (Unter EPROM versteht man einen Nurlese-Speicher (ROM), der elektrisch programmierbar (- P = progammable) und durch UV Licht löschbar (- E = eraseable) ist). Die typische Beschaltung eines Moduls geht aus Abb. 5.10 hervor. Die EPROMs werden vom PC unter folgenden Adressen angesprochen (wenn im SPORT, siehe Kap. 5.1, das Freigabebit (6) gesetzt und das Rom-Sperrbit (7) gelöscht ist):

EPROM 1 Adresse A000H + BFFFH
EPROM 2 Adresse C000H + DFFFH

Aus der PC-internen Schnittstellenschaltung (Abb. 5.11) ist ersichtlich, daß der Datenbustreiber (74L5245) durch die gemeinsame Beschaltung der PIN's 1 und 19 entweder inaktiv geschaltet ist oder Daten in den PC gibt, Datenausgabe ist hier also nicht möglich.







ROM-PACK Schnittstelle



Abb. 5.26

Für den Anwender mit der Möglichkeit, eigene EPROMs zu programmieren ein Hinweis:

Bei einer 16 k-Version der EPROMs muß unter der Adresse AOOOH ein direkter Sprungbefehl folgen, beginnend mit dem Befehlsbyte C3H. Bei einer 8 k-Version muß dieser Befehl unter COOOH beginnen. Wird nach dem Einschalten der EPROM-Inhalt in das RAM des PC kopiert und anschließend die ROM PACK's gesperrt, kann sich das Programm aus dem ROM PACK selbst modifizieren und 64 k RAM minus Programmlänge stehen zur Verfügung.

#### 6. Software

# 6.1 Das Monitorprogramm des alphatronic-PC

Das Monitorprogramm ist das Grundprogramm des alphatronic-PC. Es ermöglicht eine effiziente Nutzung der durch die Hardware ( $\hat{z}$  elektronische Schaltung) des PC vorgegebenen Möglichkeiten. Bei einem Betrieb ohne Floppydisc wird es als Betriebssystem genutzt. Das Monitorprogramm ist in 1 EPROM zu 8 kByte untergebracht und belegt den Adressbereich EOOOH bis etwa FBOOH (versionsabhängig).

Anmerkung: Die angeführten Adressangaben beziehen sich auf die Version des Monitors vom 25.Juli 1983.

Das Monitorprogramm besteht aus folgenden Komponenten :

#### a) Adressbereich E000 bis E400

#### al) Systemcheck

Dieser Programmteil wird nach dem Einschalten und nach einem Betätigen des Reset-Tasters durchlaufen. Hier wird der Videobaustein mit den Betriebsparametern versorgt, der Bildschirm gelöscht, der Piezo-Summer kurz eingeschaltet und alle Systemregister auf ihren Anfangszustand gesetzt. Danach wird abgefragt, ob ein ROM-Pack eingesteckt ist. Erkannt wird dieses an dem Byte C3H auf den Adressen A000 oder C000. Wenn dies der Fall ist, wird in das Programm des Moduls gesprungen. Ist kein Pack vorhanden, wird ermittelt, ob ein Floppydisklaufwerk angeschlossen ist und gegebenenfalls zum Ladeprogramm (IPLDSC = Initial Program Loader) gesprungen. Ist das Bit O des SPORT gesetzt, wird dieses als eingeschaltete Floppydisc interpretiert. Als drittes wird gefragt, ob die Basic-ROM's vorhanden sind und gegebenenfalls die Initialisierung des Basic vorgenommen.

#### a2) Befehle des Monitorprogramms

Weiterhin befinden sich in diesem Adressbereich die Programme, die die Monitorbefehle D, G, C, M, R, E, P erkennen und abarbeiten. Vor dem Aufruf des Monitorprogramms vom Basic sollte die Bildschirmbreite mit dem "WIDTH"-Kommando auf 80 Zeichen/Zeile eingestellt werden. Der Aufruf des Monitors erfolgt mit dem Basic Kommando "Mon" (RETURN).

Das Monitorprogramm meldet sich mit der Frage "Memory area?" (= Speicherbereich) und erwartet hierauf die Eingabe der höchsten Speicheradresse, die benutzt werden darf. Falls keine Begrenzung gewünscht wird, reicht die Betätigung der RETURN-Taste. Das Programm antwortet nun mit dem "\*". Dieses Quittungssignal (Prompt) zeigt die Bereitschaft des Monitorprogramms, Befehle zu übernehmen.

Der Monitor verfügt über 7 Befehle:

| <u>Befehl</u> | Bedeutung                                    |
|---------------|----------------------------------------------|
| D             | Dump; d.h. Speicherinhalt ausgeben           |
| G             | Goto; Sprunganweisung                        |
| С             | Change; Speicherimhalte ändern               |
| M             | Move; Speicherinhalte verschieben            |
| R             | Register; Registerinhalte der MPU ausgeben   |
| E             | Exit; Rückkehr in den Basic-Interpreter      |
| Р             | Print on, Print off; Zuschalten des Druckers |

#### Befehlsformate:

# D, Speicherinhalte ausgeben

Dieses Kommando wird benötigt, um Speicherinhalte in sedezimaler (= Hex) Form auszugeben:

\* D xxxx,yyyy (Return)

xxxx = Anfangsadresse

yyyy = Endadresse

Es erfolgt die Ausgabe der Speicherinhalte von xxxx bis einschließlich yyyy. Das Format der Ausgabe ist:

Adresse des 1. Byte; 16 Byte, sedezimale Darstellung; ASCII Darstellung der 16 Byte

#### G, Sprunganweisung

\* G xxxx (Return)

Nach dem Betätigen der Return-Taste wird ein Sprung zur Adresse xxxx des Speichers durchgeführt und das dort beginnende Maschinenprogramm (sedezimaler Code) abgearbeitet.

#### C, Speicherinhalte ändern

\* C xxxx (Return)

Nach Betätigen der Return-Taste wird der Inhalt der Speicherzelle xxxx angezeigt. Soll der Inhalt geändert werden, so müssen 2 sedezimale Ziffern (O/-F/) eingegeben werden. Soll keine Änderung erfolgen, kann mit der Space-Taste (Leertaste) auf die Ausgabe des nächsten byte (± xxxx + 1) geschaltet werden. Das Programm arbeitet so lange, wie ein Zeichen O bis 9 oder A bis F oder Space eingegeben wird. Die Eingabe eines Return oder eines nicht-sedezimalen Zeichens beendet die C-Anweisung.

# M, Speicherinhalte verschieben

#### \* M ssss.eeee.nnnn (Return)

ssss = Anfangsadresse des zu verschiebenden Bereiches

eeee = Endadresse des zu verschiebenden Bereiches

nnnn = Anfangsadresse des Zielbereiches

# R, Registerinhalte ausgeben

\* R

Es erfolgt der Ausdruck:

PC B C D E H L A F I IX IY

Die hier angegebenen Register sind die zur Zeit aktiven Register, die Hintergrundregister werden nicht angezeigt.

# E, Rücksprung ins Basic

\* E

Nach Eingabe dieses Kommandos wird das Monitorprogramm verlassen und zurück zum Basic-Interpreter gesprungen.

# P, Zuschalten des Druckers

#### \* P PRINT ON / PRINT OFF

Durch dieses Kommando wird ein angeschlossener Drucker (betriebsbereit!) zum Protokolldruck zugeschaltet. Es werden alle Zeichen am Bildschirm auch auf dem Drucker ausgegeben, solange, bis ein weiteres P eingegeben wird.

# b) Adressbereich E400 bis etwa E59D

In diesem Adressbereich befindet sich zunächst die "B105-Entry-Table". BIOS ist die Abkürzung für "Basic-Input-Out-put-System" und bedeutet "grundlegendes Ein-/Ausgabe System". Diese "Entry-Jump-Table" (Einsprungtabelle) ermöglicht anderen Betriebssystemen (z.B. CP/M) und/oder Anwenderprogrammen die Nutzung von grundlegenden Ein-/Ausgaberoutinen, ohne deren tatsächliche physikalische Adresse zu kennen, da diese Adressen sich von Version zu Version ändern können. Die Position eines Sprunges innerhalb der Tabelle sowie die Adresse der Tabelle bleibt jedoch immer gleich. Auf die über diese Tabelle angesprungenen Unterprogramme soll hier nicht näher eingegangen werden, sie sind aus dem ebenfalls bei IRIUMPH-ADLER erhältlichen Monitorlisting ersichtlich.

Dieser Tabelle folgen zwei weitere: die nächste enthält für die Initialisierung des Systems erforderliche Konstanten und die Reservierung von Arbeitsspeicherzellen als Arbeitsregisterbereich. In diesem Bereich werden für die Markierung des Systemzustandes bzw. Arbeitsmodus erforderliche Masken und Adressen abgespeichert. Die dritte Tabelle enthält den internationalen ASCII (American Standard Code for Information Interchange) -Kode. Diese Tabelle ermöglicht die Zuordnung von Tasten zum darzustellenden Zeichen.

Beispiel für die Verwendung der Einsprungtabelle:

Bei der Initialisierung wird die Stellung der DIP-Schalter abgefragt und abhängig vom Ergebnis die Sprungadresse für den Druckerausgang im Monitor verändert. Standardmäßig ist Druckerroutine (LPTOUT, E439H) mit dem Sprung zur Centronics-Routine (LPRTOT) vorbesetzt. Softwaremäßig kann durch Poken der neuen Sprungadresse auch während des Programmlaufes auf die V24-Schnittstelle (RSCOUT) umgeschaltet werden. Die einzugebenden Adressen sind monitorabhängig, siehe Monitor-Listing.

z.B. POKE &H E43A,&HC2 schaltet auf Centronics, POKE &H E43A,&BHEC schaltet auf V24 um.

#### c) Adressbereich E59D bis EF47

In diesem Bereich befinden sich Unterprogramme und Tabellen, die über die BIOS-Sprungtabelle angesprungen werden. Es handelt sich hierbei um Routinen zur Tastatur- (Keyboard) Abfrage, zur Darstellung von Zeichen auf dem Bildschirm, zur Cursorsteuerung auf dem Bildschirm, zur Zeichenein-/ausgabe über die serielle Schnittstelle (incl. Cassettenrecorder) und zur Ausgabe über die Centronics-Schnittstelle. Im Bereich von EFOO – EF2O befinden sich die Interruptvektoren. Da der alphatronic-PC keinen Interrupt nutzt, ist für jeden der Interrupts lediglich ein REI-Befehl (C9H) und drei freie Bytes vorgesehen. Soll ein Interrupt genutzt werden, muß hier ein entsprechender Sprungbefehl eingesetzt werden (siehe auch Kap. 5.6, Beschreibung des Interrupt-Controllers).

# d) Adressbereich etwa EF47 bis F200

In diesem Adressbereich liegen die Unterprogramme des Monitors (E000 - E400). Besonders hervorzuheben sind Laderoutinen für die erste Floppydisc. Diese Routinen nutzen den DMA-Steuerbaustein (siehe auch Kap. 5.6). Der Floppydisc-Steuerbaustein wird über Tabellen mit den jeweiligen Parametern versorgt, die Datenübernahme wird mit Hilfe des DMA bewerkstelligt. Nach Übernahme der ersten 256 Byte von der Floppydisc wird von dem System zur Adresse C200 gesprungen; die weitere Steuerung erfolgt von dem Programm, das dort beginnt.

Ferner befindet sich in dem Bereich der oben angegebenen Adressen eine Routine, die in Abhängigkeit von den im PC eingebauten Kodierschaltern den jeweiligen nationalen Zeichensatz dem internationalen ASCII-Rumpf hinzufügt. Die zugehörigen Tabellen sind ab Adresse F800 zu finden und zwar:

ab F800: deutscher Zeichensatz

ab F840: U.S. Zeichensatz

ab F880: französischer Zeichensatz

# 6.2 Das CP/M-Betriebssystem

Für den alphatronic-PC ist auch das weitverbreitete Betriebssystem CP/M (CP/M ist das eingetragene Warenzeichen der Firma Digital Research, es bedeutet: Control Program for Microcomputer) erhältlich.

Dieses Betriebssystem ermöglicht den Einsatz von vielen Softwareprodukten unterschiedlichster Hersteller, da dieses Softwareprodukt eine definierte, hardware-unabhängige Softwareschnittstelle bietet. Auf den Befehlssatz des CP/M wird hier nicht eingegangen; wir möchten auf das bei TA erhältliche CP/M-Handbuch verweisen.

Das CP/M besteht aus einigen Programmteilen, die voneinander logisch trennbare Aufgaben zu bewältigen haben.

a) Programmteil BIOS (Basic Input Output System) Dieser Programmteil stellt die Verknüpfung des CP/M mit der Hardware her. Die hier enthaltenen Routinen sind für die Zeichen Ein- und Ausgabe, Schreiben und Lesen eines Floppy-Disc-Sektors und ähnliches zuständig. Die BIOS-Version 2.2/3.0 des CP/M des PC beinhaltet eine Einschränkung gegenüber dem Standard: es sind lediglich 2 physikalische (tatsächlich angeschlossene) Floppydisc-Laufwerke adressierbar; Laufwerk A und Laufwerk B. Wird das Pseudo-Laufwerk P angesprochen, können (mittels Laufwerk A) unter CP/M erstellte Disketten des alphatronic P2 gelesen werden. Anzumerken ist ferner, daß diese BIOS-Version im Gegensatz zu vorhergehenden alle Datentransferoperationen zwischen Cloppydisc und PC mit Hilfe des DMA-Steuerbausteins ausführt. Unberührt davon bleibt das Datenformat. Es werden wie im Standard, Daten und Programme in Blöcke aufgeteilt und abgespeichert. Jeder Block besteht aus 8 "Records" mit jeweils 128 Datenbytes. Die Verwaltung dieser Records bzw. der gesamten Dateien übernimmt das BDOS (siehe unten). Das BIOS wird während der Initialisierung in den Adressbereich D900 bis E3FF des PC geladen. Die BIOS-Programme greifen auch auf Unterprogramme und Tabellen des PC-Monitors zurück, die sich im Adressbereich E400 bis F000 befinden.

# b) BDOS (Basic Disc Operating System)

Das BDOS des CP/M hat die Aufgabe, die Dateiverwaltung zu übernehmen und enthält Funktionen für die Kommunikation mit der Außenwelt. Die hier zusammengefaßten Programme befinden sich praktisch eine Ebene über denen des BIOS und nutzen diese. Das BDOS befindet sich nach dem Systemstart in dem Speicherbereich CBOO bis DBFF.

#### c) CCP (Console Command Prozessor)

Der CCP umfaßt Programme, die wiederum eine Ebene über dem BDOS anzusiedeln sind; hier befinden sich die direkt eingeladenen Kommandos wie DIR, ERA, .... Das CCP wird in den Speicherbereich C300 bis CAFF geladen.

#### d) CP/M-Ladeprogramm

Das Ladeprogramm hat die Aufgabe, nach dem Einschalten des PC die Programmteile des CP/M in das RAM des PC zu laden. Das geschieht auf folgende Weise:

Nach dem Einschalten des PC führt das Monitorprogramm einen Systemcheck durch. Ist kein ROM-PACK eingesteckt und mindestens ein Floppydisc-Laufwerk angeschlossen, wird das Monitor-Ladeprogramm IPL (Initial Program Loader) aufgerufen. Dieses Programm lädt den CP/M-Lader, er befindet sich auf der CP/M-Diskette, Spur O, Sektor 1. Diese Diskette muß sich im Laufwerk A befinden. Der IPL schreibt den CP/M Lader in den Adressbereich C200 bis C2Ff. Nachdem dies geschehen ist, wird zur Adresse C200 gesprungen. Um nun die Möglichkeit zu haben längere BIOS Versionen zu laden, verschiebt sich der CP/M-Lader zunächst selbst, bevor weitere CP/M-Teile übernommen werden. Der CP/M-Lader arbeitet im Adressbereich 6000 bis 60FF.

In dieser Programmversion umfa0t das CP/M 34 Floppydisc-Sektoren (einschließlich des Laders). Die letzten 4 Sektoren (1 kByte) sind als Zwischenspeicher vorgesehen, ein Sektor hiervon enthält jedoch zunächst für die Initialisierung des Systems erforderliche Informationen. 1 Sektor, das Ladeprogramm, wird vom IPL gelesen. Es verbleiben 30 (\$ 1EH) vom CP/M zu ladende Sektoren. Um Disketten mit einem längeren BIOS übernehmen zu können, muß diese Information geändert werden. Sie steht am Ende des Laders, nur noch gefolgt von der Ladeendekennung 3C 2D 2D 2D. In der Version 3.0 des Laders BOOT II findet man das Byte unter der Adresse 60CB - nach dem Umladen, zuvor unter C2F6.

#### 6.3 BASIC

In diesem Kapitel sollen lediglich einige Anmerkungen zur Darstellung einer Basiczeile im alphatronic-PC gemacht werden. Ein eingegebenes Basicprogramm ist im PC bei Betrieb ohne Floppydisc (Basic 5.11) ab der Adresse 6000H abgespeichert. Wird ein Floppydisc-Laufwerk mit dem Basic 5.26 benutzt, beginnt der Speicherbereich in Abhängigkeit von der Anzahl der benutzten Dateien (Files) zwischen 7300H und 8400H.

Aufbau eines Basic-Programms:

00 AL AH ZL ZH B ... B 00 AL AH ... 00 00 00

#### hierbei bedeuten:

00 : dieses Byte markiert den Anfang einer jeden Basic-Zeile

AL : Arbeitsspeicheradresse der nächsten Befehlsszeile, niederwertiges Byte

AH : dto., jedoch höherwertiges Byte

ZL : Zeilennummer des Basic-Befehls in sedezimaler Darstellung, niederwertiges Byte

ZH : dto., jedoch höherwertiges Byte

: Befehlszeile; hier werden die reservierten BasicBefehlsworte als "Token" abgespeichert. Ein Token
ist im Regelfall ein Byte, das genau einem Befehl
entspricht. Diese Token sparen Arbeitsspeicherplatz
und verkürzen die Programmausführungszeit. Ein Nachteil ist der, daß beim Auslisten der Programme die
Token vom Interpreter wieder durch die entsprechenden Befehlsworte ausgetauscht werden müssen. Der
Interpreter erkennt ein Token an dem höchstwertigen
Bit des Byte; ist dieses Bit gesetzt, handelt es
sich um ein Token und nicht um einen Teil einer
Variablen, einer Zahl oder eines Textes.

Beispiel für Token:

В

RUN = 138 (dezimal)
PRINT = 145 (dezimal)
LIST = 147 (dezimal)

00 00 00: Diese Kombination von drei Nullbytes wird vom Interpreter als Programmende verstanden.

# 7. Betrieb einer Floppydisk

# 7.1 Hinweise zum Betrieb einer Diskettenstation

# 7.1.1 Allgemeines

Mini-Floppydisc-Laufwerke (5 1/4 inch Disketten) sind preiswerte und zuverlässige Datenspeicher. Ihre Zugriffszeit ist gegenüber dem Cassettengerät um ein Vielfaches niedriger, ohne dabei die Sicherheit der Aufzeichnung zu verringern.

Disketten bestehen aus einer flexiblen (= floppy), magnetisch beschichteten Kunststoffscheibe (= disk), die sich im Inneren einer mit einem filzähnlichen Material ausgekleideten Hülle drehen läßt.

An einer Kante (oder zwei gegenüberliegenden Kanten) der Diskettenhülle ist eine rechteckige Kerbe ausgestanzt. Diese "Schreibschutz"-Kerbe wird von dem Controller abgefragt. Ist sie lichtdurchlässig, kann auf die Diskette geschrieben werden, bei Lichtundurchlässigkeit ist der Inhalt der Diskette vor Überschreiben geschützt.





Abb. 7.1



Abb. 7.2

Es gibt verschiedene Ausführungen von Disketten:

#### a) Softsektorierte Disketten:

Bei diesen Disketten werden die Spuren und die Sektoren durch ein Formatierungsprogramm auf der Diskette festgelegt.

#### alphatronic-PC:

Bei der Formatierung werden mit dem Programm "FORMAT" oder "PCFORM" des PC 40 konzentrische Spuren (Tracks), die wiederum in 16 Sektoren unterteilt sind, mit einem Leerzeichen (ESH) belegt und kontrolliert (siehe Anmerkung).

Mit Hilfe des Indexloches ist es dem "Floppycontroller" möglich, die Position des ersten Sektors festzustellen (auch bei hardsektorierten Disketten). Die physikalische Reihenfolge der Sektoren 1 – 16 stimmt jedoch nicht mit der Reihenfolge der Sektorenaufzeichnung überein. Dieses ist für eine Optimierung der Diskettenzugriffszeit erforderlich. Der Versatz zwischen physischem und logischem Sektor wird Interleave-Faktor genannt. Er wird vom Gerätehersteller festgelegt. Für den Anwender hat er keine Bedeutung beim Diskettenzugriff.

In einem Sektor können 256 Bytes abgespeichert werden. Die Reihenfolge der Spuren wird mit Spur O außen bis Spur 39 innen festgelegt. Eine Directory (Inhaltsverzeichnis) wird vom Disk-Basic immer in Spur 18 angelegt.

Oftmals werden neben anderen Handelsbezeichnungen die nachfolgenden Abkürzungen verwendet.:

SS/SD = Single Sided, Single Density ; Einseitige Speichermöglichkeit, Einfache Schreibdichte

DS/SD = Double Sided, Single Density; Beidseitige Speichermöglichkeit mit einfacher Schreibdichte (nur durch entsprechendes Laufwerk effektiv nutzbar) SS/DD = Single Sided, Double Density; Einseitige Speichermöglichkeit mit doppelter Schreibdichte

DS/DD = Double Sided, Double Density; Beidseitige Speichermöglichkeit mit doppelter Schreibdichte (auch diese Disketten sind nur durch ein entsprechendes Laufwerk effektiv nutzbar). 48 tpi (Tracks per inch), diese Disketten sind beim PC zu benutzen.

> Für neueste Laufwerke existieren bereits QD-Disketten mit vierfacher Schreibdichte (96 Tpi).

Für den Einsatz in einem Laufwerk mit einfacher Schreibdichte sind Disketten mit (möglicher) doppelter Schreibdichte durchaus verwendbar, umgekehrt wegen der groberen Struktur der magnetisierbaren Schicht jedoch nicht.

#### b) Hardsektorierte Disketten

Sie sind in gleicher Klassifizierung wie softsektorierte Disketten zu erhalten. Der einzige Unterschied besteht in der Anzahl und Anordnung der Index- und Sektorlöcher. Eine Einteilung der Sektoren durch Software entfällt.

Auf einem Laufwerk, welches softsektorierte Disketten verlangt, können keine hardsektorierten Disketten gelesen oder beschrieben werden; ebenso können softsektorierte Disketten nicht von einem Laufwerk für hardsektorierte Disketten bearbeitet werden.

#### 7.1.2 Pflege der Disketten und des Laufwerkes

Obwohl eine Diskettenstation einen sehr robusten Eindruck erweckt, ist doch im Umgang mit ihr einige Vorsicht geboten.

Grobe Behandlung wird sie nicht unbedingt sofort durch fehlerhafte Datenbehandlung mitteilen, aber über einen längeren Zeitraum lassen sich "mit einem Mal" alte Programme oder Daten nicht mehr lesen. Dieses wäre z.B. die Folge einer Dejustierung des Schreib-/Lesekopfes nach einem Sturz vom Arbeitstisch.

Bei jeder Benutzung einer Diskette werden sich winzigste Spuren von Abrieb und Schmutz am Schreib-/Lesekopf ablagern. Irgendwann ist dann die Ablagerung am Kopf so dick, daß es zu dem befürchteten "Head-crash" (heftiger Kopfkontakt zur Diskette) kommt. In diesem Fall wird die magnetische Beschichtung der Diskette mitsamt der darin enthaltenen Information unwiederbringlich zerstört. Um diesem vorzubeugen, sollte nach längerer Betriebszeit eine Reinigungsdiskette eines renommierten Herstellers nach dessen Angaben eingesetzt werden; aber bitte nicht vor jedem Diskettenbetrieb, sonst ist bald vom Kopf nichts mehr übrig!

Die Disketten selber können nicht gereinigt werden. Sie danken staub- und rauchfreie Lagerung durch langen und zuverlässigen Betrieb.

Da jedoch auch die bestens gehütete Diskette bei Benutzung nicht ewig hält, empfiehlt es sich, von wichtigen Disketten eine Sicherungskopie anzulegen.

Die Größenverhältnisse einer Verschmutzung zu dem Schreib-/Lesekopf sind aus Abbildung 7.3 zu ersehen.



Zusammenfassung der wichtigsten Fakturen der Diskettenbehandlung:

- 1. Rauch (!) von Disketten und dem Laufwerk fern halten.
- Laufwerk und Disketten in möglichst staubfreiem Raum betreiben.
- Disketten immer in ihrer Hülle in einem entsprechenden Behältnis aufbewahren.
- 4. Die Disketten nicht knicken.
- 5. Die Diskettenoberfläche nicht berühren.
- 6. Die Diskette nicht als Unterlage benutzen.
- 7. Die Diskette von Magnetfeldern fernhalten (Monitor, Motoren, Lötkolben usw.; besonders stark ist das Magnetfeld der Entmagnetisierungseinheit eines Farbfernsehgerätes während des Einschaltens!).
- 8. Die Diskette vor unzulässiger Erwärmung schützen (nicht in die Sonne oder in direkte Nähe der Heizung legen).
- 9. Die Diskette nicht unter + 10 Grad Celsius betreiben.
- Die Diskettenhülle nicht mit einem harten Stift beschreiben. Besser ist ein Filzstift.

#### Anmerkung:

Die seit einiger Zeit im Handel erhältlichen Disketten mit 96Tpi (Tracks per inch) haben eine so feine magnetische Beschichtung, daß sie problemlos in allen PC's verwendet werden können. Die Schreib- und Lesesicherheit wird damit zum Teil erheblich gesteigert.

Disketten sind mit oder ohne Verstärkungsring um das Loch für die Antriebswelle zu erhalten. Die Benutzung von Disketten mit Verstärkung ist zu empfehlen, aber nicht unbedingt erforderlich.

# 7.2 Sicherungswechsel

- 1. Vor dem Öffnen der Diskettenstation den Netzstecker ziehen.
- 2. Jetzt die drei, jeweils links und rechts an der Längsseite der Diskettenstation eingedrehten Schrauben entfernen.
- 3. Nun den Deckel nach oben abziehen.

#### ACHTUNG:

<u>Jegliche</u> Verschmutzung, auch mit noch so kleinen Staubteilchen, zieht erhebliche Funktionsstörungen des Diskettenbetriebes nach sich! (siehe Abb. 7.3, Seite 125)

Die Sicherung ist jetzt im hinteren Teil des Diskettenstation zugänglich. Austausch nur gegen eine Sicherung T 0,5 A.

Bei wiederholtem Auslösen der Sicherung muß die Diskettenstation dem TA-Service überlassen werden.

# 7.2.1 Im Fall größerer Schäden

Sollte der Diskettenbetrieb einmal gestört sein, versuchen Sie bitte nicht, die Station selbst zu reparieren.

Durch die äußerst geringen Abmessungen aller bewegten Teile besteht chne Verwendung von Spezialwerkzeug große Gefahr der Beschädigung. Nach einer Reparatur muß z.B. der Schreib-/Lesekopf mit Hilfe einer Spezialdiskette wieder justiert werden, sonst treten unweigerlich Schreib- und Lesefehler auf.

# 7.3.1 Einteilung einer Floppydisc

Der Floppydisc-Controller des alphatronic-PC-Systems teilt die Disketten (Floppydisc) in 40 Spuren mit jeweils 16 Sektoren ein. Die Spuren sind konzentrisch um das Mittelloch angeordnet und werden, da die Diskette ja auch eine physikalische Höhe bzw. Dicke hat, auch Zylinder genannt. Die Spur 00 befindet sich direkt am Anfang der Diskette, Spur 39 dicht am Mittelloch. Jede Spur wird beim Initialisieren wie folgt beschrieben:

- 1) Vor-Index-Lücke (Gaps)
- 2) Indexfeld zur Kennzeichnung der Spur
- 3) Nach-Index-Lücke
- 4) Sektoren O bis 15
- 5) Restlücke

Jeder Sektor ist wie folgt aufgebaut:

1) Identifikationsfeld (ID) mit

Synchronisationsfeld (zur Schreib-/Lesesynchronisation ID Identifikation Spurnummer Kopfnummer Sektornummer Sektornummer Sektorlänge (256, 512, ..... 4096 in MFM-Mode des Controllers codiert. Siehe unten) 2 Controllbytes (nach dem CRC-Verfahren) (CRC = Cyclic Redundancy Check)

- 2) "Nach-ID-Lücke"
- 3) Datenfeld mit

Synchronisationsfeld
Daten-/Steuerfeldkennung
Daten
2 Controllbytes (CRC)

4) "Nach-Daten-Lücke"

Bei jeder Schreib-/Leseoperation wird von der Steuerung zunächst das ID-feld des angesprochenen Sektors gesucht. Hinter diesem werden nach dem Auffinden Daten gelesen oder geschrieben. Vor der ersten Schreib-/Leseoperation auf einer Diskette müssen also zunächst Spur- und Sektorinformationen sowie leere Datenfelder auf die Diskette geschrieben werden. Dies geschieht mit Hilfe der sog. Formatierungsprogramme.

# 7.3.2 Der Floppydisc-Controller

Der Floppydisc Controller, also die Steuerungseinheit für an den PC anschließbare Floppydisc-Laufwerke, befindet sich im Gehäuse des ersten Laufwerkes (F1). Die Steuereinheit ist über die Systembusschnittstelle mit dem PC verbunden. Sie wird von ihm über die I/O-Adressen F8H und F9H angesprochen. Die Steuereinheit ermöglicht den Anschluß von bis zu 4 Laufwerken; die PC-Betriebssoftware (CP/M) unterstützt jedoch lediglich den Anschluß von 2 physikalischen Laufwerken. Das zweite Laufwerk wird über ein Kabel mit dem ersten Laufwerk und nicht mit dem alphatronic-PC verbunden.

Die beiden wichtigsten Komponenten des Floppydisc-Controllers sind ein Steuerbaustein des Typ uPD 765A und ein Datenseparator-Baustein des Typ SED 9420C. Ansonsten besteht die Schaltung aus Treiberbausteinen, Adressdkodierern und etwas Synchronisationslogik. Die Hauptaufgaben übernimmt der LSI (= large scale integration = hochintegriert) -Baustein uPD 765A. Er wird häufig FDC-Baustein bezeichnet (≘ Floppydisc-Controller). Dieser Baustein ermöglicht die Steuerung von maximal 4 Laufwerken. Die Datenaufzeichnung auf den Disketten kann entweder in einfacher Datendichte (= single density) im FM-(Frequenzmodulation) Verfahren oder mit doppelter Datendichte (double density) im MFM (modifizierte Frequenzmodulation) -Verfahren. Beim FM-Verfahren wird für bei jedem aufzuzeichnenden Bit zunächst ein Taktpuls auf die Diskette geschrieben. Ist das Bit logisch "l" folgt ein weiterer Taktpuls; ist es logisch "O", wird während der Periodendauer O auf die Diskette geschrieben (Beispiel siehe Abb. 7.4). Beim MFM-Verfahren werden zur Verringerung der Redundanz bei der Aufzeichnung, d.h. zur Erhöhung der Informationsdichte auf der Diskette, gegenüber dem FM-Verfahren folgende Regeln angewendet:

- Informationsbits stehen in der Mitte des Bitrahmens (wie bei FM)
- Taktbits werden nur geschrieben, wenn auf eine geschriebene logische O eine weitere folgen soll (Beispiel siehe Abb. 7.5)
- wenn Taktbits geschrieben werden, stehen sie am Anfang bzw. am Ende des Bitrahmens (wie bei FM, sie werden jedoch immer geschrieben)

Die Steuereinheit innerhalb des ersten Laufwerkes nutzt das MFM-Verfahren. Da dieses Verfahren sehr enge Toleranzen für die Datenaufbereitung erfordert, ist die Steuerung mit einem Datenseparator ausgerüstet. Seine Hauptaufgabe ist es, die Lesedaten aufzubereiten und diese, wie auch den Takt, dem FDC-Baustein anzubieten.

Der FDC-Baustein kann mit dem alphatronic-PC Daten in 3 Betriebsarten austauschen:

- mit Hilfe des DMA-Steuerbausteins im direkten Speicherzugriff
- in einem Modus, in dem der FDC Unterbrechungsanforderungen erzeugt, sobald ein Datenbyte verfügbar ist.
- mit Hilfe der Abfrage IN FOH, womit auch ein Abfragebetrieb (≜ Polling) möglich ist (siehe unten).

Die neueren Betriebsvarianten des PC nutzen die erste Methode. Bevor jedoch Daten von/zur Floppydisc transportiert werden können, muß der PC den Status des Steuerbausteins kontrollieren und den jeweiligen Befehl zum FDC senden. Dies geschieht mit Hilfe zweier I/O Adressen FBH und F9H. Mit IN F9H wird das Statusregister gelesen. Mit IN/OUT F8H wird das Datenregister gelesen bzw. beschrichen. Bei dem Datenregis-

ter handelt es sich um ein Stapelregister (Stack). Mit jedem OUT FAH wird ein weiteres Wort auf den Stapel gelegt. Das zuvor eingegebene Wort wird nicht überschrieben, sondern befindet sich ein Byte "tiefer" im Stapel (vergl. HP-Taschenrechner). Um einen kompletten Befehl zu übergeben, müssen inklusiv der erforderlichen Parameter (wie Spurnummer, Sektornummer ..) zwischen 2 und 9 Byte in definierter Reihenfolge auf den Stapel gelegt werden. Nach Ausführung des Befehls, z.B. dem Lesen eines Blockes mit Hilfe des direkten Speicherzugriffes müssen alle nun auf dem Stapel liegenden Informationen gelesen werden, egal ob der Benutzer sie benötigt oder nicht. Nach Ausführung von Schreib-/Lesebefehlen befinden sich 7 Bytes auf dem Stack, die vom PC gelesen werden müssen, bevor weitere Befehle an den FDC gesandt werden können. Näher soll an dieser Stelle nicht auf diese Integrierte Schaltung (IC) eingegangen werden, eine genaue Beschreibung findet man z.B. im " 1982 Catalog" von "NEC-Electronics (Europe) GmbH" (Beachte: Das Adressbit AO wird invertiert an den IC gelegt.)

Eine weitere Ein-/Ausgabeadresse wurde bisher noch nicht angesprochen: FOH.

Unter dieser Adresse befindet sich das Steuerregister des Floppydisc-Controllers. Es befindet sich innerhalb des ersten Laufwerkes. Es werde jeweils lediglich die beiden höchstwertigen Bits des Datenbytes genutzt.

Mit der Ausgabe OUT FOH kann man folgendes bewirken:

D7 = 0: Rücksetzen des FDC 765A

= 1: Arbeitsmodus des FDC

D6 = O: Sperren des Datenseparators SED 9420C

= 1: Freigeben " " "

Bei der Abfrage des Ports FOH mit Hilfe des Befehls IN 70H erhält man folgende Informationen:

> D7 = 0: Diskettenantriebsmotor ist eingeschaltet = 1: " " ausgeschaltet

> D6 = 1: Der Floppydisc-Controller hat ein weiteres Byte bereit/erwartet eines. Dieses Signal ist nur wichtig, wenn der Datentransfer weder über DMA noch unterbrechungsgesteuert (mit Hilfe einer Serviceroutine) erfolgt.

= 0: jetzt kann der PC, je nach zuvor zum FDC Baustein übertragenem Befehl, ein Byte in das Datenregister des FDC (Adresse F9H) schreiben bzw. von dort lesen. Hierbei handelt es sich um die langsamste Methode um Daten von der Floppydisc zu lesen bzw. zu schreiben.

Ist innerhalb eines Programmes DMA-Betrieb nicht erwünscht, sollte statt des soeben beschriebenen Abfragebetriebes mit Hilfe der Unterbrechungsanforderung EXTINIl gearbeitet werden (siehe Kapitel 5.6, Systembusschnittstelle). Die Unterbrechungsanforderung des FDC ist zur Unterbrechungsebene IR4 des PIC 8259 des PC verdrahtet.

#### M - Verfahren:



#### MFM - Verfahren:



T = Taktpuls

Abb. 7.5

#### 8. Drucker

Zur Verdeutlichung, wie man Drucker an den PC anpaßt, soll beispielhaft an den folgenden 3 Geräten gezeigt werden:

- 1. Gabriele 8008 V 24
- 2. TRD 7020 V 24
- 3. Epson MX 80 FT 3

Die Einstellungen des PC auf die unterschiedlichen Schnittstellenkonfigurationen sind in den Kapiteln 5.3 und 5.5 beschrieben.

Die Triumph-Adler Geräte haben im Lieferumfang ein zum Anschluß geeignetes Kabel, somit treten hier keinerlei Probleme auf.

Bei dem Epson wurde ein Kabel selbst erstellt. Durch die einheitliche Steckerbelegung war dies kein Problem; allerdings stand uns ein Werkzeug zum lötfreien Anschlagen eines Steckverbinders zur Verfügung. Als Kabel wurde ein Flachkabel benutzt, das nur ca. alle 10 cm parallel geführt wird, dieses verringert Verkopplungen zwischen den Datenleitungen erheblich. Falls ein solches Kabel nicht erhältlich ist, sollten für jede Datenleitung zwei Adern verdrillt werden. Eine dieser Leitungen stellt dann die Masseleitung dar und ist an einer Seite mit GND des Steckers zu verbinden. Über diese Leitungen sollte keine Stromversorgung oder Potentialausgleich erfolgen.

#### 8.1 Gabriele 8008 V 24

Die Gabriele 8008 ist eine Typenradschreibmaschine. Mit dem erhältlichen Carbonband liefert sie ein sauberes Schriftbild in Korrespondenzqualität. Durch auswechselbare Typenräder ist zwar der Zeichensatz in weiten Grenzen veränderbar, jedoch ist eine Ausgabe selbst einfacher Graphikelemente nur mit Schreibmaschinencharakter möglich.

Zum problemlosen Anschluß über das mitgelieferte Kabel ist die serielle Schnittstelle (RS 232C) zu benutzen.

#### 8.2 TRD 7020 V24

Mit dem TRD 7020 steht dem Anwender ein Typenraddrucker der jüngsten Generation zur Verfügung. Sein bestechend sauberes Schriftbild ist für sein Haupteinsatzgebiet, der Textverarbeitung, sehr gut geeignet. Großen Anteil an der gleichbleibenden Qualität des Schriftbildes hat das Carbonband. Da es aber nur, je nach Zeichenabstand, zwischen 60.000 und 200.000 Zeichen ( $\hat{z}$  ca' 40 bis 150 Seiten DIN A4) ergibt, ist als preiswerte Alternative ein Nylonband erhältlich. Bei mit zunehmender Beanspruchung etwas nachlassender Qualität des Schriftbildes, gestattet es den Druck von ca. 1 Million Zeichen ( $\hat{z}$  ca. 700 Seiten DIN A4).

Mit 20 Zeichen/Sekunde ist der IRD 7020 über eine durch Befehl abschaltbare Druckwegoptimierung selbst für professionellen Einsatz ausreichend schnell genug. Serienmäßig verfügt er über einen Zwischenspeicher (Buffer; Spooler) für 1500 Zeichen, optionell ist ein Speicher für 3500 Zeichen erhältlich.

Seine Qualitäten sind, neben der Auswechselbarkeit des Schriftbildes durch verschiedene TA Typenräder, in der breiten Palette der in seiner Sofware enthaltenen Möglichkeiten zu finden.

Als Beispiel sei hier nur die Möglichkeit des Blocksatzes angeführt. Damit ist es auch ohne ein Textverarbeitungsprogramm wie z.B. PCTEXT möglich, einen Text ohne "Flatterrand" auszugeben.

Durch seinen serienmäßigen Zwischenspeicher ist es möglich, den Druckbetrieb im "Hintergrund" laufen zu lassen. Das heißt, während der Drucker arbeitet, kann mit dem alphatronic-PC an anderen Problemen gearbeitet werden. Wenn der Speicher bis auf 64 Zeichen geleert ist, wird durch das eine Signalleitung zur Übergabe der nächsten Zeichen aufgefordert.

Durch die Möglichkeit, den Zeilenvorschub in Schritten von 1/96 Zoll (± 0,26 mm), sowie den Zeichenabstand in Schritten von 1/120 Zoll (± 0,21 mm) einstellen zu können, ist eine für Typenraddrucker gute Graphikfähigkeit vorhanden.

Die Zeichenübertragung geschieht serienmäßig nach dem V24-Protokoll mit 4800 Bd entsprechend der Grundeinstellung des PC. Das Übertragungsformat ist jedoch über eingebaute Schalter veränderbar. Optionell sind noch andere Schnittstellen erhältlich.

Nähere Einzelheiten zu den Schnittstellen sowie den Steuerbefehlen entnehmen sie bitte dem Handbuch des TRD 7020.

#### 8.3 EPSON MX 80 FT 3

Als ein weitverbreiteter, preiswerter Nadeldrucker stand der Epson zur Verfügung. Sein Schriftbild ist, obwohl für Hobbyanwendungen ausreichend, dem Typenrad unterlegen.

Seine Vorteile liegen jedoch in der für den Hobbymarkt erforderlichen Vielseitigkeit. Durch die Einzelnadelansteuerung hat er recht gute Graphikmöglichkeiten. Nachfolgemodelle des MX 80 FT3 bieten bereits ein Schriftbild in ausreichender Qualität neben erweiterten Möglichkeiten der Graphik.

Der Anschluß erfolgt über die Centronics kompatible Schnittstelle an den alphatronic-PC. Da die Steckerbelegung des Epson weitgehend dem PC gleicht, ist die Anfertigung eines Kabels unproblematisch (siehe auch hierzu weiter oben).

Die Umstellung des PC auf Druckerausgabe über die Parallelschnittstelle ist in Kapitel 8.5.2, Teil A des Bedienerhandbuches alphatronic-PC beschrieben.

| 9. Stichwortverzeichnis    |   |            |      | Datenbus                  | 10     |
|----------------------------|---|------------|------|---------------------------|--------|
| ye belefinde ever zeremile |   |            |      | Datenbus                  | 10     |
|                            |   |            |      |                           |        |
| Abfragezeit                |   | 39         |      | Datenübertragung          | 43     |
|                            |   | 64         |      | Datenwort                 | 43     |
| Acknowledge (-Leitung)     |   |            |      | Datentransfer             | 115    |
| Adressbereich              |   | 10         |      | Datenseparator            | 129    |
| Adressbus                  |   | 10         | 2    | Datenblätter              | 142    |
| Adressierungsarten         |   | 14, 19     |      | Demodulator               | 61     |
| Alu                        |   | 16         |      | DIR                       | 116    |
| Anschluß (Floppy Disc-)    | 7 | 120        |      | Disketten, hardsektoriert | 123    |
| Anschluß (Drucker-)        |   | 133        |      | Disketten, softsektoriert | 122    |
| Architektur (Z80)          |   | 14         | E 17 | Diskettenbehandlung       | 124    |
| Asynchronbetrieb           |   | 49         | 1    | Disketten, Einteilung     | 128    |
| Attributbyte               |   | 102        |      | DMA - Controller -        | 73     |
| Attribute                  |   | 103        |      | Drucker                   |        |
| Ausgangspegel              |   | 60         | _ 1_ |                           | 133    |
| Adagangapeger              |   | 00         |      | Drucker - Kabel           | 133    |
| Baudrate                   |   | 46, 54     |      | Druckwegoptimierung       | 134    |
| BAS                        |   |            |      |                           |        |
|                            |   | 88, 93     |      | Ein - Ausgabebefehle      | 30     |
| Basiczeile                 |   | 118        | F 17 | Eintrittsprungtabelle     | 113    |
| Befehlssatz Z80            |   | 19         |      |                           |        |
| Befehlstypen               |   | 21         |      | Flagregister              | 22     |
| Befehlsliste               |   | 143, ff    |      | Flags                     | 17     |
| BIOS *                     |   | 115        | _ '  | Floppydisc Controller     | 129    |
| BDOS                       |   | 116        |      | Fm                        | 129    |
| Blocksatz                  |   | 134        | 1 1  | Formatierung              | 122    |
| Blockoperationsbefehl      |   | 23         |      | FSK                       | 58, ff |
| Blocksschaltbild           |   | 11         |      |                           | 20,    |
| Buffer                     |   | 134        | E 73 | Graphik (Drucker)         | 135    |
| Burstclock                 |   | 93         |      | graphik (procker)         | 100    |
|                            |   |            |      | Head Crash                | 106    |
| Cassettenanschluß          |   | 58, 63     |      |                           | 124    |
| CCP                        |   |            |      | Hintergrundbetrieb        | 48     |
| Centronics                 |   | 116        |      | Hintergrundregister       | 17     |
| Character Generator        |   | 64, ff     |      |                           |        |
|                            |   | 12         |      | IC - Tausch               | 9      |
| CP/M                       |   | 115        |      | Impedanz                  | 90     |
| CP/M - Ladeprogramm        |   | 116        | C 7  | Initialisierung           | 56, 62 |
| CRT - Controller           |   | 12, 88, 93 |      | Interleave - Faktor       | 122    |
| Cursor, Definition         |   | 97, ff     |      | Interruptcontroller       | 71, 80 |
| CRT, Register              |   | 96         |      | Interruptmodus            | 26     |
|                            |   |            |      | Interruptroutinen         | 30     |
|                            |   |            |      | I/O Adressen              | 33     |
|                            |   |            |      | IPL (Urlader =)           | 109    |
|                            |   |            |      | 1. 1 (0118001 -)          | 10/    |

|                                                                                                                                                            |     |                                                            | - V |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------------------------------------------------------|-----|
| Keyboard, Austausch<br>Kommandowort                                                                                                                        |     | 7<br>48, ff                                                |     |
| Laufwerke A,B,P<br>Literaturverzeichnis                                                                                                                    | T w | 115<br>168                                                 |     |
| MFM Memory Mapping Mnemonik Modul (ROM-), ROM - Pack Moduswort Monitorprogramm                                                                             |     | 129<br>32<br>143, ff<br>104<br>56<br>109                   |     |
| Nadeldrucker<br>Netzteilplatine                                                                                                                            |     | 135<br>6                                                   |     |
| OP - Code .<br>Operationen                                                                                                                                 |     | 144, ff<br>143, ff                                         |     |
| Parallelschnittstelle Pegel (V.24) PIC Polling Programmierung (V.24) Prioritäten Prioritätslogik                                                           |     | 64<br>43<br>80<br>130<br>48<br>85<br>73                    |     |
| RAM Rechenbefehle Redundanz Reparaturen RCB RDM ROM - Pack                                                                                                 |     | 10<br>22<br>130<br>6<br>88<br>10                           |     |
| Schaltermatrix Schnittstellenbeschreibung Schreibschutz Serielle Schnittstelle Sektoren Sicherungswechsel Signalbelegung Spezial ICS Spooler Sprungbefehle |     | 39<br>35<br>121<br>55<br>121<br>6, 127<br>70<br>141<br>134 |     |
|                                                                                                                                                            |     |                                                            |     |

| Stack Stapelregister Statusport Statusregister Status, Centronics Statuswort Steuerworte Steuersignale Steuerungseinheit Steckverbinder Steckertausch Strobepuls Struktur des USART Synchrone Datenübertragung Synchronisation Sync - Zeichen Systemcheck Systembus System Port | • | 131<br>131<br>68<br>68<br>36<br>53<br>48<br>67<br>129<br>169<br>7<br>64<br>45<br>45<br>50<br>93<br>45<br>109<br>71 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|--------------------------------------------------------------------------------------------------------------------|
| Taktfrequenz Tastaturschnittstelle Tastenadressen Teilungsfaktor Tracks Token Typenraddrucker Typenradschreibmaschine                                                                                                                                                           |   | 14<br>39<br>40<br>51, 54<br>123<br>119<br>134                                                                      |
| Universalregister<br>Unterbrechungsanforderung<br>Unterbrechungsebenen<br>Unterbrechungsvektor<br>Unterprogrammaufruf<br>USART                                                                                                                                                  |   | 16<br>81<br>83<br>87<br>29<br>47, 48                                                                               |

| Verschiebebefehl<br>Video RAM Adressen<br>Video Schnittstelle                                                                  | 24<br>102<br>88                            |
|--------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------|
| Zeichenmatrix Zeichensatzumschaltung Zeichenlänge Zeichengenerator Zeichensynchronisation Zeitablaufdiagramm Zusammenschaltung | 12, 89<br>36<br>62<br>89<br>45<br>61<br>45 |

| 10. | Anhang |
|-----|--------|
|     |        |

# 10.1 Liste der Spezial-IC's des alphatronic-PC

| Bezeichnung                                                           | Hersteller z.B.                                                                     |  |
|-----------------------------------------------------------------------|-------------------------------------------------------------------------------------|--|
| SN 75150<br>SN 75189<br>SN 75154                                      | Texas Instruments Texas Instruments Texas Instruments                               |  |
| uP 494<br>D 8251 C<br>D 780 C - 1<br>D 8257 C - 5                     | NEC<br>NEC, Intel<br>NEC, Zilog (Z 80 A)<br>NEC, Intel<br>NEC (von TA programmiert) |  |
| D 2732 D<br>D 2764 D<br>HD 46505 SP<br>HM 6116 P - 4<br>HM 4864 P - 2 | NEC " Hitachi (= 6845 SP) Hitachi Hitachi                                           |  |

Weiterhin sind im alphatronic-PC diverse IC's der 74 LS-Familie eingebaut. Hersteller dieser IC's sind z.B. Hitachi oder Texas Instruments.

# 10.2 Bezugsquellen für Datenblätter

Soweit die im Text erwähnten Datenbücher keine ISBN-Nummer haben, sind diese nur über den Technik-Fachhandel erhältlich. Einige Fachbuchhandlungen, vornehmlich in Städten mit Hochschulen der Fachrichtungen Elektrotechnik und artverwandt, können allerdings auch Datenbücher besorgen.

Im übrigen wird Ihr Triumph-Adler alphatronic-Fachhändler bei der Beschaffung der Literatur behilflich sein können.

Literatur mit einer ISBN-Nummer wird problemlos von jeder Buchhandlung beschafft.

Ein Literaturverzeichnis ist in Anhang 10.4 aufgeführt.

#### 10.3 Befehlsliste Z 80 A

Die in der nachfolgenden Befehlsliste benutzten Abkürzungen und Kurzzeichen sind, soweit nicht im Kapitel 3 erläutert, wie folgt zu verstehen:

#### 1. In der Spalte Mnemonik:

Das übliche Komma wurde durch einen Punkt dargestellt.

Bei Verwendung der unmittelbaren (Immidiate) Adressierung ist als Platzhalter für ein unmittelbares Byte ein "N" angegeben.

DIS bezeichnet eine relative Sprungweite (siehe Kap. 3).

#### 2. In der Spalte Operation:

Das Zeichen ":=" bedeutet "ergibt sich aus".

Der Buchstabe "C" wird für das Register C sowie für das Carrybit benutzt. Seine Bedeutung ist aus der Mnemonik ersichtlich.

Das Zeichen "^" bedeutet "logisch UND verknüpft mit".

Überstrichene Zeichen stellen die logische Negation dar.

Bei den Bitmanipulationsbefehlen wurden die Bitnummern nicht als Index geschrieben.

Das Zeichen "<>" bedeutet "ausgetauscht mit".

Der Bezeichnung von 16 Bitregistern folgt manchmal ein h oder 1; h bezeichnet das höherwertige Byte des Wortes, 1 das niederwertige.

Das Zeichen "e" bedeutet "EXKLUSIV ODER verknüpft mit".

# 3. In der Spalte Flags:

B: Flag wurde von der Operation beeinflußt

U: Flag wurde nicht beeinflußt

X: Flag ist nicht definiert

0: Flag wurde zurückgesetzt

1: Flag wurde gesetzt

4. In der Spalte OP-Code steht der sedezimale Maschinencode des jeweiligen Befehles; nn und dis sind Platzhalter für unmittelbare Daten.

| - '7   | M 82 11       |                 |             |           |
|--------|---------------|-----------------|-------------|-----------|
|        | Mnemanik<br>• | Operation       |             | OF - Code |
|        |               |                 | SIHPNC      |           |
| - '7   |               |                 |             |           |
|        |               |                 |             |           |
|        | ADC A. (HL)   | A := A+(HL)+C   | 888888      | 8E        |
| - 'T   | ADC A. (IX+d) | A := A+(IX+d)+C | 888888      | DD 8E 05  |
|        | ADC A. (IY+d) | A t= A+(IY+d)+C | 8 8 8 8 8 8 | FD 8E 05  |
|        | ADC A.A       | A I= A+A+C      | 888888      | 8F        |
| - '7   | ADC A.B       | A := A+B+C      | B B B B B B | 88        |
|        | ADC A.C       | A := A+C+C      | 888888      | 89        |
|        | ADC A.D       | A := A+D+C      | B           | BA        |
| - '7   | ADC A.E       | A := A+E+C      | 8 8 8 8 8 8 | 89        |
|        | ADC A.H       | A := A+H+C      | 888888      | BC        |
|        | ADC A.L       | A t= A+L+C      | 8 8 8 8 8 8 | 80        |
| - '7   | ADC A.N       | A := A+N+C      | 8 8 8 8 8 8 | CE an     |
|        | ADC HL.RC     | HL := HL+BC+C   | B B X B 1 B | ED 4A     |
|        | ADC HL.DE     | HL := HL+DE+C   | B B X B 1 B | ED SA     |
| - 15 7 | ADC HL.HL     | HL := HL+HL+C   | B B X B 1 B | ED 6A     |
|        | ADC HL.SP     | HL := HL+SF+C   | B B X B 1 B | ED 7A     |
|        | ADD A. (HL)   | A = A+(HL)      | B B B B O B | 96        |
| - ' 7  | ADD A. (IX+d) | A := A+(IX+d)   | B B B B O B | DD 86 05  |
|        | ADD A. (IY+d) | A := A+(IY+d)   | B B B B O B | FD 86 05  |
|        | ADD A.A       | A t= A+A        | вввов       | 87        |
| - 17   | ADD A.B       | A := A+B        | B B B B O B | 80        |
|        | ADD A.C       | A I= A+C        | BBBBOB      | 81        |
|        | ADD A.D       | ^ 1= ^+D        | 898908      | 82        |
| · ' ¬  | ADD A.E       | A := A+E        | 808868      | 83        |
|        | ADD A.H       | A := A+H        | 8 9 8 8 0 9 | 84        |
|        | ADD A.L       | A 1= AIL        | врввов      | 85        |
| · " ]  | ODD A.N       | Λ := Λ+N        | B B B B Q B | C6 nn     |
|        | ADD HL.BC     | HL := HL+DC     | xxuxop      | Ú.A.      |
|        | ADD HL.DE     | HL := HL+DE     | ххихов      | 19        |
|        | ADD HL.HL     | }n_             | xxuxop      | 29        |
|        | ADD HL.SF     | HL := HL+SP     | x x u x o p | 39        |
|        | ADD IX.DC     | IX := IX+BC     | xxuxop      | DD 09     |
| 7      |               |                 |             |           |

# 10.4 Literaturverzeichnis

Das große alphatronic Basic-Buch, ISBN Nr. 3-923250-00-2

B. u. N. Bollow

Basic Interpreter, ISBN Nr. 3-7723-6941-3

R.D. Klein

Technical Manual Z80 Zilog Nr. 03-002-01

Zilog

Mikroprozessor Interface Techniken, ISBN Nr. 3-922187-00-5

R. Zaks u. A. Lesea

MCS-80 User's Manual, Intel Nr. 98-153D

Intel

Service Manual alphatronic-PC,

Triumph-Adler

Systemhandbuch alphatronic Micro P3/P4

Triumph-Adler

Bedienerhandbuch und BASIC-Interpreter, alphatronic PC

Triumph-Adler

Bedienerhandbuch für Diskettenlaufwerk und Disk-BASIC-Diskette (Re 5.26), alphatronic PC

Triumph-Adler

CP/M Handbuch, alphatronic PC

Triumph-Adler

DIN 66020 (9 CCITT V24)

Hitachi Microcomputer Data Book, Hitachi Nr. D-06-83-8.MP

Hitachi

NEC Product Catalog '82,

NEC

Programmierung des Mikrorechners alphatronic

Prof. Dipl.-Ing. E. Baeger

Programmierung des Z80, ISBN Nr. 3-88745-006-X

R. Zaks



#### 10.5 Steckverbinder

Nachfolgend ist eine Liste der am alphatronic-PC verwendbaren Steckverbinder aufgeführt.

Die Steckverbinder sind über den Fachhandel erhältlich.

| Anschluß                   | Steckertyp                                                               |
|----------------------------|--------------------------------------------------------------------------|
| BAS                        | Cynchstecker                                                             |
| RGB                        | 8 polig, Steckeranordnung nach DIN 45326                                 |
| Cassette                   | 8 polig, " " " " z.B. Hirschmann: MAS 80 SN                              |
| Systembus                  | 50 polig, ähnlich 3M: 3425-6650-7650 oder ITT Cannon: GO8-D50 A3BKAA-075 |
| Parallel-<br>schnittstelle | 34 polig, z.B. 3M: 3425-6634-7634<br>oder ITT Cannon: GO8-D34 A3KAA-075  |
| V24                        | 25 polig, ITT Cannon: D - SUB DE 25 P                                    |
| Netz                       | 3 polig, entsprechend DIN 49457 bzw. 49458                               |

#### 10.6 ESCAPE-Sequenzen

ESCAPE-Sequenzen werden gebildet durch Senden des ESCAPE-Zeichens (CHR\$ (27) ) und eines oder mehrerer Zeichen.

Zur Vollständigkeit werden eine Reihe von Kontroll-Codes hier aufgeführt, die ohne vorangestellten ESCAPE-Code arbeiten.

Die mit \* gekennzeichneten Sequenzen sind DEC VT 52 kompatibel.

| Steuerzeichen | Bedeutung                                                                                                                                                                                                                                                                                                                          |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 07            | Warnton (BEL)<br>Bei PRINT CHR\$ (7) ertönt für 1/2 Sek. ein<br>Warnton.                                                                                                                                                                                                                                                           |
| 08            | Backspace (BS = Rücktaste)  Der Cursor wird um 1 Stelle nach links verschoben. Wenn der Beginn der Zeile erreicht ist, wird der Cursor auf die vorhergehende Zeile, letzte Position gebracht.  Ist der Cursor in Home-Stellung, ist die nächste Position letzte Zeile, letzte Position.                                            |
| 10            | Line feed (LF = Zeilenschaltung) Der Cursor wird um eine Zeile nach unten verschoben. Wird dieser Befehl auf der letzten Zeile gegeben, wird der Inhalt des Bild- schirms um eine Zeile nach oben geschoben und eine neue (Leer-)Zeile eingefügt. Um dies zu verhindern, sollte die "Cursor Down" -Sequenz (27,66) benutzt werden. |
| 12            | Bildschirm löschen (FF) Der Bildschirm-Controller wird aktiviert und die Bildschirm-Initialisierung (siehe 27,12,xx) abgeschaltet. Cursor wird einge- schaltet, in die linke obere Ecke gebracht und der Inhalt des Bildschirms gelöscht.                                                                                          |
| 13            | Neue Zeile (CR) Der Cursor wird auf den Anfang der nächsten Zeile gebracht. Ein unmittelbar folgender Befehl CHR\$ (10) wird nicht ausgeführt.                                                                                                                                                                                     |
| 18            | Invers-Darstellung aus                                                                                                                                                                                                                                                                                                             |
| 28            | Invers-Darstellung ein                                                                                                                                                                                                                                                                                                             |



Sequenz Bedeutuna

27,9 Anwenderdefinierte Tastaturtabelle anhängen Die Startadresse der Anwendertabelle muß in Re-

qister < DE > stehen, das durch eine Assembler-

Routine zu laden ist.

27,12,xx Initialisieren Bildschirm

> Das Byte xx wird analysiert und die einzelnen Bits steuern folgendes:

Bit 0: 0 = Bildschirm "Scroll" aus. d.h. nach dem Schreiben der letzten Bildschirmposition wird bei der Home-Position weitergeschrieben.

> l = Bildschirm "rollt", wenn die letzte Position auf dem Bildschirm geschrieben wird -- > (3a)d.h. Zeilen werden nach oben verschoben, Zeile 1 verschwindet (Scroll-Modus)

Bit 2: 0 = CTRL-Taste gibt den Code 7FH ab.

1 = bei Betätigung der CTRL-Taste wird eine interne Verarbeitung wirksam: der Wert der gleichzeitig gedrückten Taste wird (vermindert um 40H) abgegeben, d.h. z.B. CTRL+C ergibt 03H.

Bit 3: 0 = keine Funktion

1 = die Taste < C > gibt den Code 84H ab und führt gleichzeitig CI aus (Console Input)

0 = Gleiche Farbe für Vorder- und Hintergrund ist nicht erlaubt (she. Sequenz 27,84).

> 1 = Gleiche Farbe für Vorder- und Hintergrund erlaubt.

Bit 7: 0 = Bildschirm wird gelöscht.

1 = Bildschirm nicht löschen.

27, 16, n n Leerstellen schreiben

> Beispiel: PRINT CHR\$ (27) + CHR\$ (16) + CHR\$ (20) Achtung: CHR\$ (8) + CHR\$ (9) führen zu falschen Ergebnissen.

|   |                     | - 172 -                                                                                                                                                                                                                                                                                   |
|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|   |                     |                                                                                                                                                                                                                                                                                           |
|   | Sequenz             | Bedeutung                                                                                                                                                                                                                                                                                 |
|   | 27,17 oder<br>27,72 | Cursor home Cursor in die Position oben links bringen                                                                                                                                                                                                                                     |
|   | 27,18               | Cursor ausschalten                                                                                                                                                                                                                                                                        |
|   | 27,19               | Cursor einschalten                                                                                                                                                                                                                                                                        |
|   | 27,22,yy,xx         | Cursor auf Position xx,yy stellen                                                                                                                                                                                                                                                         |
|   |                     | Beispiel: PRINT CHR\$ (27) + CHR\$ (22) + CHR\$ (2)<br>+ CHR\$ (10)<br>Cursor auf 2. Zeile Position 11 stellen                                                                                                                                                                            |
|   |                     | Für die Zeilen 8 und 9 besser mit 27,89 und Offset arbeiten!                                                                                                                                                                                                                              |
|   | 27,23               | Cursorposition feststellen                                                                                                                                                                                                                                                                |
|   |                     | Die augenblickliche Cursorposition wird an das Register $<$ DE $>$ gegeben. Der Wert wird Die Zeilenposition steht in $<$ D $>$ , die Spaltenposition in $<$ E $>$ (Auswertung durch Assembler-Routine). Die Übergabe erfolgt, nachdem CO mit 17H im Register $<$ C $>$ aufgerufen wurde. |
|   | 27,24               | Zeichen an aktueller Cursorposition schreiben                                                                                                                                                                                                                                             |
|   |                     | Das in Register < E > stehende Zeichen wird an die aktuelle Cursorposition geschrieben (nur im Assembler-Routinen).                                                                                                                                                                       |
| * | 27,25 oder<br>27,75 | Löschen bis Ende der Zeile (Cursor bleibt auf der jetzigen Position)                                                                                                                                                                                                                      |
|   |                     | Beispiel: PRINT CHR\$ (27) + CHR\$ (25)                                                                                                                                                                                                                                                   |
| * | 27,26 oder<br>27,67 | Cursor um eine Stelle nach rechts                                                                                                                                                                                                                                                         |
|   | 27,28               | Zeichen von aktueller Cursorposition lesen                                                                                                                                                                                                                                                |
|   |                     | Das Zeichen an der aktuellen Cursorposition wird<br>nach Register < E > gebracht. Die Cursorposition<br>wird um l nach rechts geschoben. Wenn die letzte<br>Zeile, letzte Position erreicht wird, bleibt die<br>Cursorposition unverändert.                                               |
|   | 27,29,n,x           | n mal Zeichen "x" schreiben                                                                                                                                                                                                                                                               |
|   |                     | Beispiel: PRINT CHR\$ (27) + CHR\$ (29) + CHR\$ (10)<br>+ "a" = 10 x "a" schreiben                                                                                                                                                                                                        |
| * | 27,49               | Graphik-Mode einschalten                                                                                                                                                                                                                                                                  |
| # | 27,50               | Graphik-Mode ausschalten                                                                                                                                                                                                                                                                  |
|   |                     |                                                                                                                                                                                                                                                                                           |

| 7              |                                                                                                                                    |                                                                                                                                                                                                              |
|----------------|------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5equ           | nz Bedeutung                                                                                                                       | ta ta                                                                                                                                                                                                        |
| * 27,6         | Cursor um eine Zeile na                                                                                                            | ach oben stellen                                                                                                                                                                                             |
| * 27,6         | Cursor um eine Zeile na                                                                                                            | ach unten stellen                                                                                                                                                                                            |
| 27,2<br>* 27,6 | oder <u>Cursor um eine Stelle</u>                                                                                                  | nach rechts                                                                                                                                                                                                  |
| * 27,6         | Cursor um eine Stelle n                                                                                                            | nach links                                                                                                                                                                                                   |
| * 27,6         | Bildschirm löschen, Cur<br>Position 1 gestellt                                                                                     | rsor wird auf Zeile 1,                                                                                                                                                                                       |
| * 27,7         | Zeile löschen                                                                                                                      |                                                                                                                                                                                                              |
|                | Die Zeile, in welcher s<br>wird gelöscht. Der Curs<br>sition.                                                                      | eich der Cursor befindet,<br>For bleibt auf seiner Po-                                                                                                                                                       |
| * 27,7         | tion wird gelöscht, der<br>sition xx wird um eine                                                                                  | Rest der Zeile bis zur Po-<br>Stelle nach links gescho-<br>xx eine Leerstelle einge-                                                                                                                         |
|                | Beispiel: START 1 wird                                                                                                             | TART 1                                                                                                                                                                                                       |
| 27,20          | Zeichen an augenblickli<br>ben                                                                                                     | cher Cursorposition schrei-                                                                                                                                                                                  |
|                | blicklichen Cursorposit<br>gabe erfolgt, wenn die<br>gister < C > aufgerufen<br>de Zeichen wird dabei n<br>gewertet. Ist die letzt | <pre>&lt; E &gt; wird an der augen- ion geschrieben. Die Über- Routine CO mit 19H in Re- wird. Das in &lt; E &gt; stehen- icht als Steuerzeichen aus- e Position auf dem Bild- ie Cursorposition nicht</pre> |
| * 27,75        | Leerstelle eingeschoben<br>zur Position xx werden                                                                                  | Cursorposition wird eine , und alle Zeichen bis um eine Stelle nach rechts Zeichen (an Position xx)                                                                                                          |
| 17             | Beispiel: START 1 wird                                                                                                             | START                                                                                                                                                                                                        |
| * 27,74        | Bildschirm ab Cursorpos                                                                                                            | ition löschen                                                                                                                                                                                                |
| 27,25          |                                                                                                                                    | ile (Cursor bleibt auf der                                                                                                                                                                                   |
|                | Beispiel: PRINT CHR\$ (2                                                                                                           | 7) + CHR\$ (25)                                                                                                                                                                                              |
| L              |                                                                                                                                    |                                                                                                                                                                                                              |

# Systemhandbuch Anhang 3

# Setzen verschiedener CURSOR-Attribute

Durch Umprogrammieren des CRT-Controllers lassen sich andere Cursor-Attribute erreichen.

| Cursor an                | OUT | &H50,&H0C | OUT | &H51,&H40 |
|--------------------------|-----|-----------|-----|-----------|
| Cursor aus               | OUT | &H50,&HOC | OUT | &H51,&H08 |
| Viereck                  | OUT | &H50,&HA: | OUT | &H51,&HO  |
| Viereck schnell blinkend | OUT | &H50,&HA: | OUT | &H51,&H40 |
| Viereck langsam blinkend | OUT | &H50,&HA: | DUT | &H51,&H60 |
| Strick schnell blinkend  | OUT | &H50,&HA: | OUT | &H51,&H49 |
| Strick langsam blinkend  | OUT | &H50,&HA: | OUT | &H51,&H69 |



Die Sondertasten des PC liefern unter CP/M einen anderen Code als z.B. bei Verwendung im Rom-Pack.

Die folgende Aufstellung gibt die entsprechenden Codes an:

|          |      | Code | unter |           |
|----------|------|------|-------|-----------|
| Taste    | CP/M |      |       | Prom-Pack |
|          |      |      |       |           |
| F1       | 85   |      |       | 81        |
| F2       | 86   |      |       | 82        |
| F3       | 87   |      |       | 83        |
| F4       | 88   |      |       | 84        |
| F5       | 8A   |      |       | 85        |
| F6       | 8C   |      |       | 86        |
| = S F1   | 90   |      |       | 87        |
| S F2     | 91   |      |       | 88        |
| S F3     | 92   |      |       | 89        |
| S F4     | 93   |      |       | 8A        |
| S F5     | 94   |      |       | 88        |
| 5 F6     | 80   |      |       | 8C        |
| >        | 82   |      |       | 10        |
| <        | 8    |      |       | 1D        |
| ESC      | 1B   |      |       | 1B        |
| S>       | EF   |      |       | EF        |
| S <      | EE   |      |       | EE        |
| BREAK    | 03   |      |       | 03        |
| GRAPH    | DF   |      |       | DF        |
| CLR      | 8F   |      |       | 08        |
| S CLR    | OC   |      |       | OC        |
| DEL      | 96   |      |       | 7F        |
| S DEL    | OC   |      |       | OC        |
| +        | 8B   |      |       | 1F        |
| <b>†</b> | 2 89 |      |       | 1E        |
| s ↓      | EC   |      |       | EC        |
| 5 🕇      | a ED |      |       | ED        |

#### Anmerkung:

S F1 bedeutet: SHIFT und F1

# INHALTSVERZEICHNIS

- 1 alphatronic PC
- 2 Minifloppy-Controller
- 3 Minifloppy-Laufwerk PC



# INHALTSVERZEICHNIS

| 1      | alphatronic PC                                     |
|--------|----------------------------------------------------|
| 1.1    | PC - Konfiguration                                 |
| 1.2    | Speicherorganisation                               |
| 1.3    | Monitorprogramm                                    |
| 1.4    | RESET - Logik                                      |
| 1.5    | System-Control-Signal                              |
| 1.6    | Der DMA - Controller                               |
| 1.7    | Der Interrupt - Controller                         |
| 1.8    | Speicherzuordnung                                  |
| 1.9    | Dynamische RAMs                                    |
| 1.9.1  | Refresh - Steuerung                                |
| 1.10   | Tastator - Logik                                   |
| 1.10.1 | Aufbau der Tastatur                                |
| 1.11   | Serielle Schnittstelle (RS 232 C)                  |
| 1.11.1 | Baudrate - Generator                               |
| 1.12   | Parallel - Schnittstelle                           |
| 1.13   | Kassettenrecorder - Schnittstelle                  |
| 1.13.1 | Technischer Ablauf (Kassettenrecorder)             |
| 1.13.2 | Lesen von Kassette                                 |
| 1.13.3 | Pin - Belegung der Kassettenrecorder-Schnittstelle |
| 1.14   | Bildschirmsteuerung                                |
| 1.14.1 | CRT - Controller                                   |
| 1.14.2 | Ansteuerung von Video- bzw. Attribut - RAM         |
| 1.14.3 | Der Zeichengenerator                               |
| 1.14.4 | Der Taktgenerator                                  |
| 1.14.5 | BAS - Ausgang                                      |
| 1.14.6 | RGB - Ausgang                                      |
| 1.14.7 | Steckerbelegung RGB                                |
| 1.15   | I/O Schnittstelle                                  |
| 1.15.1 | Steckerbelegung I/O - Schnittstelle                |
| 1.16   | DIP - Schalter - Funktion                          |
| 1.17   | ROM - Back - Schnittstelle                         |
| 1.18   | Liste der I/O - Adressen                           |
| 1.19   | Das Netzteil des PC                                |
| 1.20   | Schaltungsunterlagen PC                            |

| 2   | Der Floppy - Controller                    |
|-----|--------------------------------------------|
| 2.1 | FDC / uPD - 765 A (LSI-Baustein)           |
| 2.2 | SED - 9420 C (Datenseparator)              |
| 2.3 | Blockschaltbild - Floppy - Controller      |
| 2.4 | Schaltungsunterlagen - Floppy - Controller |
|     |                                            |
|     |                                            |
| 3   | Das Minifloppy – Laufwerk                  |
| 3.1 | Beschreibung der Testpunkte                |
| 3.2 | Einstellvorschrift                         |
| 3.3 | Bestückungs- und Schaltungsunterlagen      |

# 1.1 PC-Konfiguration

# Zentraleinheit:

- Z 80, 4 MHz
- integriertes Netzteil

#### Anwenderspeicher:

- 64 KB RAM, frei verfügbar
- zusätzlich 32 KB ROM (davon 24 KB BASIC-INTERPRETER)

# Kassetten-Steckmodul:

- für Spiele und Lern-Software

#### Schnittstellen:

- Kansas City I/O für Kassetten-Recorder
- Centronics für Drucker
- RS 232 C
- BUS I/O für Floppy-Disk (oder spätere mögliche Erweiterungen)

### Tastatur:

- alphanumerische Tastatur nach DIN 2137

#### Bildschirm:

- Bildschirmsteuerung durch CRT-Controller
- variables Bildschirmformat: 80x24

80×16

40×24

40×16

#### Bildschirm-Möglichkeiten:

- s/w Monitor
- Farb-Monitor (RGB-Ausgang)
- Fernsehgerät über HF-Modulator

# Floppy-Disk:

- Anschluß von zwei  $5^{1}/4$  " Laufwerken
- Kapazität pro Disk: 320 KB

#### Besondere Merkmale:

- CP/M-fähig mit Floppy-Disk-Einheit
- Semi-Grafik: Monitor 160x72
  - Fernsehgerät 80x70
- 8 Farben: jeweils 8 Vorder- und 8 Hintergrundfarben
- Microsoft-Interpreter V3.01











BILD 5



Steckmodul: Die Abdeckkappe wird in Pfeilrichtung abgezogen.



Nach Einführen des Steckmodul ist für den Programmladevorgang die RESET-Taste an der Rückseite des PC zu betätigen.



# Systemkonfiguration:





# 1.2 Speicherorganisation





# 1.3 Monitorprogramm

Stellen Sie die Bildschirmbreite auf 80 Zeichen je Zeile ein, bevor Sie das Monitorprogramm aufrufen. Dafür steht Ihnen das WIDTH-Kommando zur Verfügung.

Der Aufruf des Monitorprogramms geschieht folgendermaßen:

MON

RETRUN-Taste

Das Monitorprogramm meldet sich auf dem Bildschirm mit der Frage "Memory area?". Als Antwort erwartet er die höchste Speicheradresse, die benutzt werden darf. Falls Sie keine Speicherbegrenzung wünschen, betätigen Sie einfach die RETURN-Taste.

\* MONITOR \* (V.1.2.) June 1983

Memory area?

RETURN-Taste

Das  $\star$  - Zeichen sagt Ihnen, daß das Monitorprogramm bereit ist, Befehle entgegen zu nehmen.

# Befehlsvorrat des Monitorprogramms

Im Monitor gibt es fünf Befehlsarten:

| Befehl | Bedeutung       |                   |
|--------|-----------------|-------------------|
| D      | Speicherinhalte | ausgeben          |
| G      | Sprunganweisung |                   |
| C      | Speicherinhalte | ändern            |
| M      | Speicherinhalte | verschieben       |
| R      | Registerinhalte | ausgeben          |
| E      | Rückkehr in den | BASIC-Interpreter |

# Speicherinhalte ausgeben (D)

Dieses Kommando wird benötigt, um Speicherinhalte in hexadezimaler Form anzuzeigen. Die D-Anweisung hat folgendes Format:

| D | xxxx , yyyy | RETURN-Taste              |
|---|-------------|---------------------------|
|   | xxxx        | Anfangsadr. (hexadezimal) |
|   | VVVV        | Fodadr. (hexadezimal)     |

# Beispiel:

\* D COOO, COOF RETURN-Taste

# Sprunganweisung (G)

Die Sprunganweisung hat folgendes Format:

Nach Betätigen der RETURN-Taste wird ein Sprung an die Stelle xxxx des Arbeitsspeichers durchgeführt.

# Speicherinhalte ändern (C)

Die C-Anweisung hat folgendes Format:

```
C xxxx RETURN-Taste xxxx .... Speicheradr.
```

#### Beispiel:

```
* C BF01
BF01 00 -
```

Nach Betätigen der RETURN-Taste wird der Inhalt der Speicherzelle BFOl angezeigt. Soll der Speicherinhalt geändert werden, so müssen zwei Hexadezimalziffern eingegeben werden (OO-FF). Durch Drücken der Leertaste wird die Eingabe abgeschlossen. Der Inhalt der nächsten Speicherzelle wird angezeigt. Beendet wird die C-Anweisung durch Eingabe eines Zeichens, das weder O-9, noch A-F noch Leertaste ist.

# Speicherinhalte verschieben (M)

Die M-Anweisung hat folgendes Format:

```
M ssss , eeee , nnnn RETURN-Taste ssss ..... Anfangsadr. des Speicherbereichs eeee ..... Endadr. des Speicherbereichs nnnn ..... Zieladr.
```

#### Beispiel:

```
* E000, E0FF, C000 RETURN Taste completed
```

# Registerinhalte ausgeben (R)

Die R-Anweisung hat folgendes Format:

R

Beispiel:

R
PC B C D E H L A F I IX IY
0000 00 00 00 00 00 00 00 00 00000

Die hier angezeigten Register mit ihren Inhalten sind die aktiven Register. Die inaktiven Register des Z 80 werden nicht angezeigt.



# 1.4 RESET-Logik

Der alphatronic PC verfügt über zwei RESET-Signale. Das erste RESET-Signal wird ausgelöst durch Einschalten der alphatronic (Power on).

Die Verzögerungszeit beträgt 800 msec.

Das zweite RESET-Signal wird aktiv durch Betätigen der RESET-Taste (schwarzer Taster an der Rückwand des PC's).





#### 1.5 System-Control-Signal

Die Erzeugung der Control-Signale erfolgt über die beiden IC (51 und 41).

Folgende Signale stehen zur Verfügung:

- MREQEX - = Memory-Request-Signal

- IOREQEX - = Input-Output-Request-Signal - RDEX -= Read-Data-Signal-Extern - WDEX -= Write-Data-Signal-Extern

- MEMR -= Memory-Read - MEMW -= Memory-Write - IOR -= I/O-Read

- IOW -

= I/O-Write - SIOREX - = Read Data vom I/O BUS - SIOWEX - = Write Data zum I/O BUS

- MREQ -= Memory-Request - IORQ -= I/O-Request





#### 1.6 Der DMA - Controller

Der in der alphatronic PC eingesetzte µPDM 8257 (IC 102) ist ein 4-Kanal Controller für direkten Speicherzugriff. Er vereinfacht die Datenübertragung bei hoher Geschwindigkeit für das Z80 CPU-System. Seine vorrangige Funktion besteht darin, bei einem Peripherie-Request (in alphatronic PC: der FDU) eine sequentielle Speicheradresse zu generieren, die der Peripherie ermöglicht, Daten direkt aus dem oder in den Speicher zu lesen oder zu schreiben. Dies erfolgt über die Hold-Funktion des Z80: Der M8257 besitzt eine Priority-Logik, die die Peripherie-Requests auflöst und auf der anderen Seite ein Hold-Request zum Z80 ausführt.

Die bereits in Sektion III beschriebene I/O Geräte-Adresse beträgt 6xH. Die Register des DMA-Kanals 2 werden von der externen Floppy-Disk-Einheit benötigt.

Das -CS-Signal wird ausgelöst vom -57SEL-Signal. Der Z80 Hold-Status erfolgt über -BUSAK- von Z80 bis Hold des DMA und HRQ des DMA bis Z80 -BUSRQ-Signal. Das 16-Bit-Register des Kanals 2 beinhaltet die Ladeadresse des Speichers, in der alphatronic PC ist das die Adresse C200, die Daten von oder zu der FD-Einheit überträgt.



# 1.7 Der Interrupt Controller PIC μPD 8259

Der  $\mu PD$  8259 programmierbare Interrupt Controller bedient bis zu acht Vectored-Priority-Interrupts für die CPU. Er ist ausbaufähig bis zu 64 Vectored-Priority-Interrupts ohne zusätzliche Schaltung. Die  $\mu PD$  8259 Schaltung ist statisch und benötigt kein Clock-Input.

Der  $\mu$ PD 8259 wird von der Monitor-Software initialisiert. Die I/O-Geräte-Adresse beträgt 7XH, um den Modus und die Interrupt-Vector-Adresse zu bestimmen. Für jedes Interrupt ist das Call-Address-Intervall von 4 bestimmt, das bedeutet, für jeden Vector stehen 4 Bytes zur Verfügung. Der Vector-Adreßbereich beginnt bei EFOO; es werden 8x4=32 Bytes benötigt.

In der alphatronic PC wird kein Interrupt-Vector verwendet. Falls Sie den PIC verwenden möchten, muß der Inhalt im Vector-Adreßbereich geändert werden. Um die Funktion des PIC  $\mu$ PD 8259 zu überprüfen, gehen Sie mit dem Monitor-Befehl in die folgende Routine:

- \* c E700 (interrupt level 0) 3E 20 DB 70 CB
- \* c 8000 (Programmbeginn) 3E FE D3 71 FB 76

Die Memonic lautet:

| ORG EFOO                 | ORG 8000                                                                                                |
|--------------------------|---------------------------------------------------------------------------------------------------------|
| LD A, 20<br>IN 70<br>RET | LD A, FE; Contents Mask Reset<br>OUT 71 ; Contents zum 8259<br>EI ; Enable Interrupt<br>HALT ; Z80 Hold |



# 1.8 Speicherzuordnung

Die Speicherzuordnung sieht wie folgt aus:

|                       |       |    | Adresse           |    |
|-----------------------|-------|----|-------------------|----|
| ROM-BASIC-Interpreter | BASIC | I  | 0000 - 1FF        | FΗ |
|                       | BASIC | II | 2000 - 3FF        | FΗ |
|                       | BASIC | II | 4000 <b>-</b> 5FF | FΗ |
| MONITOR-ROM           |       |    | F000 - FFF        | FΗ |
| ROM-BACK I            |       |    | A000 - BFF        |    |
| ROM-BACK II           |       |    | C000 - DFF        |    |
| Dynamische RAMs       |       |    | 0000 - FFF        | FН |
| Video u. Attribut-RAM |       |    | F000 - FFF        |    |

Über den Memory Decoder IC 34 (74LS13) erfolgt die Selectierung der einzelnen ROMs.

Der Speicherbereich von FOOO - FFFF wird belegt vom Monitor-ROM oder vom Video-RAM.

Welches jetzt aktiv ist, ist abhängig von dem Signal MONINH (Monitor - Inhibit).

High Level : Monitor ROM selected
Low Level : Video RAM selected

Die Selectierung für ROM-BACK I und ROM-BACK II erfolgt über IC 34 (Pin 10 und 9). Über das Signal -ROMPE- (ROM-BACK-ENABLE) erfolgt die Lesefreigabe für den IC-Baustein (IC 16).



# 1.9 Dynamische RAMs

Wie das Schaltbild zeigt, besteht die Speicherlogik aus 8 dyn. RAM-Bausteinen vom Typ 4164.

Die 16 Bit breite Adresse wird über die beiden Multiplexer IC 68 und IC 69 (74 LS 157) gemultiplext. Die Adressierung der 8 RAM-Bausteine erfolgt durch die gemultiplexten Adressen.

Die Datenausgabe von den RAM-Bausteinen zum alphatronic-BUS erfolgt über den Transceiver-Baustein IC 70 (74 LS 245). Das Signal - MEMR - liefert die Freigabe.

# 1.9.1 Refresh - Steuerung ( - RFSH - / - MREQ - )

Das Ausgangssignal - RFSH -, das low-aktiv ist, zeigt an, daß die unteren 7 Bits des Adreßbusses eine Refresh-Adresse für dynamische Speicher beinhaltet.

Das Signal - MREQ - wird benutzt, um ein Refresh-Lesen aller dynamischer Speicher durchzuführen.

#### 1.10 Tastatur - Logik

Der alphatronic PC besitzt als Eingabe eine mechanische Tastatur. Die Tastatur ist über ein Kabel mit der Logik-Platte verbunden. Folgende Leitungen stellen die entsprechenden Verbindungen her:

| SC | 0  |  | RT | 0 |   | - SLED |   |
|----|----|--|----|---|---|--------|---|
| SC | 1  |  | RT | 1 |   | - GLED | _ |
| SC | 2  |  | RT | 2 | 7 |        |   |
| SC | 3  |  | RT | 3 |   |        |   |
| SC | 4  |  | RT | 4 |   | GND    |   |
| SC | 5  |  | RT | 5 |   | VCC    |   |
| SC | 6  |  | RT | 6 |   |        |   |
| SC | 7  |  | RT | 7 |   |        |   |
| SC | 8  |  |    |   |   |        |   |
| SC | 9  |  |    |   |   |        |   |
| SC | 10 |  |    |   |   |        |   |
| SC | 11 |  |    |   |   |        |   |
|    |    |  |    |   |   |        |   |

#### 1.10.1 Aufbau der Tastatur

Das Tastenfeld der alphatronic ist eine Schaltermatrix und besteht aus 12 Reihen und 8 Spalten. Daraus ergibt sich die maximale Anzahl von 96 Tasten. Wird eine Taste gedrückt, stellt das Tastenelement eine Verbindung zwischen einer Reihe und Spalte her.

Die Abfrage, ob eine Taste gedrückt wurde, erfolgt über den IC-Baustein 59 (74 LS 159). Die Abfragezeit (scan-time) beträgt 10 msec.

Das Einlesen des Tastatur-Status erfolgt über den IC-Baustein 47 (74 LS 240). Siehe Zeichnung 1.







# 1.11 Serielle Schnittstelle (RS 232 C)

Die serielle Schnittstelle ist durch den Baustein 8251 A realisiert. Die Übertragung geschieht seriell mit der eingestellten Baudrate von 4800 Baud, 8 Bits, 1 Start-, 2 Stopbits und no Parity. Der USART-Baustein 8251 A ist aber frei programmierbar und kann vom Anwender programmiert werden. Wie dieses zu



| <u>Pin</u> | Signal | Bedeutung           |
|------------|--------|---------------------|
| 1          |        | Nicht belegt        |
| 2          | TXD    | Transmitted Data    |
| 3          | R×D    | Received Data       |
| 4          | RTS    | Request to Send     |
| 5          | CTS    | Clear to Send       |
| 6          | DSR    | Data Set Ready      |
| 7          | GND    | Signal Ground       |
| 8          | DCD    | Data Carrier Detect |
| 9-14       | NC     | Nicht belegt        |
| 15         | TxC    | Transmitted Clock   |
| 16         | NC     | Nicht belegt        |
| 17         | R×C    | Receiver Clock      |
| 18-19      | NC     | Nicht belegt        |
| 20         | DTR    | Data Terminal Ready |
| 21-25      | NC     | Nicht belegt        |

#### 1.11.1 Baudrate - Generator

Die Software kann nur in bestimmten Grenzen (d.h. durch Programmierung des USART) den 8251 A beeinflussen. Um aber jetzt in weiteren Grenzen einzustellen, ist es möglich, über Steckbrücken die Baud-Rate zu verändern. Die Baudrate für den USART kann dann von 300 Baud bis 9600 Baud eingestellt werden.



IC 39 / Pin 10 = 300 Baud
IC 39 / Pin 11 = 600 Baud
IC 39 / Pin 6 = 1200 Baud
IC 39 / Pin 5 = 2400 Baud
IC 39 / Pin 4 = 4800 Baud
IC 39 / Pin 3 = 9600 Baud

Die Baudrate ist auf 4800 Baud voreingestellt. Sie kann jedoch manuell verändert werden; vgl. Sie hierzu die folgende Skizze:

|    | Bauc                 |
|----|----------------------|
| 1) | 9600                 |
| 2) | 4800                 |
| 3) | 2400                 |
| 4) | 1200                 |
| 5) | 600                  |
| 6) | 300                  |
|    | 2)<br>3)<br>4)<br>5) |



# 1.12 Parallel - Schnittstelle

Nachstehend wird die Parallel-Schnittstelle vom Typ Centronics beschrieben, da der alphatronic PC auch über diese Schnittstelle verfügt. Die Ausgangssignale liegen an einem (34-poligen) Stecker an, der sich auf der hinteren Seite des PC befindet. Um den PC mit einem Drucker zu verbinden, ist ein Spezialkabel erforderlich.

Über den IC-Baustein 4 (74 LS 373) werden die parallelen Daten (DATA O bis DATA 7) ausgegeben. Die Freigabe erfolgt an Pin 11 (Port-Adresse OUT 30H).

Das Senden- bzw. Empfangen der Steuersignale

- STROBE -
- ACK -
- BUSY -
- RESET -

erfolgt über IC-Baustein 5 (74 LS 367). Die Freigabe erfolgt an Pin 1 (Port-Adresse IN 30H).





# Ein-/Ausgabe-Signale

| Nr.                                                                    | Signal                                                                       | Bedeutung                                                                                                                                                            | Richtung                                                                  |
|------------------------------------------------------------------------|------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| 1                                                                      | STB                                                                          | Freigabesignal für das<br>Senden der Daten zum<br>Drucker; negative Logik,<br>TTL-Pegel                                                                              | Ausgang<br>Ausgang<br>Ausgang<br>Ausgang                                  |
| 3<br>5<br>7<br>9<br>11<br>13<br>15                                     | DATA-1<br>DATA-2<br>DATA-3<br>DATA-4<br>DATA-5<br>DATA-6<br>DATA-7<br>DATA-8 | Die Signale <u>Data-l bis</u> <u>DATA-8</u> enthalten Informa- tionen über das jeweils 1. bis 8. Bit der parallel zu übertragenden Daten.: positive Logik, TTL-Pegel | Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang |
| 19                                                                     | ACK                                                                          | Der Computer erhält das<br>Quittungssignal vom Drucker:<br>dieser hat Daten empfangen<br>und ist erneut empfangsbereit.<br>Negative Logik, TTL-Pegel                 | Eingang                                                                   |
| 21                                                                     | BSY                                                                          | Signal an PC vom Drucker<br>Er ist empfangsbereit, sein<br>Puffer ist leer.<br>Negative Logik, TT1-Level                                                             | Eingang                                                                   |
| 23<br>25<br>27<br>29<br>31<br>33                                       | NC<br>NC<br>GND<br>NC<br>GND<br>NC                                           | Nicht belegt Nicht belegt Masse Nicht belegt Masse Nicht belegt Masse Nicht belegt                                                                                   |                                                                           |
| 2<br>4<br>6<br>8<br>10<br>12<br>14<br>16<br>18<br>20<br>22<br>24<br>26 | GND                                      | Masse Der PC leitet das System-                                                        |                                                                           |
| 28<br>30<br>32<br>34                                                   | NC<br>GND<br>NC<br>NC                                                        | RESET-Signal an den Drucker<br>weiter. Negative Logik,<br>TTL-Pegel<br>Nicht belegt<br>Masse<br>Nicht belegt<br>Nicht belegt                                         | Ausgang                                                                   |



#### 1.13 Kassettenrecorder - Schnittstelle

Der alphatronic PC besitzt für das Laden und Speichern von Programmen eine Kassettenrecorder-Schnittstelle. Die Ein-/ Ausgabe - Signale liegen an einer achtpoligen Buchse an, die sich neben der Bildschirmbuchse and der linken Seite des Computers befindet. Um den alphatronic PC mit einem Kassettenrecorder zu verbinden, ist ein Spezialkabel erforderlich. Falls Sie die Fernsteuerung nicht benutzen, ist lediglich ein DIN-Kabel erforderlich.

### 1.13.1 Technischer Ablauf (Kassettenrecorder)

Die Ansteuerung der Kassettenrecorder-Schnittstelle erfolgt über den USART-Baustein 8251 A, mit einer Übertragungsgeschwindigkeit von 1200 Baud.

Das Signal TxD (Transmitted Data) vom USART-Baustein beinhaltet die seriellen Daten, die über den Baustein IC 48 (74 LS 74) ausgegeben werden.

Über eine Steckbrücke ist es möglich, den Ausgangspegel auf 25 mV bzw. 700 mV einzustellen.





### 1.13.2 Lesen von Kassette

Das nachfolgende Timing-Diagramm zeigt die Demodulation des Lesesignals.







# 1.13.3 Pin - Belegung der Kassettenrecorder-Schnittstelle

Ein-/Ausgabe-Signale

Pin-Belegung



(von der Lötseite aus gesehen)

| Nr.         | Signal              | Bedeutung                                                   | Richtung           |
|-------------|---------------------|-------------------------------------------------------------|--------------------|
| 1 2 3       | REC<br>GND<br>MON   | verbunden mit 4<br>Signal Ground (Masse)<br>verbunden mit 5 | Ausgang            |
| 4           | REC                 | Schreibsignal<br>TTL-Pegel                                  | Ausgang            |
| 5           | MON                 | Lesesignal<br>TTL-Pegel                                     | Eingang            |
| 6<br>7<br>8 | REM1<br>REM2<br>GND | Fernsteuerung<br>Fernsteuerung<br>Signal Ground             | Ausgang<br>Ausgang |



# 1.14 Bildschirmsteuerung

Die Bildschirmsteuerung ist in folgende Funktionsgruppen unterteilt:

- CRT-Controller HD 4650 S
- Adreßerkennung, -auswahl und -modifikation
- Taktsignalgenerator
- BAS-Signal
- RGB-Signal
- Zeichengenerator
- Video-RAM und Attribut-RAM

# 1.14.1 CRT - Controller HD 4650 S

Die Steuerung des gesamten Zeitablaufs erfolgt durch den Controller--Chip HD 4650 S. Seine Control bzw. Adreßregister werden durch -ADR Oadressiert (RS-Register Select) und über den Datenbus gelesen bzw. geschrieben. Über die Ausgänge MA O bis MA 10 erzeugt der Controller die interne Refreshadresse für Video-RAM und Attribut-RAM.

Die Ausgänge RA O bis RA 3 erzeugen die aktuelle Rasterzeilennummer für den Zeichengenerator.

Außerdem erzeugt der Controller alle Synchronsignale für das BAS---Signal (Bild-Austast-Synchron Signal) und das RGB-Signal.

Neben HSYNCH und VSYNCH erzeugt der Controller auch das Cursorsignal, welches das Videosignal während der Austastlücken unterdrückt.

Über die Multiplexer IC 45, IC 44 und IC 43 (74 LS 157), erfolgt die Adressierung des Video- und Attribut-RAM.



# 1.14.2 Ansteuerung von Video- bzw. Attribut-RAM

Die Ansteuerung sieht wie folgt aus:

 $\overline{\text{MREQ}}$  .  $\overline{\text{All}}$  .  $\overline{\text{ADFR}}$  .  $\overline{\text{VRAMW}}$  = WE (Attr.-RAM)



# 1.14.3 Der Zeichengenerator

Zusammen mit den 8 Bits des abzubildenden Zeichens und den 4 Bits (RO-R3) wird die Adresse für den Zeichengenerator gebildet.

# 1.14.4 Der Taktgenerator

Der Quarzgenerator IC 102 erzeugt den Dot-Clock (PAL 17,72 MHz). Jedes Zeichen das dargestellt wird, ist 8 Dot-Clocks lang.

Ob jetzt mit 80 Zeichen je Zeile bzw. 40 Zeichen je Zeile gearbeitet wird, ist abhängig von IC 89 bzw. IC 103.



# 1.14.5 BAS - Ausgang

Das Zeichen, das am Ausgang des Schieberegister IC 79 (74 LS 166) am Pin 13 ansteht, wird über die ICs 61 und 89 in der BAS-Mischstufe mit dem HYSNCH und VSYNC verknüpft und über den Koaxstecker auf den Monitor ausgegeben.





# 1.14.6 RGB - Ausgang

Der PC hat eine Schnittstelle zum Anschluß eines Farbmonitors. Die Ausgabesignale liegen an einer achtpoligen Buchse an, die sich auf der linken Seite des PC befindet.

Die Information, die seriell ausgegeben wird (IC 79, Pin 13) liegt am Select Input Eingang des IC-Bausteins 90, Pin 1 (74 LS 157) an. Außerdem wird am IC-Baustein 90 das Video-Signal mit der Information vom Attribut-RAM verknüpft und über das Synchronisierungs-IC 97 (74 LS 175) auf den RGB-Ausgang ausgegeben.





# 1.14.7 Steckerbelegung RGB

| Nr.                                  | Signal                                           | Bedeutung                                                                                                                         | Richtung                                                                             |
|--------------------------------------|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------|
| 1<br>2<br>3<br>4<br>5<br>6<br>7<br>8 | VDD<br>GND<br>BSTCLK<br>HSYNC<br>VSYNC<br>R<br>G | +12V Signal-Masse Color burst clock Horizontale Synchr. Vertikale Synchr. Videosignal (Rot) Videosignal (Grün) Videosignal (Blau) | Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang<br>Ausgang |



(Von der Lötseite aus gesehen)

| (1) | VDD    |   | Spannungsversorgung für den TV-Adapter                                                      |
|-----|--------|---|---------------------------------------------------------------------------------------------|
| (2) | GND    | : | Signal Ground (Masse)                                                                       |
| (3) | BSTCLK | : | Zwischenträger-Taktfrequenz, positive Logik, TTL-Pegel, PAL: 4,43362 MHz, NTSC: 3.57954 MHz |
| (4) | HSYNC  | : | Horizontales Synchronisiersignal                                                            |
| (=) |        |   | negative Logik, TTL-Pegel                                                                   |
| (5) | VSYNC  | : | Vertikales Synchronisiersignal                                                              |
|     |        |   | negative Logik, TTL-Pegel                                                                   |
| (6) | R      | : | Video-Signal (ROT), positive Logik,                                                         |
|     |        |   | TTL-Pegel                                                                                   |
| (7) | G      | : | Video-Signal (Grün), positive Logik,                                                        |
|     |        |   | TTL-Pegel                                                                                   |
| (8) | В      | : | Video-Signal (Blau), positive Logik,<br>TTL-Pegel                                           |
|     |        |   | 3                                                                                           |



# 1.15 I/O Schnittstelle

Eine besondere Schnittstelle bietet Erweiterungsmöglichkeiten, u.a. zum Anschluß einer Diskettenstation.

Die 50-polige Buchse für diese Schnittstelle befindet sich auf der Rückseite des PC. Zum Anschluß von Geräten an diese Schnittstelle benötigen Sie ein spezielles Kabel.

# 1.15.1 Steckerbelegung I/O Schnittstelle

| 1  | GND      | 2  | GND      |
|----|----------|----|----------|
| 3  | DO       | 4  | D1       |
| 5  | D2       | 6  | D3       |
| 7  | D4       | 8  | D5       |
| 9  | D6       | 10 | D7       |
| 11 | -WAIT-   | 12 | -RESET-  |
| 13 | -CCLK-   | 14 | -DCLK-   |
| 15 |          | 16 | -SIOR-   |
| 17 | -WR-     | 18 | -MREQ-   |
| 19 | -IORQ-   | 20 | -RD-     |
| 21 | OUTDVI   | 22 | OUTDV2   |
| 23 | 0        | 24 | -EXINTI- |
| 25 | -EXINT2- | 26 | -AEN-    |
| 27 | -GRPP-   | 28 | DRQO     |
| 29 | DRQ1     | 30 | DRQ2     |
| 31 | TC       | 32 | -DACK2-  |
| 33 | -DACKO-  | 34 | -DACK1-  |
| 35 | A15      | 36 | A14      |
| 37 | A13      | 38 | A12      |
| 39 | All      | 40 | A10      |
| 41 | A9       | 42 | A8       |
| 43 | A7       | 44 | A6       |
| 45 | A5       | 46 | A4       |
| 47 | A3 =     | 48 | A2       |
| 49 | Al       | 50 | AO       |

1.16 DIP - Schalter - Funktion

Im Gerät befindet sich auf der Platine ein DIP-Schalter mit sechs Einstellungsmöglichkeiten:

Schalter 1 - 3 dient zur Einstellung von Ländervarianten der

Tastatur

Schalter 4 Auswahl der Druckerschnittstelle (parallel, seriell)

Schalter 5 TV-Farbsystem (PAL, NTSC)

Schalter 6 ohne Funktion

Schaltervoreinstellung:

2

1

ON ON ON Internat. Tastatur
OFF ON ON Deutsche Tastatur

4

3

OFF V.24 (seriell):

Voreinstellung für den europäischen Bereich

ON Centronics (parallel):

Voreinstellung für den außereuropäischen Bereich

5\_\_\_

OFF NTSC ON PAL



1.17 ROM - Back - Schnittstelle

Der alphatronic PC verfügt über eine Steckmodul-Schnittstelle, um die mit entsprechenden Anwenderprogrammen angebotenen Steckmodule aufnehmen zu können. Der 30-polige Stiftsockel befindet sich links oberhalb der Tastatur und ist mit einem Schutzdeckel abgedeckt. Das Anwender-Programm befindet sich in PROMs vom Typ 8 KB 2764. Es sind max. zwei PROMs einsetzbar (zusammen 16 KB).

Liste der I/O - Adressen 1.18 I/O Address-l OUT 10H : System Flag 1 BIT 6 5 3 2 1 0 DB7 DB<sub>6</sub> DB5 DB4 DB3 DB<sub>2</sub> DB1 DB<sub>0</sub> : 40 character display or 80 character display select Bit O 1: 80 character display 0: 40 character display Bit 1 : Display Inhibit l : Display Inhibit O : Display Available Bit 2 : CMT/RS232C Select CMT=cassette tape recorder 1 : RS232C Select 0 : CMT Select : CMT Motor Start Bit 3 1 : Motor on O : Motor off Bit 4 : Buzzer On 1 : Buzzer On 0 : Buzzer Off Bit 5 : Should always be 0 1: 0: Bit 6 : ROM PACK Enable 1 : ROM PACK Enable (Bit 7=0 is necessary condition) O : ROM PACK Disable Bit 7 : ROM Access Enable 1 : ROM Access Disable (All RAM Area) O : ROM Access Enable

OUT 20H

BIT 7 6 5 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DBO

Bit O : CRTST

1 : CRT Controller Reset
0 : Release Reset Condition

Bit 1 : PRTRST

1 : Centronics Printer Reset
0 : Release Reset Condition

Bit 2 : PRTSTB

1 : Centronics Printer strobe signal active

O : Not active

Bit 3 : MONINH

1 : Select V-RAM

O : Select Monitor ROM

Bit 4 : GLED

1 : Graphic LED On

0 : Off

Bit 5 : SLED

1 : Shift Lock LED On

0 : Off

Bit 6 : Monitor ROM Address Select (8k bytes ROM)

1 : Upper 4k bytes
0 : Lower 4k bytes

Bit 7 : Not Use

Bit 3 6 0 0 MONITOR lower 4k bytes 0 1 " upper 4k bytes 1 0 1 V-RAM

OUT 30H

DATA BUS - - -> Centronics DATA BUS

BIT 7 6 5 4 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DBO

IN 30H

BIT 7 6 5 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0

Bit O : SIOC

1:

0 : not used

Bit 1 : CRTVR

1 : V-SYNC Return Period

O: Not

In the V-SYNC Return Period V-RAM can be rewritten.

Bit 2 : CACK

1 : Centronics printer acknowledge signal

0 : Not

Bit 3 : CBSY

1 : Centronics Printer Busy signal

O : Ready

Bit 4 - 7 are not used.

8251 (Device No. 4xH)

This 8251 (programmable Communication Interface) is used for RS-232C Interface and CMT Interface exclusively.

OUT 40H

DATA BUS - - -> 8251 DATA

7 5 BIT 6 4 3 2 0 1 SD7 SD<sub>6</sub> SD5 SD4 SD3 SD<sub>2</sub> SD1 SDO

IN 40H 8251 DATA - - -> DATA BUS

7 BIT 6 5 3 2 1 0 RD7 RD6 RD5 RD4 RD3 RD2 RD1 RDO

OUT 41H

DATA BUS - - -> CONTROL (Mode Setting)

BIT 7 5 6 4 3 2 1 0 EΡ **S2** SI PEN L2 L1 B2 Bl

Bit O, Bit 1

Baud Rate Factor

B1 0 1 0 1

B2 0 0 1 1

SYNC (1x)(16x)(64x)

MODE

Bit 2, Bit 3

Character Length

| Ll | 0         | 1         | 0         | 1         |
|----|-----------|-----------|-----------|-----------|
| L2 | 0         | 0         | 1         | 1         |
|    | 5<br>BITS | 6<br>BITS | 7<br>BITS | 8<br>BITS |

Bit 4 : PARTIY ENABLE

l : Enable
0 : Disable

Bit 5 : EVENPARITY GENERATION/CHECK

1 : Even 0 : Odd

0

I/O Address-7

OUT 41H

DATA BUS - - -> CONTROL (Command Setting)

BIT 7 6 5 4 3 2 1

EH IR RTS ER SBRK RXE DTR TXEN

Bit O : TxEN (TRANSMIT ENABLE)

l : Enable
0 : Disable

Bit 1 : DTR (DATA TERMINAL READY)
"high" will force DTR output
to zero

Bit 2 : RxE (RECEIVE ENABLE)

l : Enable
0 : Disable

Bit 3 : SBRK (SEND BREAK CHARACTER)

1 : Forces TxD "low"
0 : Normal operation

Bit 4 : ER (ERROR RESET)

1 : Reset error flags PE, OE, FE

Bit 5 : RTS (REQUEST TO SEND)

"high" will force RTS output to zero

Bit 6 : IR (INTERNAL RESET)
"high" returns 8251 to
Mode Instruction Format

Bit 7 : EH (ENTER HUNT MODE)

1 : Enable search for Sync. characters

(HAS NO EFFECT IN ASYNC. MODE)

I/O Address-8 HD465055 (Device No. 5XH) CRT-Controller OUT 50H DATA BUS - - -> HD46505 DATA (Internal Register Number) BIT 7 6 5 4 3 2 1 0 RA4 RA3 RA2 RAl RAO OUT 51H DATA BUS - - -> HD46505 DATA (DATA to the internal Register) available to Reg. No. O -- Reg. No. 15 BIT 7 6 5 4 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB<sub>2</sub> DB1 DBO IN 51H HD46505 Internal Reg. DATA - - -> DATA BUS available to Reg. No. 12 -- Reg. No. 15 7 BIT 6 5 4 1 0

DB7

DB6

DB5

DB4

DB3

DB2

DB1

DB0

HD46505S (Cont'd) CRT-Controller

Internal Register

| Address   | Reg. | Register Name              | Unit   | DATA BIT                |
|-----------|------|----------------------------|--------|-------------------------|
| 4 3 2 1 0 | No.  |                            |        | 7 6 5 4 3 2 1 0         |
| x x x x x | AR   | Address Reg.               | -      | / / /                   |
| 0 0 0 0 0 | RO   | Horizontal<br>Total Chara. | Chara. |                         |
| 00001     | Rl   | Horizontal Display Chara.  | Chara. |                         |
| 0 0 0 1 0 | R2   | H-Sync. Position           | Chara. |                         |
| 0 0 0 1 1 | R3   | Sync. Pulse Width          |        | V3 V2 V1 V0 H3 H2 H1 H0 |
| 0 0 1 0 0 | R4   | Vertical Total<br>Chara.   | Line   |                         |
| 00101     | R5   | Total Adjust<br>Luster     | Luster | / / /                   |
| 0 0 1 1 0 | R6   | Vertical Display           | Line   | /                       |
| 0 0 1 1 1 | R7   | V-Sync. Position           | Line   | /                       |
| 0 1 0 0 0 | R8   | Interrace & Scue           | -      | C1 C0 D1 D0 / / V S     |
| 0 1 0 0 1 | R9   | Max. Luster<br>Address     | Luster | / / /                   |
| 0 1 0 1 0 | R10  | Cursor Start<br>Luster     | Luster | / B P                   |
| 0 1 0 1 1 | R11  | Cursor End Luster          | Luster | / / /                   |
| 0 1 1 0 0 | R12  | Start Address (H)          | -      | / /                     |
| 0 1 1 0 1 | R13  | Start Address (L)          | -      |                         |
| 0 1 1 1 0 | R14  | Cursor (H)                 | -      | / /                     |
| 0 1 1 1 1 | R15  | Cursor (L)                 | -      |                         |

Luster = Attribute RAM (R, G, B, REVERSE, Blink)

I/O Address-10 8257 (Device No. 6XH) DMA Controller OUT 60H Channel O DMA Address DATA BUS <- - - 8257 DATA BIT 7 6 5 4 3 2 1 0 AO - A15: Α7 A1 Α6 **A5** Α4 А3 A2 AO DMA Start Addr. A15 A14 A13 A12 All A10 Α9 **A8** OUT 61H Channel O Terminal Count DATA BUS - - ->8257 DATA 7 BIT 6 5 4 3 2 1 0 CO - C13: C7 C5 C3 C2 C6 C4 Cl CO Terminal Count Value RD C13 C12 C10 **C9** WR C11 C8 RD WR 0 0 : DMA Verify Cycle 0 1 : DMA Write Cycle 1 0 : DMA Read Cycle 1 1 : Illegal OUT 62H Channel 1 DMA Address **OUT 63H** Channel 1 Terminal Count IN 64H Channel 2 DMA Address In 65H -Channel 2 Terminal Count used for Floppy-Disk-Unit OUT 66H Channel 3 DMA Address

OUT 67H

Channel 3 Terminal Count

LALLIET = 6PDec

I/O Address-ll

8257 (Device No. 6XH) DMA Controller

**OUT 68H** 

MODE SET

DATA BUS - - -> 8257

7 6 BIT 5 3 2 1 0 AC TCS EN RP EN3 EN2 EN1 ENO Enable DMA channel Enable DMA channel 1 Enable DMA channel 2 FD Enable DMA channel 3 Enable Rotating Priority Enable Extended Write Enable TC Stop Enable Auto Load

8259 (Device No. 7XH)

Interrupt Controller Refer to 8259 Manual

OUT 70H

ICW 1 DATA BUS - - -> 8259

BIT 5 6 4 3 2 1 0 Α7 Α6 Α5 1 LTIM ADI 1 0 Single use Call Address Interval 1 : Interval of 4 0 : Interval of 8 l : Level Trigger Mode

A7--A5 of Interrupt Vector Address
Interval of 4 means 4 bytes for one vector.

0 : Edge Trigger Mode

OUT 71H

ICW 2 DATA - - -> 8259

BIT

7 6 5 4 3 2 1 0 A15 A14 A13 A12 A11 A10 Α9 8A

Al5--A8 of Interrupt Vector Address.

OUT 71H

OCW 1 DATA - - -> 8259

BIT

7 6 5 4 3 2 1 0 M7 M6 M5 M4 М3 M2 Ml MO

Interrupt Mask
1 : Mask Set
0 : Mask Set

OUT 70H

OCW 2 DATA BUS - - -> 8259

BIT

| 7 | 6  | 5   | 4 | 3 | 2  | 1  | 0  |
|---|----|-----|---|---|----|----|----|
| R | SL | EOI | 0 | 0 | L2 | Ll | LO |

Bit 0, 1, 2

IR Level to be acted upon

|    | 0 | 1 | 2           | 3 | 4 | 5 | 6 | 7 |
|----|---|---|-------------|---|---|---|---|---|
| LO | 0 | 1 | 0<br>1<br>0 | 1 | 0 | 1 | 0 | 1 |
| Ll | 0 | 0 | 1           | 1 | 0 | 0 | 1 | 1 |
| L2 | 0 | 0 | 0           | 0 | 1 | 1 | 1 | 1 |

Bit 5, 6, 7

R SL EOI

0 0 1 Non-specific EOI Command

O l 1 \*Specific EOI Command

1 0 1 Rotate On Non-Specific EOI Command

1 0 0 Rotate In Automatic EOI Mode (Set)

O O Rotate In Automatic EOI Mode (Clear)

1 1 0 \*Set Priority Command

O l O No operation

# \* LO-L2 are used

IRO: Timmer Interrupt 24 msec.

IR1 : RyRDY

IR2 : TxRDY
IR3 : EXINT2

IR4 : EXINT1 External Box (e.g. Graphic Box)

IR5 : not use

IR6 : not use

IR7 : VINT

I/O Address-14 FDD Unit (Device No. OFXH) with FD Controller (uPD 765A) OUT OF 8H DATA BUS - - -> uPD 765A DATA BIT 7 5 6 4 3 2 1 0 DB7 DB<sub>6</sub> DB5 DB4 DB3 DB2 DB1 **DBO** Refer to uPD 765A Manual IN OF8H uPD 765A DATA - - -> DATA BUS The contents are command result status of the controller. BIT 7 6 5 4 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB2 DB1 **DBO** Refer to uPD 765A Manual. IN F9 IN OFOH uPD 765A STATUS REGISTER - - -> DATA BUS BIT 7 6 5 4 3 2 1 0 DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 Refer to uPD 765A Manual-OUT OF TH DATA BUS - - -> FDD Unit 7 BIT 6 5 4 3 2 1 0 DB7 **DB6** DB5 DB4 DB3 DB<sub>2</sub> DB1 **DBO** Bit 7 : FDCRST 1 : Release the reset condition O : Reset the FD Controller (uPD 765A)

(Bit 7=1 is the necessary condition)
0 : Inactivate the data separator

1 : Activate the data separator (SED-9420C)

Bit 6 : ACTDS



ROM PACK PCB Schematic Diagram





#### 1.19 Das Netzteil des PC

Über den Netzfilter gelangen die 220V an den Transformator und werden dann über einen Gleichrichter in Gleichspannung umgewandelt.

Die Erzeugung der +12V bzw. -12V Spannungen erfolgt über die Spannungs-regler IC 301 und IC 302.

Der IC-Baustein 303 ist der Spannungsregler für die +5V - Spannung, diese Spannung wird über den Stecker (rotes Kabel) der Logik-Platte zugeführt.

Um jetzt aber den alphatronic PC auch in anderen Ländern einsetzen zu können (unterschiedliche Netzspannungen), ist es möglich, durch Ändern des Transformators, sich der jeweiligen Netzspannung anzupassen. Siehe dazu Zeichnung l

150













| Parallel I/O    | STB   GND   2   1   STB   GND   2   2   2   2   2   2   2   2   2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Arrangement                                                  |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|
| CRT             | 1 + 12 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Each Connector Ar                                            |
| RS - 232C       | 1 S R X D T X C 15 S R X D T X C 15 S R X D T X C 15 S R X D T X C 17 S G N D D T R Z D 10 D T R | Each Co                                                      |
| Audic cassene   | 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 19 SCIO<br>20 SCII<br>21 SLED<br>22 GLED<br>23 GND<br>24 VCC |
| (I)<br>ROM Pack | 1   GND   16   16   17   17   17   17   17   17                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | CON                                                          |
| System          | GND GND   C   C   C   C   C   C   C   C   C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                              |

- 2 DER FLOPPY-CONTROLLER
- 2.1 FDC/UPD-765A (LSI-Baustein)
- 2.2 SED-9420 C (Datenseparator)



#### 2 Der Floppy-Controller

Wie das Blockschaltbild zeigt, besteht die Floppy-Controller-Platte aus zwei Schwerpunkten:

- FDC / UPD-765 A (Controller-Baustein)
- SED 9420 C (Datenseparator)

#### 2.1 FDC / UPD - 765 A (LSI-Baustein)

Dieser LSI-Floppy-Disk-Controller besitzt die Möglichkeit, maximal vier Laufwerke zu selectieren. Der Datentransfer vom PC zum Minifloppy-Laufwerk bzw. vom Minifloppy-Laufwerk zum PC erfolgt durch DMA.

### 2.2 SED - 9420 C (Datenseparator)

Die Hauptaufgabe dieses Bausteins liegt darin, die Lesedaten, die vom Laufwerk kommen aufzubereiten und dem DISK-Controller-Baustein zur Verfügung zu stellen.







MAIN PCB SCHEMATIC DIAGRAM - 2







Power Supply PCB