# GRAF computer GDP64HS

Die monochrome Standardgraphik- Karte für den

NDR- Computer und

mc- Computer

Ausgabe 3

Graf Elektronik Systeme GmbH 8960 Kempten - Tel.: 08 31 - 62 11

| Inhalt                                                           | Seite |
|------------------------------------------------------------------|-------|
| 1 Einführung                                                     | 3     |
| 1.1 Zum NDR-Computer                                             | 3     |
| 1.2 Wozu dient die Baugruppe                                     | 4     |
| 2. Technische Daten                                              | 5     |
| 3 Prinzipbeschreibung                                            | 6     |
| 3.1 Blockschaltbild                                              | 6     |
| 3.2 Datenübertragung zum Monitor                                 | 9     |
| 4 Aufbauanleitung                                                | 12    |
| 4.1 Stückliste des Komplettbausatzes                             | 13    |
| 4.2 Stückliste des Aufbausatzes                                  | 14    |
| 4.3 Aufbau Schritt für Schritt                                   | 15    |
| 5 Testanleitung                                                  | 18    |
| 5.1 Erste Prüfung ohne IC's                                      | 18    |
| 5.2 Test der GDP 64k im System<br>5.3 Test und Beispielprogramme | 22    |
| Beschreibung zu den Testprogrammen                               | 22    |
| Alphazeichen                                                     | 23    |
| Graphik                                                          | 24    |
| Vektoren zeichnen                                                | 25    |
| Demo für 680xx                                                   | 26    |
| 5.4 Jumperstellungen                                             | 27    |
| 6 Fehlersuchanleitung                                            | 28    |
| 7 Schaltungsbeschreibung                                         | 30    |
| 7.1 Wie funktioniert die Baugruppe ?                             | 30    |
| 7.2 Hinweise zum Monitoranschluß                                 | 40    |
| 8 Anwendungsbeispiel                                             | 41    |
| 8.1 Direkte Eingabe von Grafikzeichen                            | 41    |
| 8.2 Beispiel als Basic - Programm                                | 42    |
| 8.3 Beispiel in Turbo - Pascal                                   | 42    |
| 8.4 Hardcopyprogramm unter CP/M 2.2                              | 43    |
| 8.5 Hardcopyprogramm für 680xx<br>8.6 Hardscroll- Demo für 680xx | 56    |
| 0.0 Haldscioli- bene lai oooka                                   | -     |
| 9 Diverses                                                       | 64    |
| 9.1 Ausblick                                                     | 64    |
| 9.2 Kritik<br>10 Unterlagen zu den verwendeten IC's              | 64    |
| 10 Unterlagen zu den verwendeten IC's                            | 65    |
| 10.1 TTL-IC'S                                                    | 65    |
| 10.2 Der Grafik Prozessor EF 9366                                | 83    |
| 11 Literatur                                                     | 90    |
| Anhang A: Schaltplan                                             | 91    |
| Anhang B: Bestückungsplan                                        | 94    |
| Anhang C: Best Plan mit Layout, B- Seite                         | 95    |
| Anhang D: Layout Bestückungsseite                                | 96    |

#### 1. Einführung

#### 1.1 Zum NDR-Computer

Der NDR-Computer wird in der Fernsehserie "Mikroelektronik - Mikrocomputer selbstgebaut und programmiert " aufgebaut, erklärt und in Betrieb genommen. Diese Serie wird vom Norddeutschen Rundfunk und vom Bayerischen Fernsehen ausgestrahlt. Es werden bald auch die Regionalsender anderer Bundesländer die Sendung in ihr Programm aufnehmen.

Zur Serie gibt es einige Begleitmaterialien, es ist daher nicht unbedingt notwendig, die Fernsehserie gesehen zu haben, um den NDR-Computer zu bauen und zu begreifen:

- Bücher:

Rolf-Dieter Klein,
"Rechner modular"
ISBN 3-7723-8721-7, DM 68,erschienen im Franzis-Verlag, München
Bestellnummer: 10991

Rolf-Dieter Klein,
"Die Prozessoren 68000 und 68008"
Rechnerarchitektur und Sprache im NDR-KLEINComputer
ISBN 3-7723-7651-7, DM 78.erschienen im Franzis-Verlag, München

- Zeitschriften "mc" und "ELO" des Franzis-Verlages
- Zeitschrift "LOOP" der Firma Graf Elektronik Systeme
- Videocassetten:

lizensierte Originalcassetten für den privaten Gebrauch. Auf diesen zwei Cassetten sind die 26 Folgen der Fernsehserie enthalten.

Systeme: VHS, Beta, Video 2000 Preise: siehe gültige Preisliste

#### 1.2 Wozu dient die Baugruppe

Die Baugruppe GDP64HS ist das Bindeglied zwischen dem Mikrocomputer (SBC 2, SBC 3, CPU 680xx oder CPU Z80) und einem Monitor. Sie ermöglicht es einen Monitor mit BAS - Anschluß oder einen TTL- Monitor anzuschliessen. Nun ist es möglich Arbeitsschritte, die der Computer durchführt, auf dem Monitor anzuzeigen, Graphiken darzustellen oder Einblick in das Innenleben des Computers zu bekommen (Speicherbelegung, Kontrolle der Eingaben). Die GDP64HS kann zudem noch sogenannte Hardcopys erstellen, d.h. der Bildschirm wird mit Hilfe eines Druckers auf ein Blatt Papier kopiert.

Da jeder Bildpunkt auf dem Monitor ansprechbar sein muß, wird bei einer Bildebene von 256 x 512 Bildpunkten ein eigener Speicher von 16 KByte benötigt, wenn jeder Bildpunkt ein Bit beansprucht. Da aber vier unabhängige Bildebenen aufgebaut werden können, braucht man demnach einen Speicherplatz von 64 KByte. Dieser ist in 8 x 64 KBit Speichern organisiert.

In diesem Speicher wird jeweils das gesamte Bild abgespeiseriell alle 20 ms abgerufen (50 mal in der chert und dadurch entsteht ein stehendes Bild. Die Verwal-Sekunde); tung des Speicherbereiches (Abruf des Bildes , Refresh...) übernimmmt der auf der GDP64HS befindliche Graphik-Prozessor Mit dem Mikrocomputer können per Datenbus Befehle 9366. z.B. Schreiben eines Zeichens, Größe übermittelt werden, des gewünschten Zeichens, Form des Zeichens, Lage und Position des Zeichens auf der Bildebene, Auswahl einer der vier Bildebenen . Dieser Prozessor ermöglicht es auch schnelle Graphik darzustellen (Blockgraphik und Vektoren). Durch Definition von verschiedenen Vektoren ist es möglich, Linien (Vektoren) in jede Richtung und in jeder Größe zu zeichnen .

Verschiedene Konfigurationen mit der GDP64HS (Bild 1):



#### 2. Technische Daten

Spannungsversorgung: +5V

Stromaufnahme: 500 mA

Busformat: NDR - Bus 54-poliq

ECB - Bus 64-poliq

Leiterplattenformat: 160mm x 100mm (Europakarte)

1.BAS (beinhaltet HS, VS und VIDEO - Signal) Ausgang:

2.TTL - Ausgang: HS, VS, VIDEO (invertierbar) z.B. IBM Monitor

EF 9366 (Thomson-CSF) Graphik - Controller:

-kann 4 Seiten bedienen, wobei in eine qeschrieben und zugleich eine weitere

gelesen werden kann.

-integrierter ASCII- Zeichensatz

-Graphikbefehle \* Kurzvektoren

\* Vektoren

\* Blockgraphik 5x8 und 4x4

8 x 64k RAM (dynamisch) Speicher:

Modify (zerstörungsfreies sonstige Funktionen: Read Write Zeichnen auf dem Bildschirm)

- Hardcopy (Rücklesen des Bildschirminhaltes und Ausgabe auf einen Drucker)

- Hardscroll (Scrollen des Bildschirms mit Hilfe der Hardware, d.h. die Adressen des Bildschirmspeichers werden hardwaremäßig aufaddiert.

#### 3. Prinzipbeschreibung

#### 3.1 Blockschaltbild



Von der Haupt- CPU (z.B. von der CPU68008) wird über die Adressleitungen AO...A3 eines der 16 Register der Neben- CPU (hier EF 9366) angewählt. Soll z.B. ein Vektor gezeichnet werden, so teilt man dem Graphik-Prozessor lediglich den Anfangs- und Endpunkt mit. Die Zwischenwerte werden von ihm selbst berechnet und dann in den Speicher abgelegt.

Der interne Aufbau des Speichers wird durch den Grafikprozessor und sekundär durch die Speicherdekodierlogik organisiert. Im Speicher steht dann die Information, die später auf dem Bildschirm erscheint.

Beispiel: Wir verfolgen das Auslesen eines Bytes vom Speicher zum Monitor (z.B. 10001110)

Das Byte steht am Ausgang des Speichers und wird bei aktivieren des Signals SH/L (Shift Load, am Schieberegister) parallel in das Schieberegister eingelesen. Hier wird das Signal mit dem Punktetakt (14 MHz, CLK) verknüpft und seriell (in der Punktfolge 10001110) an den Monitor hinausgeschoben. Da jedes Bit einen Bildpunkt darstellt, werden jetzt 8 Punkte auf dem Bildschirm angezeigt. Ein dunkler Punkt entspricht einer 1 und ein heller einer 0. (ebenfalls in der Reihenfolge 10001110). Siehe Bild 3 auf der nächsten Seite.



Monitor Bild 3

Der Speicher ist für 4 Seiten aufgebaut, die durch die Seitenumschaltung ausgewählt werden können. Es kann in eine Seite geschrieben und zugleich eine weitere gelesen werden. Das aus dem Schieberegister kommende Videosignal geht entweder direkt zum Monitor (TTL) oder zum Videomischer. In dieser Mischstufe wird das Video-Signal mit horizontalen und vertikalen Synchronisationssignalen (HS und VS) so aufbereitet, daß es danach als BAS-Signal (siehe 3.2.2) zur Verfügung steht.

Will man eine Hardcopy erstellen, muß man ähnlich der Datenübertragung zum Monitor den Bildspeicher auslesen. Das Auslesen des Bildschirmspeichers läuft parallel zum Display (Ausgeben der Bildschirminformation). Durch einen Befehl an den Graphikprozessor kann jeweils ein Byte des Bildschirmspeichers gelesen werden und im Arbeitsspeicher abgelegt werden. Durch eine Druckerroutine kann nun das Bild auf einen Drucker ausgegeben werden. Das Auslesen des Bildschirmspeichers ist auch für andere Aufgaben sehr nützlich (z.B. Vergleich von Bildschirmseiten, Abfrage des Maus-Zeigers für Graphikprogramme, Windowtechnik, usw.)

Hardware-Scroll-Logik dient zum Rollen (Scroll) Bildschirms. Bei der bisherigen GDP64k wurde der Scroll softwaremäßig erzeugt. Sollte der Bildschirm Textdarstellung um eine Textzeile nach oben gescrollt werden, so mußte das gesammte Bild noch einmal aufgebaut (um eine Zeile versetzt). Dadurch war der Scroll natürlich sehr langsam und nur zeilenweise (Textzeile = 8 Bildschirmzeilen) möglich. Der Hardware Scroll behebt diese beiden Mängel. Dabei wird der Bildschirmspeicher beim Scrollen nicht mehr verändert, sondern nur die Adressierung Bildschirmspeichers. Dies wird durch zwei Addierer erledigt, die lediglich die Bildspeicheradressen, die vom Graphikprozessor kommen mit einer Scrolladresse, die über 61 ausgegeben werden kann, aufaddiert und damit die Bildspeicheradresse erzeugt. Dadurch kann der hirm zyklisch gescrollt werden, natürlich mit einer Bildschirm zyklisch gescrollt werden, größeren Geschwindigkeit und zeilenweise (fließender Übergang).

Mit Hilfe des RMW-Modus kann man einfach bewegte Bilder erzeugen, da bei Schreibvorgängen in den Bildspeicher (=Monitor) alle Punkte komplementiert werden. Wenn z.B. ein Punkt gesetzt war, so wird er gelöscht, wenn er nicht gesetzt war, so wird er eingeschrieben. Der größte Vorteil des RMW-Modus ist, daß zerstörungsfrei gezeichnet werden kann. Dies ist z.B. nötig, um einen Maus-Zeiger oder ein Fadenkreuz auf einer Graphik oder einem Bild darzustellen,

ohne das Hintergrundbild zu zerstören.

Die Dekodierlogik mit den Adressen A4...A7, den Signalen IORQ und M1 wird benötigt, um die GDP64HS bei I/O- Zugriff von 70...7F (Graphikprozessor) und 60...6F (Seitenport, RMW=Mode, Hardcopy und Hardscroll) anzusprechen.

Die Takterzeugung stellt alle benötigten Frequenzen (Pixelclock, Clock für Schieberegister, Takte für die Adressierung der Speicher ) aus dem Grundtakt von 14 MHz her.

#### 3.2 Datenübertragung zum Monitor:

#### 3.2.1 Prinzip der Signale HS, VS und VIDEO.

HS- Signal: (Horizontal- Synchronisation) Dieses Signal ist für die Zeilensynchronisation zuständig. Der Bildschirm wird veranlaßt, mit dem Schreiben einer Zeile so lange zu warten, bis die zu Übertragende Information am VIDEO- Ausgang bereitgestellt ist. Wie der Name des Signales schon andeutet, wird das Übertragen der Daten und das Schreiben der Daten auf den Bildschirm synchronisiert.

VS- Signal: (Vertikal- Synchronisation) Dieses Synchronisationssignal veranlaßt einen neuen Bildschirmaufbau, der alle 20 ms stattfindet. Der Schreibstrahl des Bildschirms fährt also von der rechten unteren Ecke in die linke Obere und wird in dieser Zeit ausgeblendet. Während dieses Vorganges kann keine Information geschrieben (also nichts auf dem Bildschirm dargestellt ) werden.

VIDEO- Signal: Es besteht aus High- und Low- Signalen die Bildinformation wiederspiegeln. Will man dieses Signal ansehen, verwendet man am besten ein Oszilloskop.

#### 3.2.2 Monitor mit BAS - Signal:

Das BAS - Signal wird bei normalen Monitoren über eine einzige Leitung übertragen und setzt sich aus den Einzelsignalen HS + VS + Video zusammen. Die Signale HS(bzw VS) und das Videosignal stehen im Verhältnis 1 zu 2.



Bild 4

#### 3.2.3 Monitor mit TTL-Signal z.B. IBM - Monitor:

Hier werden die Signale HS, VS und Video über verschiedene Leitungen zum Monitor übertragen. (siehe rechts, prinzipieller Verlauf der Signale ohne Angabe der Zeiten).



Beispiel: Eine Originalaufnahme der drei Signale HS, VS und Video mit den Logik-Analyser erstellt:

Im ersten Diagramm erkennt man das VS- Signal, darunter das Signal HS und das VIDEO-Signal(VI). Wie daraus zu ersehen ist, wird während des HS-Signales keine Bildinformation geschrieben. Wird der HS- Impuls aktiv, wird in der nächsten Zeile weitergeschrieben. Das VS-Signal leitet den Aufbau eines neuen Bildes ein.



Bild 6

#### 3.2.4 Wie funktioniert ein Monitor ?

Der Monitor (Brownsche Röhre) besteht aus einer Kathode einer Fokussiereinrichtung (Wehnelt- Zylinder und Anode), Ablenkplatten für horizontale und vertikale Ablenkung und einer auf der Röhreninnenseite aufgetragenen Leuchtschicht.

Von der Kathode werden Elektronen ausgesendet, die von der Fokussiereinrichtung gebündelt werden. Die Ablenkplatten sorgen in horizontaler sowie in vertikaler Richtung für die nötige Ablenkung des Elektronenstrahles, damit jeder Punkt des Bildschirms erreicht wird.

Trifft der Elektronenstrahl an der Frontseite des Bildschirms auf (auf die Leuchtschicht ) so beginnt der angestrahlte Punkt zu Leuchten. Der ausgesandte Elektronenstrahl muß sehr scharf gebündelt sein, um eine hohe Auflösung zu erreichen.



Bild 7

#### 4. Aufbauanleitung

#### CMOS-Warnung:

CMOS-Bausteine sind hochempfindlich gegen elektrostatische Aufladung! Bewahren oder transportieren Sie CMOS-Bausteine nur auf dem leitenden Schaumstoff! Alle Pins müssen kurzgeschlossen sein.

Tip: Fassen Sie an ein geerdetes Teil (z.B. Heizung, Wasserleitung) bevor Sie einen Baustein berühren.

Bitte beachten Sie hierzu auch den Artikel "Schutzmaßnahmen für MOS-Schaltungen" in unserer Zeitschrift LOOP3.





### 4.1 Stückliste des Komplettbausatzes GDP64HS

| zahl                                                     | Nr.                                                                                                                                                                              | Position<br>im Plan                                                                              | Bezeichnung                                                                                                                                                                  | Bemerkungen                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 1                                                        | 11229<br>11232                                                                                                                                                                   |                                                                                                  |                                                                                                                                                                              | Leiterplatte GDP64HS<br>Handbuch                                                                                                                                                                                                                                                                                             |  |  |  |  |
| 2<br>1<br>1<br>1<br>1<br>1<br>3<br>1<br>1<br>2<br>1<br>1 | 60082<br>60080<br>60104<br>60101<br>60075<br>60033<br>60014<br>60137<br>60121<br>10806<br>60098<br>60094<br>60115<br>10806<br>60118<br>60120<br>60120<br>60120<br>60126<br>61126 | J13<br>J7<br>J8<br>J11<br>J16J23<br>J6<br>J3,J4,J10<br>J9<br>J12<br>J29,J30<br>J27<br>J28<br>J24 | 74 LS 08 74 LS 05 74 LS 166 74 LS 163 74 LS 00 7404 4164, 200ns 74 LS 32 25 LS 2538 74 LS 153 74 LS 138 74 LS 245 EF 9366 74 LS 273 74 LS 283 74 LS 383 74 LS 374 74 ALS 574 | Sechs Inverter 8-Bit Schieberegister synch. 4-Bit Zähler 4 NAND Gatter 6 Inverter Dynam. RAM 64 kBit D-Flip Flop mit Preset Vier OR-Gatter 3 zu 8 Decoder 4 zu 1 Multiplexer 3 Bit Binärdekoder 8 fach Bus Transreceiver Graphik-Processor 8 Bit D-Register 8-fach NAND 4 Bit Volladdierer 8 Bit Datenlatch 8 Bit Datenlatch |  |  |  |  |
| 10<br>15<br>5                                            | 60183<br>60185<br>60187<br>60193                                                                                                                                                 | SO 14<br>SO 16<br>SO 20<br>SO 40                                                                 | 14-polige IC-Fassu<br>16-polige IC-Fassu<br>20-polige IC-Fassu<br>40-polige IC-Fassu                                                                                         | ang<br>ang                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 1<br>1<br>1<br>1<br>3<br>4                               | 60665<br>60621<br>60631<br>60643<br>60651<br>60626                                                                                                                               | R1<br>R5<br>R10<br>R8<br>R3,R4R11<br>R2,R6,R7,R9                                                 |                                                                                                                                                                              | Widerstand 75 Ohm Widerstand 150 Ohm Widerstand 220 Ohm Widerstand 330 Ohm Widerstand 470 Ohm Widerstand 1000 Ohm                                                                                                                                                                                                            |  |  |  |  |
| 2                                                        | 60518<br>60958                                                                                                                                                                   | RN1,RN2<br>RN3                                                                                   | 8X3,3,K<br>4x470 Ohm                                                                                                                                                         | Netzwerkwiderstand<br>Netzwerkwiderstand                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 1<br>11                                                  | 60248<br>60239                                                                                                                                                                   | C7<br>C1C6,<br>C8C12                                                                             | 10 uF,Tantal ELKC                                                                                                                                                            | auf Polung achten!<br>Keramikkondensator                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 1                                                        | 60590                                                                                                                                                                            | T1                                                                                               | BC 107                                                                                                                                                                       | Transistor                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
| 1                                                        | 60166                                                                                                                                                                            | Q1                                                                                               | Quarz 14.00 MHz                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
| 1<br>1<br>1<br>1<br>1                                    | 60499<br>60725<br>10787<br>10405<br>10406<br>10097                                                                                                                               | ST1<br>ST3<br>ST2<br>ST4<br>ST4<br>BU1                                                           | 7-polige Stiftleis<br>9-polige D-Sub-Buc<br>ECB-Bus 64-polig<br>NDR - Bus 18-polig<br>NDR - Bus 36-polig<br>Monitor Buchse Cin                                               | chse<br>oder<br>g, gewinkelt und<br>g, gewinkelt                                                                                                                                                                                                                                                                             |  |  |  |  |

#### 4.2 Stückliste des Aufbausatzes GDP64k-GDP64HS

| An-<br>zahl           | Art<br>Nr.                       |                                                           | Bezeichnung                                                                                                                    | Bemerkungen                                                                                                                                   |
|-----------------------|----------------------------------|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>1<br>2           |                                  | J5<br>J3,J4,J10<br>J29,J30<br>J2<br>J14,J15<br>J25<br>J26 | 74 LS 138<br>74 LS 30<br>74 LS 283                                                                                             | Leiterplatte GDP64HS Handbuch 4 AND-Gatter Vier OR-Gatter 3 Bit Binärdekoder 8-fach NAND 4 Bit Volladdierer 8 Bit Datenlatch 8 Bit Datenlatch |
| 10<br>15<br>5<br>1    | 60183<br>60185<br>60187<br>60193 | SO 16                                                     | 14-polige IC-Fassu<br>16-polige IC-Fassu<br>20-polige IC-Fassu<br>40-polige IC-Fassu                                           | ng<br>ng                                                                                                                                      |
| 1<br>1<br>1<br>3<br>4 | 60643                            | R1<br>R5<br>R10<br>R8<br>R3,R4R11<br>R2,R6,R7,R9          |                                                                                                                                | Widerstand 75 Ohm<br>Widerstand 150 Ohm<br>Widerstand 220 Ohm<br>Widerstand 330 Ohm<br>Widerstand 470 Ohm<br>Widerstand 1000 Ohm              |
| 2<br>1                | 60518<br>60958                   | RN1,RN2<br>RN3                                            | 8X3,3,K<br>4x470 Ohm                                                                                                           | Netzwerkwiderstand<br>Netzwerkwiderstand                                                                                                      |
| 1<br>11               | 60248<br>60239                   | C7<br>C1C6,<br>C8C12                                      | 10 uF,Tantal ELKO<br>100 nF                                                                                                    | auf Polung achten !<br>Keramikkondensator                                                                                                     |
| 1                     | 60590                            | T1                                                        | BC 107                                                                                                                         | Transistor                                                                                                                                    |
| 1                     | 60166                            | Q1                                                        | Quarz 14.00 MHz                                                                                                                |                                                                                                                                               |
| 1<br>1<br>1<br>1<br>1 | 10405                            | ST1<br>ST3<br>ST2<br>ST4<br>ST4<br>BU1                    | 7-polige Stiftleis<br>9-polige D-Sub-Buc<br>ECB-Bus 64-polig<br>NDR - Bus 18-polig<br>NDR - Bus 36-polig<br>Monitor Buchse Cin | hse<br>oder<br>, gewinkelt und<br>, gewinkelt                                                                                                 |

## 4.3 Aufbau Schritt für Schritt des GDP64HS Komplettbausatzes bzw. des Aufbausatzes

Auf einer Seite der Leiterplatte steht der Hinweis "Lötseite"; auf dieser Seite wird ausschließlich gelötet. Die Bauteile sind nur auf der anderen Seite (der Bestückungsseite) aufzustecken.

Beim Einlöten der Bauelemente beginnt man am besten mit den ganz flachen Bauelementen. Bevor Sie jedoch beginnen sollten Sie sich Ihren Bestückungsdruck genau ansehen und die Bauelemente mit der Stückliste vergleichen. Eventuell fehlende Bauteile sollten Sie sofort reklamieren.

Demnach sollten Sie alle liegenden Widerstände zuerst bestücken. Dies sind die Widerstände R1 bis R11. Diese Widerstände sind durch Farbcodes zu indentifizieren:

| Widerstand     | Widerstandswert | Farbcode             |  |  |  |
|----------------|-----------------|----------------------|--|--|--|
| R1             | 75 Ohm          | violett-grün-schwarz |  |  |  |
| R2, R6, R7, R9 | 1 kOhm          | braun-schwarz-rot    |  |  |  |
| R3, R4, R11    | 470 Ohm         | gelb-violett-braun   |  |  |  |
| R5             | 150 Ohm         | braun-grün-braun     |  |  |  |
| R8             | 330 Ohm         | orange-orange-braun  |  |  |  |
| R10            | 220 Ohm         | rot-rot-braun        |  |  |  |

Der vierte Strich kennzeichnet die Toleranz und bei diesen Widerständen immer "gold".

Gehen Sie beim Einlöten der Widerstände folgendermaßen vor: Anschlußdrähte der Widerstände rechtwinkelig nach unten biegen und in den entsprechenden Platz auf der Leiterplatte stecken. Achten Sie bitte darauf daß die Widerstände auf der Leiterplatte aufliegen. Auf der Lötseite sollten Sie die überstehenden Enden leicht abbiegen und dann mit einem Seitenschneider abschneiden und verlöten.

Wenn Sie die Baugruppe für den NDR-Computer aufbauen, sollten Sie jetzt die 54-polige abgewinkelte Stiftleiste bestücken. Die Stiftleiste wird als 18-polige und als 36polige Stiftreihe geliefert. Beim Bestücken sollten Sie folgendermaßen vorgehen: Beide Stiftleisten mit abgewinkelten Ende in die vorgesehenen Bohrungen (ST4) stecken; dann die Leiterplatte umdrehen und 4 bis 5 Punkte (an den Enden und in der Mitte einige) verlöten. Jetzt sollten Sie erst auf der Bestückungsseite kontrollieren, ob Steckerleiste parallel geraden Stifte der Leiterplatte liegen und ob sich zwischen den Lötpunkten "Bäuche" gebildet haben. Sollte einer dieser beiden Defekte vorliegen können Sie dies jetzt noch problemlos beheben und dann die restlichen Pins verlöten.

Ist die Steckerleiste bestückt, kommt die arbeitsintensivste Bestückung: Die IC-Sockel. Bei den IC-Sockel gibt es eigentlich nur eines zu berücksichtigen und das ist die richtige Polarisation der Sockel. Jeder Sockel ist mit einer Kerbe versehen, die Pin 1 markiert. Auf dem Bestückungsdruck ist ebenfalls eine Kerbe bei jedem IC-Sockel aufgedruckt. Diese beiden Kerben müssen übereinstimmen (siehe Abb.).

Stecken Sie nun alle IC-Sockel auf. Achten Sie darauf, daß Sie nicht einen 14-poligen in den Platz eines 16-poligen stecken usw. Sind alle Sockel aufgesteckt, ist es hilfreich wenn Sie nach folgender Beschreibung vorgehen:

Legen Sie nun eine feste Pappe, ein Stück Holz oder etwas ähnliches auf alle Bauelemente und drehen dies unter festem andrücken der Pappe mit der Leiterplatte herum und löten von jedem IC-Sockel zwei diagonal gegenüberliegende Pins an. Bevor Sie die restlichen Pins verlöten, sollten Sie auf der Bestückungsseite noch einmal kontrollieren, ob alle Sockel richtia gesteckt worden sind und ob alle auf Leiterplatte aufliegen.

späteres Ändern macht meistens vielmehr Mühe und führt ungeübten Aufbauern oftmals zur Zerstörung Leiterplatte (Leiterbahnen werden abgerissen oder Durchkontaktierungen zerstört usw.).

Die Keramikkondensatoren C1 bis C6 und C8 bis C12 sind ungepolt; sie brauchen hier also nicht auf die Polung zu achten.

Beim Einlöten des Tantalkondensators C7 achten Sie bitte auf richtige Polung. Das "+" auf dem Kondensator muß mit dem "+" auf dem Bestückungsdruck übereinstimmen.

Beim Transistor muß auf die Anschlüsse E,B,C geachtet werden. Der Transistor hat an seinem Umfang eine "Nase". Der PIN, der dieser Nase am nächsten kommt, ist der Emitter (siehe Abb.)



Transistor von unten gesehen Bestückungsdruck

Der Transistor sollte nicht sehr tief hineingesteckt werden, da sonst die Hitze des Lötkolbens ihn zerstören könnte.

Zum Schluß werden die Buchsen und der Quarz bestückt. Beim Einlöten der BAS-Buchse BU1 ist darauf zu achten, daß diese ganz auf der Leiterplatte aufliegt. Die Buchse sollte fest aufliegen, dann erst kann sie eingelötet werden.

Der Schwingquarz ist nicht gepolt und kann somit nicht falsch herum eingelötet werden. Der Quarz kann, wenn er stehend stört auch nach folgender Abb. gelegt werden. Allerdings müssen Sie dann beim Bestücken des Haltewinkels den Quarz so legen, daß die Schraube für diesen noch Platz findet. Das Gehäuse des Quarzes darf Kontakt mit der Schraube bzw. mit Masse haben.



Abb. Einlöten des Quarzes Die Stecker ST1 und ST3, sowie die Jumper JMP1 bis JMP5 werden nicht bestückt. Die Jumper sind auf der Lötseite der Leiterplatte voreingestellt.

Sollten Sie die GDP64HS für den ECB-Bus aufgebaut haben, müssen Sie jetzt noch die 64-polige Messerleiste (ST1) bestücken, und die in folgender Abbildung durch Pfeil gekennzeichnete Brücken auf der Lötseite schließen.

#### Rückwandblech:

Wollen Sie diese Baugruppe in das Gehäuse GEH3 einbauen, so wird ein passendes Rückwandblech benötigt. (Bitte gesondert bestellen) #11211

#### 5. Testanleitung

#### 5.1 Erste Prüfung ohne IC's Komplettbausatz bzw. Aufbausatz

Die Leiterplatte ist bis jetzt erst mit den Sockeln und mit den passiven Bauelementen bestückt. Mit diesem Aufbau wird der erste Test durchgeführt.

Zu diesem Test muß die Baugruppe in den Bus gesteckt werden. Achten Sie beim Einstecken in den Bus, daß Sie die Baugruppe richtig herum einsetzen. Ein falsches Einstecken, z.B. um ein Pin zu weit rechts kann zu Kurzschlüssen führen und kann Bauelemente zerstören.

Nach dem Einstecken der Leiterplatte muß der Rechner weiter problemlos funktionieren. Falls nein - weiter im Kapitel 6.

Man mißt, ob an allen IC-Sockeln die Versorgungsspannung von +5V ankommt. Dabei liegt bei Standard-TTL-Bausteinen jeweils am letzten Pin einer Fassung (z.B. bei 14-poligen an Pin 14, bei 16-poligen an Pin 16, bei 20-poligen an Pin 20), die Versorgungspannung von +5V. 0V bzw. Masse liegt jeweils auf dem letzten Pin der ersten Reihe (bei 14-poligen auf Pin 7, bei 16-poligen auf Pin 8, bei 20-poligen auf Pin 10). Achtung!: Bei den RAM-Bausteinen sind die Plus- und Masse-Anschlüsse genau andersrum (+5V liegt an Pin 8 und GND liegt an Pin 16). Beim Graphik-Prozessor EF 9366 liegt Masse auf Pin 20 und +5V auf Pin 40 (siehe auch Kapitel 9).

Liegt die Versorgungsspannung +5V und 0V (Masse,GND) an den richtigen Pins an, dann können die IC's eingesetzt werden. Dabei muß auf die Richtung der IC's geachtet werden. Die Markierung auf dem IC muß mit der Kerbe in der Fassung übereinstimmen.

#### 5.2 Test der GDP64HS im System

#### 5.2.1 Bestücken der ICs und erste Tests beim Komplettbausatz

Sie können jetzt alle ICs einstecken. Bitte achten Sie darauf, daß Sie die ICs richtig herum einstecken. Die Kerbe auf dem IC muß mit der Kerbe am Sockel bzw. auf dem Bestückungsdruck übereinstimmen. Kontrollieren Sie lieber doppelt, denn wenn ein IC falsch herum eingesteckt ist, ist es garantiert 'tot'.

Haben Sie ein Osszilloskop und wollen die Baugruppe Schritt für Schritt testen, so können Sie auch nach folgender Beschreibung vorgehen:

Zuerst wird nur das IC Jll eingesteckt (IC zur Takterzeugung). Wird die Leiterplatte nun auf den Bus gesteckt, muß an Jll/8 eine Taktfrequenz von 14 MHz zu messen sein.

Wenn dieser Takt anliegt können die restlichen IC's bis auf den EF 9366 (J28) und die Speicherbausteine J16..J23 hineingesteckt werden; aber nicht bei angelegter Spannung!!! Wird danach die Spannung wieder angelegt, muß an IC J28/1 ein 1,75 MHz Signal messbar sein. An J7 müssen folgende Signale zu messen sein:



Bild 8

Anschließend muß die Versorgungsspannung wieder weggenommen und der EF 9366 eingesteckt werden. Einschalten der Spannung muß auf dem Monitor ein abgegrenzdunkles Bild erkennbar sein. Es ist noch keine Bildinformation erkennbar (auch nicht vorhanden). Synchronsignal, das der EF 9366 erzeugt, muß mit dem Oszilloskop am BAS - Ausgang zu messen sein. Wie das Signal aussieht, ist in Kapitel 3 unter 'Daten- übertragung zum Monitor' zu sehen.

Anschließend sollte die Spannungsversorgung der Speicherbausteine J16..J23 kontrolliert werden. Jeweils an Pin 8 müssen 5 Volt anliegen (Masse liegt an Pin 16). Nach Abschalten der Spannung können die Speicherbausteine eingesteckt werden.

#### 5.2.2 Bestücken der ICs und erste Tests beim Aufbausatz

Da die Ausstattung des Aufbausatzes auf die Weiterverwendung von ICs der 'alten' GDP64k abgestimmt ist, sollten Sie diese กแก bereithalten. Beim Entnehmen der benötigten Schaltkreise benützen Sie bitte einen Schraubendreher der Grösse zwei oder drei, bzw. ein Taschenmesser mit schmaler Klinge. Das Werkzeug wird nun vorsichtig von der Stirnseite her in den Spalt zwischen IC und ICs eingeschoben. Durch die Keilform des Schraubendrehers wird Schaltkreis jetzt im vorderen Bereich aus der Fassung Durch leichte Kippbewegungen angehoben. wird Schaltkreis vollständig ausgehebelt. Eventuell verbogene IC-Beinchen werden mit einer Flachzange geradegerichtet. Verwendung eines Taschenmessers können Sie ebenfalls Kippbewegungen durchführen, oder nachdem die Klinge ganz untergeschoben wurde das IC mit Drehbewegungen aus seiner Fassung lüften. Beachten Sie hierbei jedoch die CMOS- Warnung!

Beim Umsetzen der ICs arbeiten Sie sich bitte IC für IC durch, d.h. hier Entnehmen und dort Einsetzen.
Besondere Erwähnung verdienen die ICs J1 und J31 (6-fach Inverter 7405): Im Schaltplan und im Bestückungsplan der GDP64HS werden hierfür LS- Typen vorgesehen. Alternativ können anstatt der LS- Typen aber auch Standardtypen eingesetzt werden, die auf der GDP64k bereits vorhanden sind. Aus diesem Grund sind dem Aufbausatz diese Bausteine nicht beigelegt worden.
Die sonstige Vorgehensweise entspricht der Testamleitung unter Kapitel 5.2.1.

#### 5.2.3 Test im Z80-System

Sind nun alle Bausteine bestückt, kann der Test mit der Software beginnen. Setzen Sie in Ihrem Rechner nur das Grundprogramm ein, so reicht es, wenn Sie die SBC3 (bestückt mit EGRUND2), die KEY bzw. KEY2 und die GDP64HS im BUS stecken haben. Der Monitor wird mit dem Monitorkabel am Monitor und an BU1 der GDP64HS angeschlossen. Nach dem Einschalten der Spannung muß nach einer kurzen Copyright Meldung das Grundmenue des Grundprogrammes erscheinen. Bleibt das Bild dunkel, so sollten Sie erst mal am Kontrastregler des Monitors drehen. Es kann nämlich sein, daß dieser am Anschlag steht und somit kein Bild kommen erscheinen kann.

Haben Sie einen Z80-Rechner mit FLOMON, so genügt es für den ersten Test die SBC3 (mit FLOMON), die KEY bzw. KEY2, eine Speicherkarte mit mindestens 64k RAM (z.B. ROA64, RAM64, RAM256, ROA256/1M) und die GDP64HS einsetzen. Schließen Sie die Tastatur an die KEY und den Monitor an die GDP64HS an. Wenn Sie jetzt den Rechner einschalten, muß das FLOMON-Grundmenü erscheinen. Wenn dieses Menu nicht erscheint, können Sie natürlich noch kontrollieren, ob der Kontrastregler am Monitor richtig eingestellt ist. Bringt dies auch keinen Erfolg, sollten Sie mit Kapitel 6 fortfahren.

#### 5.2.3 Test im 680xx System

#### 5.2.3.1 Test im 68008 System

Zum Test der GDP64HS im 68008-System benötigen Sie als Mindestkonfiguration eine CPU68k, eine ROA64 (mit EASS 0-3 und mindestens einem RAM 8k; eingestellt auf Bank 0), eine KEY bzw. KEY2 und eine GDP64HS. Wenn Sie jetzt die Tastatur an der KEY und den Monitor an der GDP64HS anschließen, und die Spannung einschalten, erscheint nach einer kurzen Copyright Meldung das Grundmenue des Grundprogrammes 68k. Sollte es nicht erscheinen, können Sie wiederum versuchen den Kontrastregler des Monitors richtig einzustellen. Bringt dies keinen Erfolg sollten sie mit Kapitel 6 fortfahren.

#### 5.2.3.2 Test im 68000-System

Zum Test der GDP64HS im 68000 System benötigen sie folgende Mindestkonfiguration: Eine CPU68000, zwei ROA64k (mit EG68000 ODD und EVEN; auf Bank 0 eingestellt), eine KEY bzw.KEY2 und die GDP64HS. Dabei ist zu beachten, daß eine ROA64 auf der "ODD"-Seite (ungerade) der CPU68000 steckt, und die andere auf ROA, die KEY und die GDP64HS auf der "EVEN" Seite gesteckt sein muß (siehe auch CPU68000 Handbuch Seite 5 unten). Nachdem Sie die Tastatur (an die KEY) und den Monitor (an die GDP64HS an BU1) angeschlossen haben, können Sie den Rechner einschalten. Es muß muß das Grundmenü des Grundprogrammes erscheinen. Bleibt der Bildschirm dunkel, sollten Sie den Kontrastregler des Monitors noch einstellen; dieser könnte am Anschlag sein und daher kein Bild zeigen. Bleibt auch dies ohne Erfolg, können Sie mit Kapitel 6 fortfahren.

#### 5.2.3.3 Test im 68020-System

Zum Test der GDP64HS im 68020 System benötigen Sie folgende Mindestkonfiguration: CPU68020, vier ROA64k mit EG68020 auf Bank 0 eingestellt, eine KEY bzw. KEY2 und die GDP64HS. Auch bei dieser Konfiguration sollten Sie darauf achten, daß Sie die Baugruppen an die richtige Stelle im Bezug auf die CPU68020 stecken (siehe hierzu im CPU68020 Handbuch Seite B). Wenn Sie jetzt die Tastatur (an die KEY) und den Monitor an die GDP64HS (an BUI) anschließen, muß das Grundmenu des Grundprogrammes 68k auf dem Bildschirm erscheinen. Sollte kein Bild erscheinen, sollten Sie den Kontrastregler des Monitor noch einstellen; ist dieser nämlich am Anschlag kann kein Bild erscheinen. Bringt dies aber auch nicht den erhofften Erfolg sollten Sie mit Kapitel 6 fortfahren.

#### 5.3 Beispiel und Testprogramme:

#### Beschreibung zu den Testprogrammen:

#### 1. Beispiel: (Buchstaben) (lauffähig ohne Flomon)

Ist das Bit 2 des Registers 70h auf 0, so darf kein Kommando an die GDP gegeben werden, da diese dann beschäftigt ist. Man muß also vor jeder Befehlsausgabe oder jedem Umsetzen eines der anderen Register darauf warten, daß dieses Bit auf eins liegt. (Siehe auch 'Warteschleife' wail ). Im Programm: Aufruf der Warteschleife durch 'call wail'.

Wird der Wert 6 an die GDP geleitet, so erfolgt 'Bildschirm Löschen' und es kann die Ausgabe beginnen. Zuerst wird der Buchstabe 'A' in gewohnter Größe geschrieben. Ofh an 73h bewirkt 'Groß -Schreibung'.Das Zeichen 'B' wird groß auf dem Bildschirm dargestellt. Danach wird wieder auf Kleinschreibung umgestellt (11h nach 73h), und es wird der Buchstabe 'C' geschrieben.

Die Verzögerung gestattet es, das Bild eine Weile anzusehen, bevor wieder ins Betriebssystem zurückgesprungen wird.

#### 2. Beispiel: (Figurenzeichnen mit FLOMON)

Dieses Programm zeigt das Zeichnen verschiedener Figuren auf dem Bildschirm.

Mit dem Befehl 'ld de,Al' wird die unter 'Al' stehende Information eingelesen und mit 'call string' zur Ausführung gebracht.

Mit der Routine 'Eingabe' wird auf einen Tastendruck gewartet. Was die einzelnen Zeichen hinter db.. bedeuten ist dem Programm zu entnehmen.

#### 3. Beispiel: (Vektoren mit FLOMON)

Das dritte Beispiel zeigt die Darstellung von Vektoren, die zu einem sternähnlichen Gebilde zusammengefügt werden. Die Befehle 'clrall' und 'wait' sind FLOMON- Befehle ;ihre Sprungadressen werden am Programm Anfang definiert. 'clrall' löscht alle Bildschirmseiten und 'wait' führt genau das aus, was im vorigen Beispiel in der 'wail' Routine stand. Zunächst werden die X und Y Register geladen (=Anfangspunkt Bildschirmmitte), der Schreibstift gesetzt (PEN down), und die Richtung, in der gezeichnet werden soll, festgelegt. Das Ganze wird in der Schleife 'LOOP' abgearbeitet, die

durch incrementieren von b die Zeichenrichtung ändert.

|                                                             |                                                            |                          |                                                                         | **************************************                                                                                            |
|-------------------------------------------------------------|------------------------------------------------------------|--------------------------|-------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 0070<br>0060                                                |                                                            | gdp<br>seite             | equ 70h<br>equ 60h<br>org 8800h                                         | :BASIS<br>;Seltenadr.                                                                                                             |
| 8800'<br>8802'<br>8804'<br>8807'<br>8809'                   | 3E FO<br>D3 60<br>CD 8839 '<br>3E 06<br>D3 70              | start:                   | ld a,0F0h out (seite),a call wail ld a,6 out (gdp),a                    | ;Seite 3 verwenden<br>;warten bis GDP fertig<br>;Warteschleife aufrufen<br>;Bildschirm löschen<br>;und ausführen                  |
| 880B'<br>880E'<br>8810'<br>8812'<br>8814'                   | CD 8839 ' 3E 03   03 71   3E 41   03 70                    |                          | call wai1 ld a,3 out (gdp+1),a ld a,41h out (gdp),a                     | ;Warteschleife aufrufen<br>;PEN down<br>;PEN-Mode<br>;Zeichen A laden<br>;und ausgeben                                            |
| 8816'<br>8819'<br>8818'<br>8810'<br>881F'                   | CD 8839 ' 3E 0F D3 73 3E 42 D3 70                          |                          | call wail ld a,15 out (gdp+3),a ld a,42h out (gdp),a                    | :Warteschleife aufrufen<br>:* 15 (Zeichen gross)<br>;Zeichen 8 laden<br>;und ausgeben                                             |
| 8821'<br>8824'<br>8826'<br>8828'<br>8828'                   | CD 8839 ° 3E 11 D3 73 3E 43 D3 70                          |                          | call wail ld a,11H out (gdp+3),a ld a,43h out (gdp),a                   | ;Warteschleife aufrufen<br>;* 1 (Zeichen klein)<br>;Zeichen C laden<br>;und ausgeben                                              |
| 882C'<br>882F'<br>8830'<br>8832'<br>8833'<br>8836'<br>8836' | 01 2222<br>0B<br>16 FF<br>15<br>20 FD<br>78<br>B1<br>20 F6 | ; Verzögerung<br>wschl:  | ld bc,2222h dec bc ld d,0ffh er: dec d jr nz,er ld a,b or c jr nz,wschl | ;z.B. 2222 mal durchlaufen<br>;Schleifenanfang<br>;innere Schleife<br>;durch diese Befehle wird<br>;das Flag Register beeinflusst |
| 8839'<br>8838'<br>8830'<br>883F'                            | DB 70<br>E6 04<br>28 FA<br>C9                              | ; Warteschleifd<br>wail: | _                                                                       | ;Warten bis GDP fertig<br>;(Maskierung)<br>;erst wenn fertig<br>;dann nächsten Befehl                                             |

|        |             | . Z80                                   |                            |
|--------|-------------|-----------------------------------------|----------------------------|
|        |             | , ************************************* | ********                   |
|        |             | :* ZEICHENPROGRAMM ra                   | ku 3'87 *                  |
|        |             | *********                               | ********                   |
| 000D   |             | cr equ Odh                              | ;Return-Taste              |
| 0060   |             | seite egu 60h                           | ;Seitenadresse             |
| 0005   |             | system equ 00005h                       | ;Systemadresse             |
| 0024   |             | stop equ '\$'                           | :Ende Eingabeliste         |
|        |             | org 8800h                               |                            |
| 88001  | AF          | start: xor a                            | :Hier wird Seite O         |
| 8801'  | D3 60       | out (seite),a                           | ;verwendet                 |
| 8803   | 11 8820'    | ld de.al                                | ;Einlesen der Liste        |
| 8806'  | CD 880C'    | call string                             | ;ausführen                 |
| 8809'  | C3 8812'    | jp eingabe                              | ;UP Eingabe rufen          |
| 880C ' | OE 09       | string: 1d c,9h                         | ;Zeichenstring zur         |
| 880E ' | CD 0005     | call system                             | :Ausführung bringen        |
| 8811'  | C9          | ret                                     |                            |
| 8812'  | 3E FF       | eingabe:1d a,Offh                       | ;Warten bis                |
| 88141  | 5F          | ld e,a                                  | ;eine Taste                |
| 8815'  | 0E 06       | ld c,6h                                 | ;gedrückt wird             |
| 8817'  | CD 0005     | call system                             |                            |
| 881A1  | FE 00       | cp Oh                                   |                            |
| 881C ' | CA 8812'    | jp z.eingabe                            |                            |
| 881F'  | C9          | ret                                     |                            |
| 88201  | 18 18 47 0D | al: db lbh,lbh,'G',cr                   | ;Zeichenliste (Grafikmodus |
| 88241  | 5A OD       | db 'Z',cr                               | ;Bildschirm löschen        |
| 88261  | 4D 20 31 30 | db 'M 100 100',cr                       | ;Anfangspunkt setzen       |
| 882A1  | 30 20 31 30 |                                         |                            |
| 882E 1 | 30 OD       |                                         |                            |
| 8830'  | 52 20 35 30 | db 'R 50 50',cr                         | ;Rechteck zeichnen         |
| 88341  | 20 35 30 CD |                                         |                            |
| 88381  | 4F 20 33 30 | db '0 30 30 0 360',cr                   | :Kreis zeichnen            |
| 8830'  | 20 33 30 20 |                                         |                            |
| 8840'  | 30 20 33 36 |                                         |                            |
| 8844   | 30 OD       |                                         |                            |
| 88461  | 42 20 48 61 | db 'B Hallo',cr                         | ;'Hallo` schreiben         |
| 884A1  | 6C 6C 6F 0D |                                         |                            |
| 884E'  | 58 20 30 0D | db 'X O',cr                             | ;Rücksprung                |
| 88521  | 41 24       | db 'A',stop                             | zum Alpha-Modus            |
|        |             | END                                     |                            |

|                |         | . z80        |         |            |                 |                           |
|----------------|---------|--------------|---------|------------|-----------------|---------------------------|
|                |         | ;*****<br>;* | Demopro | orann V    | ectoren         | raku 3'87 *               |
|                |         | *****        | *****   | ****       | *****           | ******                    |
| 0070           |         |              | gdp     | equ        | 70h             | ;BASIS                    |
| 0060           |         |              | seite   | equ        | 60h             | ;Seitenadr.               |
| F040           |         |              | clrall  |            | 0f040h          | :Bildschirmseiten löschen |
| F055           |         |              | wait    | equ        | 0f055h          | :Warten                   |
| 0005           |         |              | system  | equ<br>org | 00005h<br>0100h | ;Systemadresse            |
| 0100'          | CD F040 | start:       | call cl | rall       |                 |                           |
| 0103'          | CD F055 |              | call wa | iit        |                 |                           |
| 0106'          | 3E 10   |              | 1d a,01 |            |                 | ;Hier wird Seite 1        |
| 0108'          | D3 60   |              | out (se | eite),a    |                 | ;verwendet                |
| 010A'          | 06 17   |              | ld b,23 |            |                 |                           |
| 0100'          | 0E 20   |              | loop:   | •          |                 |                           |
| 010E'<br>010E' | CD F055 |              | roop.   | call w     | ait             |                           |
| 0111'          | 3E 05   |              |         | ld a,5     |                 |                           |
| 0113'          | D3 70   |              |         | out (g     |                 |                           |
| 0115'          | CD F055 |              |         | call w     | ait             | :Warteschleife aufrufen   |
| 0118'          | 3E 7E   |              |         | 1d a,0     | 7eh             | ;Y-Register low           |
| 011A'          | D3 7B   |              |         | out (g     | dp+11),a        |                           |
| 0110'          | CD F055 |              |         | call w     |                 | ;Warteschleife aufrufen   |
| 011F'          | 3E FF   |              |         | ld a,0     |                 | ;X-Register low           |
| 0121'          | D3 79   |              |         | out (g     | dp+09),a        |                           |
| 0123'          | CD F055 |              |         | call w     |                 |                           |
| 0126           | 3E 03   |              |         | ld a,3     |                 | ;pen down                 |
| 0128'          | D3 71   |              |         | out (gd    | p+1).a          |                           |
| 012A'          | CD F055 |              |         | call w     |                 | ;Warteschleife aufrufen   |
| 0120'          | 78      |              |         | ld a,b     |                 | :Richtung festlegen       |
| 012E'          | D3 70   |              |         | out (g     | dp),a           |                           |
| 0130'          | CD F055 |              |         | call w     |                 | ;Warteschleife aufrufen   |
| 0133'          | 3E 45   |              |         | 1d a,4     |                 | ;laenge X-Richtung        |
| 0135'          | D3 75   |              |         | out (g     | dp+5),a         |                           |
| 0137           | CD F055 |              |         | call w     |                 | -laongo V Dichtung        |
| 013A'          | 3E 50   |              |         | ld a,5     |                 | ;laenge Y-Richtung        |
| 013C'          | D3 77   |              |         | out (g     | dp+7),a         |                           |
| 013E.          | 04      |              |         | inc b      |                 |                           |
| 013F'          | 78      |              |         | ld a,b     | )               |                           |
| 0140'          | 91      |              |         | sub c      |                 |                           |
| 0141'          | 20 CB   |              |         | jr nz,     | 100p            |                           |

```
0143' 3E FF eingabe:ld a,0ffh

0145' 5F ld e,a

0146' 0E 06 ld c,6h

0148' CD 0005 call system

014B' FE 00 cp 0h

014D' CA 0143' jp z,eingabe
```

END

Zum Schluß hier noch ein kleines Programm, welches auf 680xx-Systemen läuft:

In diesem Beispiel wird von den Befehlen 'hebe', 'senke', 'drehe' und 'schreite' Gebrauch gemacht.

Zuerst wird die Schildkröte bei x = 50, y = 50 positioniert, Richtung nach oben. Dann schreitet sie 50 mal schreibend nach oben, hebt an, schreitet 50 mal ohne zu schreiben, wird gedreht und schreibt weiter.

```
;*
        Demo- Programm (Schildkroete)
       fuer 680xx- Systeme
***************
                   ;setzen bei 50/50
move #50,d1
move #50,d2
move #90.d3
                   ;Richtung nach oben
jsr §set
                    ;50 * schreiten und zeichnen
move #100,d0
jsr §schreite
                    ;Schreibstift anheben
isr Shebe
move #50,d0
                    ;50 * schreiten und zeichnen
jsr §schreite
move \#-45,d0
                    ;um 45 Grad drehen
isr §drehe
                    ;Schreibstift absenken
jsr §senke
move #50,d0
                    ;50 * schreiten und zeichnen
isr §schreite
move \#-45,d0
                    ;um 45 Grad drehen
jsr §drehe
                    ;50 * schreiten und zeichnen
move #50,d0
jsr §schreite
rts
```

#### 5.4 Jumperung der Baugruppe

Auf der Baugruppe sind die Jumper JMP1 bis JMP5. Alle diese Jumper sind voreingestellt und müssen bei Standardkonfigurationen auch nicht geändert werden. Hier nun die Beschreibung der einzelnen Jumper:

JMP1: Damit wird in Verbindung mit JMP2 und JMP3 auf den Betrieb mit dem EF 9367 umgestellt. Dabei ist jedoch der 14 MHz- Quarz gegen einen 12MHz- Quarz auszuwechseln.

In der voreingestellten Position von JMP1 wird der EF 9366 bedient.

Beim Einsatz des Videoprozessors EF 9367 ist eine Hardcopy- Funktion bis auf weiteres nicht möglich.

JMP2: JMP2 dient zur Umstellung der Auflösung der GDP64HS.

Die Standardauflösung liegt bei 256 x 512

Bildpunkten. Legt man diesen Jumper um, kann man auch

mit einer Auflösung von 512 x 512 Bildpunkten im

Interlace-Modus (Zeilensprungverfahren) arbeiten.

Allerdings kann dies nur mit dem Graphikprozessor

9367 durchgeführt werden. Außerdem gibt es für diese

Auflösung eigentlich keine Software, da das Flimmern

des Interlace Modus wohl meistens als störend

empfunden wird.

JMP3 dient nur dazu einzustellen, welcher Graphikprozessor verwendet wird (9366 oder 9367). Voreingestellt ist der 9366.

JMP4: JMP4 ist in drei Abschnitte aufgeteilt. Die oberen 2 Brücken dienen zum Invertieren des Videosignales. Die Brücken 3 und 4 dienen zum Invertieren des HSync-Signales und die Brücken 6 und 7 zum Invertieren des Vsync-Signales.

JMP4 0 1 0 0 2 0 0 3 0 0 4 0 0 5 0 0 6 0

Videosignal invertiert: 1 gebrückt, 2 offen Videosignal nicht invertiert: 2 gebrückt, 1 offen HSYNC invertiert: 3 gebrückt, 4 offen HSYNC nicht invertiert: 4 gebrückt, 3 offen VSYNC invertiert: 5 gebrückt, 6 offen VSYNC nicht invertiert: 6 gebrückt, 5 offen

JMP5: JMP5 dient lediglich dazu, das VSYNC-Signal auf den INT zu legen. Dieser JMP ist natürlich offen.
JMP5 wurde vorgesehen, um einen definierten Interrupt von 20 ms erzeugen zu können. Dies ist eventuell für Multitasking-Aufgaben interessant. Sonst bleibt dieser Jumper immer offen.

#### 6. Fehlersuchanleitung

Sollte Ihre Baugruppe bei den in Kapitel 5 beschriebenen Tests nicht funktionieren, so heißt es jetzt systematisch auf Fehlersuche zu gehen.

Wir wollen Ihnen nun ein paar Vorschläge machen, wie eine systematische Fehlersuche mit und ohne Oszilloskop vor sich gehen kann:

#### 6.1 Mögliche Fehler und ihre Behebung

- 6.1.1 Sind die bisher verwendeten Baugruppen in Ordnung? (Funktionierte das System ohne die Baugruppe GDP 64K?)
- 6.1.2 Sind die Jumper richtig gesteckt?
- 6.1.3 Machen Sie zuerst eine Sichtprobe. Können Sie irgendwo auf Leiterplatte unsaubere Lötstellen (zuviel Lötzinn, manch- mal zieht das Lötzinn Fäden) erkennen, die eventuell einen Kurzschluß verursachen könnten? Dann müssen Sie diese Lötstellen nachlöten und die unzulässige Verbindung beseitigen.
- 6.1.4 Haben Sie auch alle IC's richtig herum und am richtigen Platz eingesteckt? (Vergleiche mit Bestückungsplan)
- 6.1.5 Sind alle gepolten Bauteile (Elkos, Dioden, usw.) richtig herum eingelötet?
- 6.1.6 Haben Sie auch keine Lötstelle vergessen zu löten? (sehen Sie lieber noch einmal nach)
- 6.1.7 Sehen Sie irgendwo "kalte" Lötstellen? Kalte Lötstellen erkennt man daran, daß sie nicht glänzen, sie sind im Vergleich mit richtig gelöteten Lötstellen trübe.
- 6.1.8 Haben Sie auch nicht zu heiß gelötet? Wenn der Lötkolben zu heiß eingestellt ist und (oder) Sie zu lange auf der Lötstelle bleiben, dann kann es passieren, daß sich die Leiterbahnen von der Platine lösen und Unterbrechungen bilden. Ferner kann es auch passieren, daß Durchkontaktierungen unterbrochen werden, oder daß Bauteile durch zu heißes Löten zerstört werden.
- 6.1.9 Nehmen Sie alle IC's aus ihren Fassungen. Schauen Sie sich beim herausnehmen die IC-Füßchen genau an. Manchmal sind Füßchen umgeknickt oder steckten daneben. Nehmen Sie sich die Layouts zur Hand und kontrollieren Sie alle Leiterbahnen, mit einem Durchgangsprüfer oder mit einem Ohmmeter auf Durchgang. Bereits kontrollierte Leiterbahnen können Sie, der Übersicht wegen, auf dem Layout mit Bleistift durchstreichen oder mit Farbstiften nachziehen.

6.1.10 Prüfen Sie die Versorgungsspannung mit einem DigitalVoltmeter (am Bus +5V, nicht am Netzgerät, da am
Kabel bei starker Belastung bis zu 0,5V abfallen
können). Toleranzen von +/- 5% also von 4,75V bis
5,25V sind erlaubt. Falls die Spannung zu gering ist,
prüfen Sie, ob die Verbindung vom Netzteil zum
Bus mit ausreichend dickem (mind. 2 mm Quadrat)
Kabel erfolgt ist. Gegebenenfalls müssen Sie Ihr
Netzteil nachregeln. Vorsicht: nie über 5,1V
nachregeln, da sich auf einigen Platinen 5,1V
Zenerdioden befinden, die ab 5,1V durchschalten, was
entweder zum Zusammenbruch Ihrer Versorgungsspannung
führt oder die Zenerdiode bis zu Ihrer Zerstörung
erhitzt.
Übrigens: Wir empfehlen 5,05V.

Wenn Sie alle Leiterbahnen kontrolliert und nichts gefunden haben, dann ist die Wahrscheinlichkeit groß, daß ein Bauteil defekt ist.

Wenn Sie einen Prüfstift oder ein Oszilloskop haben, dann können Sie jetzt überprüfen, ob an den jeweiligen Ausgängen die richtigen Signale anliegen. Welche Signale wo anliegen müssen, können Sie aus der Schaltungsbeschreibung und aus dem Schaltplan entnehmen.

Falls Sie keine Meßgeräte haben, dann müssen Sie alle Bauteile systematisch austauschen, bis Sie das Defekte gefunden haben. Verwenden Sie dazu eventuell eine zweite Baugruppe (die eines Freundes oder eines Bekannten).

Sollten Sie gar nicht zurande kommen, hilft Ihnen unser Pauschal-Reparatur-Service, dessen Bedingungen Sie der Preisliste entnehmen können.

#### 7. Schaltungsbeschreibung

#### 7.1 Wie funktioniert die Baugruppe?

Das Herz der GDP64HS ist der Graphik Display Prozessor EF 9366 für 512 mal 256 Bildpunkte. Es könnte aber auch der EF 9365 oder der EF 9367 verwendet werden, dazu müssen aber die Brücken JMP1, JMP2 und JMP3 verändert werden. Standard ist die Bestückung mit dem EF 9366, auf den auch die gesamte Software abgestimmt ist.

Der GDP J28 ist an den Datenbus und an die Adressbits A0...A3 angeschlossen. Die vier Adressbits bewirken, daß eines der 16 GDP-Register ausgewählt wird. Über den Datenbus kann dann in das gewählte Register geschrieben bzw. vom gewählten Register gelesen werden. Der Datenbus des Graphikprozessors ist außerdem noch durch einen biderektionalen Treiber (J27) vom Systemdatenbus getrennt, der nur dann aktiviert wird, (J27/19) wenn auf ein Register des GDP zugegriffen wird (Portadressen 70h bis 7Fh). Die Richtung des Datentransfers wird durch das READ-Signal festgelegt (J27/1).

Die Ausdekodierung der Adressen 70h bis 7Fh übernimmt der 3 zu 8 Dekoder (J30). Wird eine Portadresse 70h bis 7Fh angesprochen, so wird der Ausgang 7 (J30/7) aktiviert (low). Dieser Ausgang steuert die Enable-Eingänge des Graphikprozessors (J28/17) und des bidirektionalen Treibers (J27/19).

Die Ausdekodierung der Adressen 60h und 61h übernimmt zum Teil auch der 3 zu 8 Dekoder 74LS138. Der Ausgang Y6 (J30/9) wird aktiviert, wenn eine Adresse von 60h bis 6Fh angesprochen wird. Die Selektion der Adressen 60h und 61h aus diesen 16 Portadressen übernimmt der zweite 3 zu 8 Dekoder (J29). An dessen Ausgang Y0 (J29/15) liegt dann ein Low-Signal an, wenn auf Port 60h zugegriffen wird. Der Ausgang Y1 (J29/14) wird aktiv (LOW), wenn auf Port 61 zugegriffen wird. Soll z.B auf Port 60 (Seiten- und RMW-Port) geschrieben werden, so wird der Ausgang J29/15 low, ebenso ist das Signal -WR LOW. Dadurch wird der Ausgang des ODER J3/8 low, was das Latch J24 dazu bewegt neue Daten aufzunehmen. Mit dem Inhalt dieses Latches kann die Schreib- und Lesseite eingestellt, sowie das Steuerbit für RMW gesetzt werden (siehe Abb.).

| 1 | 7 | ! | 6     | ! | 5 | ! | 4 | !   | 3   | !   | 2   | 1   | 1   | 1  | 0     | ! |
|---|---|---|-------|---|---|---|---|-----|-----|-----|-----|-----|-----|----|-------|---|
|   |   |   | <br>! |   |   |   |   |     |     |     |     |     |     |    | <br>! |   |
|   | 1 |   | 1     |   | ! |   | ! |     |     |     |     | RM  | W   |    |       |   |
|   | ! |   | 1     |   | ! |   | 1 |     |     |     |     |     |     |    |       |   |
|   | 1 |   | 1     |   | ! |   | ! |     |     |     |     |     |     |    |       |   |
|   | İ |   | 1     |   |   |   |   | - I | ese | sei | te  | 0 b | is  | 3  |       |   |
|   | 1 |   | 1     |   |   |   |   |     |     |     |     |     |     |    |       |   |
|   |   |   |       |   |   |   |   | - S | chr | eib | sei | te  | 0 b | is | 3     |   |

RMW: Bit 0 = LOW RMW nicht aktiviert
Bit 0 = HIGH RMW aktiviert
Die Schreib- und Leseseite kann universell eingestellt wer-

den. Man kann z.B. im Hintergrund schreiben, also Lese- und Schreibseite verschieden wählen, oder man kann die Seiten wechselseitig hin und herschalten, um zwei Seiten qasi gleichzeitig sichtbar zu haben. Die Seiten können synchron (nach einem VSYNC-Signal) oder asynchron (zu einem beliebigen Zeitpunkt umgeschalten werden.

Damit es hierbei nicht zu Kollisionen kommen kann, dient J12, ein 2 mal 4 zu 1 Multiplexer, als Umschalter für die

Videospeicherseiten (je 16kB).

Zunächst sei die Brücke (Jumper) JMP2 auf der Stellung '9366' (Ist auf der Platine bereits realisiert). Damit ist nur der obere Teil des Multiplexers (J12) maßgebend. J12 erzeugt mit seinen Ausgang 1Y (J12/7) das jeweils höchstwertige Adressbit Al5 bzw. A7 der gemultiplexten Adresse, deren Wertigkeiten von der gewählten Seite abhängig sind. Abhängig von der Information an den Select- Eingängen A und B (J12/14,2) wird einer der Eingänge 1CO...1C3 (J12/6,5,4,3) auf den Ausgang 1Y (J12/7) durchgeschaltet. Die logischen Pegel an den Eingängen 1CO und 1C1 (J12/6,5) bestimmen die Seite, aus der gelesen werden soll, 1C2 und 1C3 (J6/4,3) definieren die Schreibseite (vgl. auch obige Abbildung). Die Taktaufbereitungslogig (J8 und J7) sorgt dafür, daß die Adressbits im für die Speicher richtigen Timing erzeugt werden.

Bild 9 zeigt beispielsweise folgende Betriebsart: Auf Seite 1 einschreiben und die Seite 0 auslesen. Die Signale S153/1C0 und S153/1C1 liegen auf low (entspricht Seite 0). Das Signal S153/1C2 liegt auf high und S153/1C3 liegt auf

low, somit ist Seite 1 zum Beschreiben angewählt.

In der ersten Hälfte des Timingdiagrammes ist BLK (Signal S153/B) aktiv, d.h. der EF9366 ist mit der Bildausgabe aus Speicherseite O beschäftigt. Das Signal S153/1Y repräsentiert die Adressleitungen Al5 bzw. A7, jenachdem ob eine Spaltenadresse oder eine Zeilenadresse ausgegeben wird.

Al5 bzw.A7 sind hierbei erwartungsgemäß low.

In der zweiten Hälfte des Timingdiagrammes (Bild 9) ist die Leitung BLK (Signal S153/B) unwahr geworden; es wird in die DRAMs eingeschrieben. Man erkennt, daß Signal S153/IY seine Polarität wechselt: Wenn die fallende Flanke von RAS auftrit (geschieht ca. 150ns vor CAS, das sind rund 100% der Zeitdauer von CAS) ist Al5 low und bei CAS ist A7 high. A15 und A7 sind aber ja ein- und- dasselbe Signal (hier S153/IY). Signal RAS wurde hierbei nicht explizit aufgenommen, da es ja acht dieser Leitungen gibt.

#### NICOLET PARATRONICS



Bild 9

Seitenanwahl und Adressbiterzeugung. Zur Zeitintervallabschätzung: Der Beobachtungszeitraum beträgt 5us.

Wenn die RMW-Logik aktiviert wird, bewirkt sie eigentlich nichts anderes, als daß sie Dateneintragungen vom GDP aus in den Videospeicher abfängt, wenn es erforderlich ist modifiziert und schließlich in die vorgesehene Speicherstelle einschreibt. Dieser Ablauf ist natürlich sehr zeitkritisch, da während der Zeitdauer eines normalen Schreibzyklus zuerst noch gelesen und dann geschrieben wird.

RMW verändert also den Videospeicherinhalt, ohne daß es der GDP mitbekommt.

Dies ist dann nützlich, wenn z.B. auf ein zum Teil weißes Bild noch gezeichnet werden soll. Ohne RMW wird dann Weiß auf weiß gezeichnet, was dann natürlich unsichtbar ist. Mit RMW wird der Inhalt des Speichers erst einmal "angeschaut" (weiß oder schwarz) und dann entsprechend mit dem neuen Speicherinhalt modifiziert, d.h. wird auf einen hellen Hintergrund ein helles Rechteck gezeichnet, so erscheint dies mit RMW schwarz und ist damit sichtbar. Sehr nützlich ist dies z.B. für einen Maus-Zeiger, da dieser durch zweimaliges Zeichnen wieder verschwindet, ohne daß das Hintergrundbild zerstört wird.

Der Read-Modify-Write Vorgang kann in drei Schritten erläutert werden:

#### 1.READ

Will der GDP in eine Speicherzelle (1Bit) schreiben, wird die Leitung WE (Write Enable) am DRAM- Baustein kurzfristig "künstlich" auf high gehalten. Da jedoch die übrigen Signale wie Adressen, CAS und RAS stimmen, glaubt sich der betroffene DRAM- Baustein im Lese-Modus und gibt die gewünschte Bitinformation auf den internen Datenbus.

Im Timingdiagramm (Bild 10) ist zu erkennen:
RMW- Modus ist eingeschaltet (Signal RMWENABL ist high).
Der GDP 9366 leitet einen (vermeindlichen) WRITE-Zyklus ein (Signal 9366/-WR ist auf low und die Signale J16/-RAS und -CAS werden nacheinander low).
Der Baustein J16 befindet sich jedoch im Lesemodus (Signal 4164/-WR ist noch high) und gibt ein Bit aus (Signal J16/DO wird low). Die übrigen sieben DRAM-Bausteine sind nicht angesprochen, deren Datenausgänge sind hochohmig (Signale J20/DO, J22/DO, J23/DO, J17/DO und J18/DO sind high, da für Logik- Analysator tristate und high nicht unterscheidbar sind).
Die Wertigkeit (low) des Datenausgangsbit von J16 besagt, daß an dieser Stelle momentan ein heller Bildpunkt ist.

#### 2.MODIFY

Ist die Speicherinformation ausgelesen, wird sie nach folgendem Schema mit dem neuzuschreibenden Speicherinhalt verknüpft:

| altes Pixel                                                          | neues Pixel                                                          | tatsächliches Pixel                                                         |
|----------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------------------------------------------|
| hell (Bit =0)<br>hell (Bit =0)<br>dunkel (Bit =1)<br>dunkel (Bit =1) | hell (Bit =0)<br>dunkel (Bit =1)<br>hell (Bit =0)<br>dunkel (Bit =1) | <pre>dunkel (Bit =1) !! dunkel (Bit =1) hell (Bit =1) dunkel (Bit =1)</pre> |

(Pixel kommt von "picture element" und heißt: Bildpunkt, Bildelement.)

In Bild 10 ist zu erkennen, wie die Datenleitung, die zu den DRAM- Bausteinen führt (Signal 4164/DI), High- Potential annimmt. Das heißt, das tatsächliche Bildelement (Pixel) wird dunkel gezeichnet, obgleich der Prozessor 9366 ein helles Bildelement schreiben wollte (Signal 9366/DIN ist während der Beobachtungszeit low).

#### 3.WRITE

Das so behandelte Datenbit wird erst jetzt in die Speicherstelle eingetragen, indem die WR- Leitung low gezogen wird (Signal 4164/WR), noch bevor die Auswahl des Bausteins J16 beendet wird (-CAS und J16/-16 gehen wieder auf high). ist ein

Wenn die Signale CAS und RAS unwahr werden,

RMW- Zyklus abgeschlossen.



Bild 10

Timing eines RMW- Zyklus.

Zur Abschätzung der Zeitintervalle: Der gesamte dargstellte Zeitraum beträgt 500ns.

Schaltungstechnisch wurde dies mit nur wenigen Gattern realisiert. Da beim Schreiben auf der GDP64HS immer nur ein Bit geschrieben wird, ist auch immer nur einer der Speicherausgänge aktiv, die Ausgänge der anderen Speicher sind im hochohmigen Zustand. Dadurch können alle Speicherausgänge (siehe Bild 10, Signale J16/DO, J22/DO, J23/DO, J17/DO, J18/DO) auf ein Achtfach- NAND (J2/1,2,3,4,5,6,11,12) gelegt werden. Ist der Speicherausgang high (Bildpunkt dunkel), ist J2/8 invertiert, also auf high. Ist der der Ausgang Speicherausgang aber low, so ist der Ausgang J2/8 auch invertiert, also auf high (Bildpunkt hell) (siehe Bild 10, Signal -PIXEL). Das AND- Gatter (J5/9,10,8) dient lediglich dazu, den RMW zu sperren oder freizugeben. Ist das RMW-Bit gesetzt, geht das ausgelesene Bit weiter (zu J10/2), wenn nicht, wird es hier abgeblockt. Das ODER- Gatter (J10/1,2,3) vergleicht den ausgelesenen Speicherinhalt (durch J2 invertiert) mit dem einzuschreibenden Bit. War der ausgelesene Punkt hell (Low-Signal), liegt wegen der Invertierung an J2 ein High Signal an J10/2. Soll jetzt wieder ein heller Punkt geschrieben werden (also low), so wird der Ausgang J10/3 high und es wird ein dunkler Punkt in den Speicher geschrieben (siehe Bild 10, Signal4164/-WR).

Die Verzögerung des Write-Signales für die DRAM- Speicher wird mit dem Load-Signal (J7/9) realisiert (siehe Bild 10, Signale LOAD und 4164/-WR). Mit J5/4,5,6 kann dieses Load-Signal mit Hilfe des RMW- Bits wieder gesperrt werden. Das OR-Gatter (J10/12,13,11) läßt ohne RMW das Schreibsignal DW (J28/14) original vom GDP passieren und mit RMW das Load-Signal .

Wird auf den Port 61h geschrieben, so wird J29/14 aktiviert und gleichzeitg der Ausgang J3/6. Dadurch wird auf den Scroll-Port (J26) ein Byte übergeben. Der Wert dieses Bytes (von 0 bis 255) wird als "Scroll-Wert" zur horizontalen Adresse aufaddiert. Wird z.B. der Wert 40h auf Port 61h ausgegeben, so wird der Bildschirminhalt um 40h = 64 dezimal Punkte nach unten gescrollt. Der Rest, der unten vom Bildschirm verschwindet, wird oben wieder hineingeschoben (zyklisches Rotieren des Bildschirmspeichers). Der kleinste Wert, der beim Scrollen eine Wirkung zeigt, ist zwei, da die Datenleitung DO nicht an den Scrollport 61h angeschlossen ist. Steuerung des Hardscrolls wird von dem -BLK und dem Steuersignal für den Seitenport (J6/6) gesteuert. Diese beiden Signale werden ODER-verknüpft (J4/1/2/3) und ergeben ein vorgezogenes CAS- Signal für die Addierlogik. Addition der Scroll- Werte wird nur bei CAS durchgeführt, und außerdem nur im Display Modus, um den Schreibzugriff und den Refresh des Speichers nicht zu stören. In Bild 11 sind Signale LS74/6 und -BLK, die ODER- Verknüpft das Signal LS32/3 ergeben. Dieses verfrühte CAS- Signal aktiviert das Datenlatch ALS574 (J26/1); damit wird der Scrolloffset an die Addierer J14 und J15 angelegt. Mit dem Aktivieren des Latches J26 wird zugleich der Übertragseingang CI (Carry In) des niederwertigeren Addierers (J15/7) auf low gesetzt. Die Addition des Scrolloffsets zur horizotalen Adresse Bild 11 folgendermaßen nachzuvollziehen: Nachdem Signal LS32/3 aktiv wird (=low), liegen am Addierer J15 der niederwertigere Teil der Horizontaladresse (=90h) (Signale DAD3...DAD6) und der Offsetwert 02h (Signale D4..D1) an. DAD3 hat hierbei die höchste Wertigkeit und DAD6 die Niedrigste. Die Signale M3...M6 präsentieren das Ergebnis der Addition, nämlich 92h. Auch hierbei ist M3 höherwertiger als M6. fallenden Flanke von -CAS können nun die DRAM-Speicherbausteine die manipulierte Horizontaladresse übernehmen. Nachdem das Scrollen faktisch erledigt ist, wird der Latchbaustein J26 wieder hochohmig geschaltet (Signal LS32/3 wird high) und an den Eingängen der Addierer J14, J15 liegen High- Pegel an (Sicherheitshalber ist RN2 als Pull-Up- Widerstandsnetzwerk eingesetzt worden). Damit aber nicht OFFh zu jeder folgenden Adresse hinzugezählt wird, wird gleichzeitig der CI- Eingang des nieder-wertigeren Addierers (J15/7) mit High- Pegel beschaltet (0FFh + 01 = 00). Effektiv wird also zu den verikalen Adressen Null dazugezählt.

#### NICOLET PARATRONICS



Bild 11

Timingdiagramm beim Hardscroll.

Dargestellt sind die Signale rund um den Addierer J15 (Manipulation des niederwertigeren Teils der Horizontal-adresse).

Zum Abschätzen der Zeitintervalle: Der Beobachtungszeitraum erstreckt sich über 500ns.

Der Bildschirmspeicher kann über Port 60h rückgelesen werden. Dabei muß allerdings die Adresse des rückzulesenden Bytes im Bildschirmspeicher an das X- und Y-Register des Graphikprozessors übergeben werden und anschließend ins Kommandoregister der Befehl OFh eingetragen werden. Ist der Graphikprozessor im Display-Mode an der eingestellten Adresse angekommen, legt der Graphikprozessor das Signal MFREE auf low und beim nächsten Ladeimpuls (J7/9) wird der Datenwert ins Latch J25 übernommen. Dieses Byte muß nun über Port 60h eingelesen werden, bevor das Ganze wieder von neuem beginnt (Setzten der neuen Adresse, Befehl OFh ausgeben, warten bis Adresse im Display erreicht).

In Bild 12 wird beispielsweise der Wert FEh aus dem Videospeicher ausgelesen. Bevor dieses Bild aufgenommen werden konnte, wurde auf den dunklen Bildschirm an der Stelle x=256 und y=128 ein heller Punkt gezeichnet (Kurzvektor). Danach wurden die selben x- und y- Werte in die oben erwähnten xlsb- und ylsb- Register des EF9366 eingetragen. Normaler-

weise sind die Pixelkoordinaten mit den Speicheradressen nicht identsch, in diesem Fall funktioniert es aber. Nachdem der Wert OFh in das CMD- Register geschrieben ist, aktiviert der GDP beim Erreichen der vorgegebenen Speicheradresse die Leitung MFREE (Signal -MFREE wird low). Seitens des EF9366 wird nur ein Bildpunkt angesprochen, denn die Leitung -ALL ist schon am Anfang des Beobachtungszeitraumes unwahr (Signal -ALL ist high). Ist jedoch die Brücke JMP1 vor dem NAND- Gatter (J8/1,2,3) in der voreingestellten Position, wird der Demultiplexer 25LS2538 (J9) mit Hilfe der Gatter (J8/1,2,3) und (J8/4,5,6) dazu bewegt, alle -RAS- Leitungen auf low zu legen (siehe Signale -MFREE, -ALL, J8/3 und J7/OC).

J8/1,2,3 verknüpft die Ausgänge -ALL und -MFREE des GDP (J28), siehe Bild 12, Signale -MFREE, -ALL und J8/3. Eine Freigabe (Enable) des Demultiplexers J9 wird unterbunden, da die Enable- Eingänge -E1, -E2, E3, E4 zum Teil unwahre Information erhalten. Eingang -E1 wird von -DW des EF9366 angesteuert und ist zu diesem Zeitpunkt wahr, ebenso wie E3 (siehe Bild 12, Signal J7/QC). Die Eingänge -E2 und E4 des J9 sind hingegen unwahr beschaltet (siehe Bild 12, Signale J8/3, J8/6).

Der POL-Eingang des Multiplexers J9/12 schaltet alle Ausgänge in ihrer Polarität um. Ohne ein Lowsignal an POL zu diesem Zeitpunkt, wären alle Ausgänge von J9 auf '1'; durch POL=0 werden sie zu '0', d.h. alle Speicher erhalten ein identisches -RAS, das die Ausleseadresse definiert.

Damit geben alle acht DRAM- Bausteine ihre angewählte Bitinformation an den Latchbaustein (J25/3,4,7,8,13,14,17,18). In Bild 12 sind das die Signale DO, D1, D2, D3, D4, D5, D6 und D7. Die Signale D1...D7 repräsentieren hierbei Bildpunkte links vom Punkt x=256 und y=128 in der gleichen Bildzeile.

Mit dem Auftreten des nächsten LOAD- Impulses (negative Logik) erhält Latch J25 einen Clock- Impuls vom ODER-Baustein (J3/11) und speichert die Bildschirminformation (in Bild 12 die Signale -MFREE, LOAD und J25/CLK).

Befände sich JMP1 in seiner alternativen Position, würde der Demultiplexer J9 normal arbeiten können; nur ein Bit würde ausgelesen werden. Alle übrigen Datenausgänge währen hochomig und der Hauptprozessor (Z80 oder 680xx) würde sie als high erkennen. JMP1 wird jedoch nur beim Betrieb des EF 9367 umgesteckt, um die übrigrn GDP- Funktionen zu ermöglichen, ein Rücklesen des Videospeicherinhaltes ist damit (noch) nicht möglich.



Auslesen des Videospeicherinhaltes (hier Datum FEh). Zum Abschätzen der Zeitintervalle: Der Beobachtungszeitraum beträgt lus.

Der Arbeitstakt der GDP64HS wird über den Quarz Q1 und dem Taktgenerator J11 erzeugt. Es sollte darauf geachtet werden, daß auf Grund der hohen Taktrate ein 7404 ohne LS eingesetzt wird! Der Bildpunkttakt liegt am Punkt C der 7-poligen Stiftleiste am oberen Platinenrand.

Der 14MHz Bildpunkttakt führt direkt zum Schieberegister J13 (wird später erwähnt) und zum Zähler J7, der die sonstigen im System benötigten Signale erzeugt. J7 zählt von 8 bis F und lädt sich nach Überschreiten von 'F' wieder selbst über die Eingänge A, B, C und D (J7/3,4,5,6). Der Grundtakt steuert das Schieberegister J13 über J13/7 (Punkttakt der Graphik). Weiter führt er zum Videomischer J4/10. Dadurch ergibt sich ein Punkttakt von 71 ns. Der Grundtakt der mit dem Zähler J7 maximal durch acht geteilt wird, ergibt einen Systemtakt von 1,75 MHz, der am Ausgang J7/12 ansteht und als CK zum GDP geführt wird.
Über IC J8/8 wird das CAS - Signal für die Speicher erzeugt.

Um Störungen zu vermeiden, darf in ein Bild nur dann geschrieben werden, wenn der Strahl außerhalb des darstellbaren Bereiches liegt. Der GDP (J28) teilt dies durch seinen BLK- (Blank) Ausgang J28/25 mit, der an den Eingang B von J12 8J12/2) gelegt ist. Der Eingang A wird von einer Taktflanke, die mit J6 zwischen RAS und CAS liegt, belegt. Dadurch wird die Adresse einer aktuellen Seite nur zum erlaubten Zeitpunkt umgeschaltet, da die dynamischen Speicher die Adressinformation ja sequentiell angelegt bekommen.

In Bild 13 sind diese Signale nocheinmal abgebildet.



Bild 13

Takterzeugung.

Zur Abschätzung der Zeitintervalle: Der Beobachtungszeitraum erstreckt sich über lus.

Der EF 9366 übergibt eine 14 Bit große Adresse für

Bildpunkte auf einmal (Byte) an seinen Ausgängen DADO (J28/37)...DAD6 (J28/59). Aufgrund einer Eigenart des EF9366 erscheint am Ausgang DADO das jeweils höchstwertigste Adressbit und an DAD6 das Niederwertigste. Die Byteadressen werden gemultiplext, d.h. da nur sieben Ausgänge vorhanden sind, wird die Adresse auf zweimal übertragen; zuerst die Niederwertigen dann die höherwertigen sieben Bit. Vorgang wird durch die Signale CAS und RAS gesteuert, und zwar jeweils zur abfallenden Flanke von RAS bzw. CAS wird ein Adressteil übernommen. Die Adressausgänge DAD führen über die Addierstufen J14 und J15 zu den DRAMs. lichkeit werden die 64kBit- DRAM- Bausteine aber mit zwei mal acht Adressbits versorgt, wobei das achte Bit durch die zusätzliche Hilfslogik mit J12 (Seitenlogik) erzeugt wird. Mit den Ausgängen MSL0 (J28/6)...MSL2 (J28/7) kann der EF9366 darüberhinaus auch noch einzelne Pixel adressieren (Auswahl eines von acht DRAM- Bausteinen). Sie werden zum geleitet, einem 3 zu 8 Decoder mit einigen Baustein J9 Besonderheiten: decodiert die an seinen Eingängen (A,B,C) anstehende Information und schaltet jeweils einen Ausgang J9 /11,9,8 usw. auf low. Dadurch wird ein RAS erzeugt, und die dem jeweiligen Speicherchip übergeben. Adressen Besonderheit von J9 ist, daß sich die Polarität der Ausgänge J9/11,9,8,18,19,1,2,3 mittels des Einganges POL (J9/12) steuern läßt: Wenn POL auf high ist, herrscht am Ausgang negative Logik vor, wenn POL auf low ist, sind die Ausgänge auf positive Logik eingestellt. Dieser Effekt wird u.a. im Rücklesemodus ausgenutzt. Desweiteren können alle Ausgänge mit vier Enable- Eingängen gesperrt werden. Dabei nehmen

Die Ausgabedaten der RAM's führen an die Eingänge des 8-Bit Schieberegister J13. Jeweils zu Beginn eines neuen Taktschrittes werden die 8 Punktdaten hier übernommen, gesteuert durch den LOAD- Impuls von J7. Während der Blank-Zeit, gesteuert durch BLK (J28/25), wird der LOAD- Impuls an ODER-Gatter J4/12,13,11 unterbunden. Im Schieberegister J13 wird

alle Ausgänge gleichen Pegel an. Ob sie entweder high oder low werden, hängt von der Information am POL- Eingang ab.

die feste '1' des 'Serial Inputs' (J13/1) übernommen. Eine '1' entspricht einem dunklen Bildpunkt.

Die aus dem Schiebregister hinausgeschobenen Daten (J13/13) werden am ODER- Glied (J4/9,10,8) mit dem Punkttakt (14 MHz) verknüpft und der Mischstufe zugeführt. Sie besteht aus den Invertern (J1/9,8), (J1/13,12), den Widerständen R1...R3 und dem Transistor T1. Hier wird noch ein Synchronisationssignal, das vom GDP generiert wird (J28/34), hinzuaddiert. Das Signalgemisch steht mit einem Quellwiderstand von 75 Ohm zur Verfügung. Am Ausgang BU1 liegt dann das BAS-Signal an. Am Ausgang ST3 liegen die Video-Signale mit TTL-Pegel an, wobei die Synchronsignale und das Video-Signal jeweils invertiert werden können (JMP4/x).

#### 7.2 Hinweise zum Monitoranschluß:

VS - Signal: Eine logische Eins geht direkt an ST3/9 (nichtinvertiert) wenn JMP4/6 gesetzt ist. Ist JMP4/5 gesetzt, wird das VS - Signal negiert an ST3/9 geführt.

HS - Signal: Eine logische Eins geht direkt an ST3/8 wenn JMP4/4 gesetzt ist.

Ist JMP4/3 gesetzt, wird das HS - Signal negiert an ST3/8 geführt.

VI - Signal: Eine logische Eins geht direkt an ST3/7 wenn JMP4/2 gesetzt ist. Ist JMP4/1 gesetzt, wird das VI - Signal negiert an ST3/7 geführt.

Bei Verwendung eines normalen Monitors wird die BAS- Buchse BU1 verwendet, soll ein TTL-Monitor z.B. ein IBM - Monitor angeschlossen werden, benötigt man das Viedeo-Signal (nur Bildinformation) und zusätzlich die Synchronisationssignale (HS und VS). Deshalb wird der Monitor an ST3 angeschlossen. JMP4 ist so eingestellt, daß ein IBM-Monitor funktioniert. Bei kompatiblen Monitoren kann allerdings, aufgrund der verschiedenen Horizontal Synchronfrequenzen auftreten, daß der Monitor nicht synchronisiert. Sollten Sie diese Frequenz am Monitor nicht per Drehpotentiometer verändern können, besteht keine Möglichkeit den Monitor anzuschließen.

ST1 verwendet man intern für Messzwecke oder zum Anschluß der alten HCOPY/MAUS Baugruppe.

### 8. Anwendungsbeispiele

### 8.1. Grafikzeichen direkt eingeben:

Nach dem Einschalten erscheint (mit CPU Z80) das Flomon-Grundmenü. Drückt man nun CTRL-C gefolgt von ESC ESC G, so wird auf den Grafik-Modus umgeschaltet. Nun ist der Grafikprozessor bereit, Grafikbefehle aufzunehmen. Die Eingaben sind jetzt nicht mehr sichtbar.

Beispiel: Drücken der Taste 'Z', der gesamte Bildschirm gelöscht, es ist alles dunkel und auch kein Cursor zu sehen. Durch Eingabe von M 100 100 wird der Anfangspunkt mit den Koordinaten x=100, y=100 festgelegt. Danach zeichnen wir ein Rechteck. Der Befehl hierzu lautet: R30 30 (Rechteck mit 30 x 30 Punkten, aber aufgepaßt, weil der Bildschirm 256 x 512 Punkte hat, wird dieses Rechteck kein Quadrat! Um ein Quadrat zu erhalten muß eine Seite dementsprechend geteilt werden: R30 15)

Beim Einschalten des Grafikmodus wird automatisch die Seite 0 angewählt. Nun ist es aber auch möglich, eine andere der 4 Seiten auszuwählen. Der Befehl P n cr macht dies möglich, wobei n der Parameter zur Festlegung der Schreib- und Leseseite ist: (n = Schreibseite x 4 + Leseseite). P 10 cr (cr=RETURN) wählt also die Seite 2 als Schreib- und Leseseite aus. Will man verschiedene Seiten der Reihe nach anzeigen, verwendet man den X - Befehl. X n cr ist die Befehlssyntax, wobei n die Zeitdauer der Anzeige darstellt (n= Multiplikator \* 20 ms).

Eine kleine 'Programm' - Sequenz: Achten Sie bitte darauf, daß die Grafikbefehle in Großbuchstaben eingegeben und mit RETURN abgeschlossen werden müssen.

Nach dem Einschalten des Computers gehen Sie wie folgt vor: CTRL-C drücken,

dann ESC ESC G (Grafikmodus ein) (Vorsicht, jetzt sehen Sie nicht mehr, was Sie eintippen.) (Bildschirm löschen) M100 100 (Anfangskoordinaten) R 20 20 (Rechteck x=20, y=20 zeichnen) P 5 (Seite 1 auswählen) R 30 30 (Rechteck x=30, y=30 zeichnen) P 10 (Seite 2 auswählen) R 40 40 (Rechteck x=40, y=40 zeichnen) P 15 (Seite 3 auswählen) R 50 50 (Rechteck x=50, y=50 zeichnen) X 20 (Seiten 0...3 zyklisch anzeigen)

### Programmbeschreibung:

Nachdem mit M100 100 ein Anfangspunkt festgelegt wurde, wird ein Rechteck auf die Seite 0 gezeichnet. Nun wird mit dem P-Befehl die nächste Seite angewählt und ein größeres Rechteck konstruiert. Zum Schluß wird mit X 20 ein zyklisches Anzeigen aller Seiten gestartet.

Gestoppt werden kann dieser Vorgang durch Eingabe von X 0. Es wird bei der augenblicklich angezeigten Seite angehalten.

#### 8.2. Oben beschriebenes Beispiel als Basic-Programm:

Die Grafikbefehle werden hier durch BASIC übertragen. Mit CHR\$(27) wird die Taste ESC dargestellt. Achten Sie auch hier darauf, daß Grafikbefehle nur in Großbuchstaben eingeben werden.

```
1  Print CHR$(27); CHR$(27); "G"
2  Print "Z; PO"
3  Print "M100 100"
4  Print "R20 20"
5  Print "P 5"
6  Print "R30 30"
7  Print "P 10"
8  Print "R40 40"
9  Print "P 15"
10  Print "R50 50"
11  Print "X20"
```

### 8.3. Die gleiche Routine in TURBO PASCAL.

```
program test;
BEGIN
    writeln (#27,#27,'G');
    writeln ('Z;PO');
    writeln ('M100 100');
    writeln ('R20 20');
    writeln ('P 5');
    writeln ('R30 30');
    writeln ('P 10');
    writeln ('R40 40');
    writeln ('P 15');
    writeln ('R50 50');
    writeln ('X 20');
END.
```

Nach Starten des Programmes werden wie auch im BASIC - Programm alle vier Seiten der Reihe nach angezeigt. Da auf jeder Seite ein Rechteck verschiedener Größe abgebildet ist, bekommt man den Eindruck, ein wachsendes Rechteck vor sich zu sehen.

Weitere Befehle finden Sie im Buch 'Rechner modular' beschrieben, dessen Bestellnummer der Einführung zu entnehmen ist.

### 8.4 Kleines Hardcopyprogramm unter CP/M 2.2

nachfolgende Hardcopyroutine ist für den Einsatz unter CP/M 2.2 gedacht, als nachträglich zu ladende Hilfsroutine für EPSON FX80-Drucker mit paralleler Schnittstelle. belegt den RAM- Speicher oberhalb von CP/M ab Adresse F900h. Das Ende des Programmes inclusive Bufferbereich ist bei FC42h. Der FLOMON- Zeiger FREEMEM (F031h) wird nicht beachtet bzw. aktualisiert. Die SER- Hilfsroutine kann dazugeladen werden, wenn sie verbleibenden RAM- Bereich zwischen FLOMON- Ende (dorthin zeigt der Inhalt von FREEMEM) und F8FFh Platz findet.

```
.780
0000'
                                       cseg
                             ********************
                             * Programm für Hardcopy
                             :* Starten mit GDPKCOP
                            :* A C H T U N G : Bei ältrere GDP 64k als r8 sind Änderungen *
                                              auf der GDP erforderlich.
                            ;* Ralf Röttgen
                                                         22 Dezember 1987
                                                    *********
                                       ld de.Text
                                                        : Statuszeile ausgeben
00001
       11 001A'
                                                        : Kennung fuer "Print String"
                                       1d c.09h
00031
       0E 09
                                       call 0005h
00051
       CD 0005
                                       ld hl, lo
                                                        : Startadresse
00081
       21 007B1
                                                        ; Zieladresse
                                       ld de.0f900h
00081
       11 F900
                                       ld bc.hi-lo
                                                        : Zahl der zu kopierenden Bytes
000E*
       01 0342
                                                        ; Programm kopieren
                                       ldir
0011'
       ED BO
                                       1d h1.Check
                                                        : Adresse der Check-Routine
00131
       21 F900
                                                        : Consol-Input umlenken (60 k CP/M)
0016
       22 EAOA
                                       1d (OeaOah).hl
00191
                                       ret
       C9
001A'
        18 1B 47
                            Text:
                                       db 1bh, 1bh, 'G'
       50 30 00 40
                                       db 'PO'.0dh.'LO 0 511 0 511 12 0 12'.0dh
00101
00211
       30 20 30 20
00251
       35 31 31 20
00291
       30 20 35 31
002D1
       31 20 31 32
0031'
       20 30 20 31
00351
       32 OD
00371
                                       db 'M430 2',0dh,'BHardcopy ^§',0dh
        4D 34 33 30
003B*
        20 32 0D 42
        48 61 72 64
00351
        63 6F 70 79
00431
00471
       20 5E 40 0D
```

```
db 'P5',0dh,'L0 0 511 0 511 12 0 12',0dh
        50 35 0D 4C
00481
004F1
        30 20 30 20
        35-31 31 20
00531
        30 20 35 31
00571
00581
        31 20 31 32
005F1
        20 30 20 31
00631
        32 OD
        40 34 33 30
                                          db 'N430 2',0dh, 'Bilardcopy ^§',0dh
00651
0069
        20 32 0D 42
006D'
        48 61 72 64
0071'
        63 6F 70 79
00751
        20 5E 40 0D
                                          db 'AS'
00791
        41 24
00781
                               lo:
                                          .Phase Of900h
F900
        CD F003
                               Check:
                                          call Of003h
                                                             ; eingegebenes Zeichen laden
                                          CD 0
                                                             ; Control O als Startzeichen
F903
        FE 00
                                                             : Hardcopy ausfuehren
F905
        CA F90B
                                          jp z,Hcopy
                                                             ; Bit 7 loeschen
F908
        E6 7F
                                          and 7fh
F90A
                                          ret
        C9
                                          ld hl.0
                                                             ; H+L-Register loeschen
F90B
        21 0000
                               HCcpy:
F90E
        39
                                          add hl.sp
                                                             : Stackpointer nach H+L kopiern
                                          ld (OldStack), hl ; alten Stackpointer retten
F90F
        22 FAOF
                                                             ; Stackpointer laden
                                          ld sp,Stack
F912
        31 FC41
                                          Call InitRX80
                                                             : Initialisierung des Druckers
F915
        CD F937
                                          1d a.32
                                                             : Zahl der Druckzeilen
F918
        3E 20
                                                             ; (Punkte pro Zeile / 8)
                                          nush bc
F91A
        C5
                               Loop1:
                                          ld c.a
                                                             : Zeilenanzahl übernehmen
F91B
        4F
                                                             ; GDP-Zeile =0
                                          1d b.0
F91C
        06 00
                                                             ; Widerholungsfaktor sichern
        F5
                                          push af
F91E
                                          push hl
F91F
        E5
                                                             : eine Druckzeile abtasten
        CD F96B
                                          Call GetLint
F920
                                          Call InitLine
                                                             : Drucker fuer die Ausgabe
        CD F930
F923
                                                             ; dieser Zeile initialisieren
        CD F9E7
                                          Call PrtLine
                                                             : Zeilenpuffer ausgeben
F926
                                          pop hl
F929
        E1
                                          pop af
                                                             : Wiederholungsfaktor laden
F92A
        F1
F92B
        C1
                                          pop bc
                                          dec a
                                                             ; Druckzeile a um 1 erhöhen
F92C
        30
        C2 F91A
                                          jp nz,Loopl
F92D
                                           ld hl, (OldStack) ; H+L mit altem Stackpointer laden
F930
        2A FAOF
                                                             : Stackpointer restaurieren
F933
        F9
                                          ld sp,hl
                                                             : Eingabe des naechsten Zeichens
F934
        C3 F900
                                          jp Check
```

```
************
                                         Initialisierung des Druckers
                                           *********************
F937
        21 F94E
                             InitRX80: ld hl.InitTab
                                                         ; Adresse der Tabelle mit den
                                                         : Daten zur Initialisierung
F93A
        C3 F940
                                        ip Loop
F930
        21 F959
                             InitLine:
                                        ld hl.InitlTab
                                                         ; Initialisierung fuer eine Zeile
F940
        4E
                             Loop:
                                        ld c.(hl)
                                                         : Byte laden
F941
        E5
                                        push h)
                                                         ; Register sichern
F942
        CD FOOF
                                        call OfOOfh
                                                         : Byte ausgeben
F945
       E1
                                        ld gog
                                                         : Register restaurieren
F946
        23
                                        inc hl
                                                         : Adresse erhoehen
F947
        3E FF
                                        ld a.Offh
                                                         : Akku loeschen
F949
       RE
                                                         : Ende-Marke ?
                                        cp (hl)
F94A
       C2 F940
                                                         : naechstes Byte ausgeben
                                        ip nz.Loop
        C9
F94D
                                        ret
                                                         : Ende der Initialisierung
F94E
        1B 40
                             InitTab:
                                        db 1bh.'§'
                                                         ; Drucker normieren
F950
       OD DA OA DA
                                        db Odh, Oah, Oah, Oah; oberer Rand
F954
       ΔΩ
       1B 33 17
F955
                                        db 1bh, '3',23
                                                         : Zeilabstand auf 24/216 Zoll setzen
F958
       FF
                                        db Offh
                                                         : Offh als Ende-Marke
F959
       20 20 20 20
                             InitlTab: db'
                                                       ': linker Rand
F950
       20 20 20 20
F961
       20 20 20 20
F965
       1B 2A 01 00
                                        db 1bh. '*', 1,0,2 : 8 Punkt-Bitmuster mit doppelter Dichte
F969
       02
F96A
       FF
                                        db Offh
                                                         : Offh als Ende-Marke
                                        : 8 Spalten des Bildschirms abtasten
                                                         : GDP-Zeile b = c * 8
                             GetLint:
                                        ld a.b
F968
        78
                                        add a.8
                                                          ; a um 8 erhöhen
F96C
        C6 08
                                        ld b,a
F96E
        47
                                                          ; Zähler um 1 erniedrigen
                                        dec c
F96F
        OΒ
                                                          ; wenn c = 0 Schleife c-mal
        79
                                        1d a.c
F970
        D6 00
                                        sub 0
F971
                                                          ; durchlaufen springe nach
        CA F979
                                        jp z,Getsub
F973
                                        ip getlint
        C3 F96B
F976
                                                          : erste Speicherzelle nach HL
                                         ld hl.Buffer
F979
        21 FA11
                              Getsub:
                                                          : Zeilenzähler auf 0
                                         1d c.0
F97C
        DE 00
                                                          : Bytezähler auf O
        11 0000
                              Getline:
                                         ld de,0
F97E
                                                          ; Zeile um 1 erniedrigen
                                         dec h
F981
        กร
                                                          ; prüfen ob GDP bereit
        CD E9E0
                              NZEILE:
                                         call warten
F982
                                         ld a,b
        78
F985
                                         out (7bh),a
                                                          : Zeilenzahl nach Port $7b
        03 78
F986
                                                          : prüfen ob GDP fertig
F988
        CD F9E0
                              NBYTE:
                                         call warten
                                         ld a.e
        7B
F988
                                                          : Bytezahl niederwertig
                                         out (79h),a
F98C
        D3 79
                                         call warten
F98E
        CD F9E0
                                         ld a.d
F991
        7A
                                                          ; Bytezahl höherwertig
        D3 78
                                         out (78h),a
F992
                                         call warten
F994
        CD F9E0
                                         1d a, Ofh
F997
        3E OF
                                                          : beim nächsten Zugr. auslesen
                                         out (70h), a
 F999
        D3 70
                                         call warten
F99B
        CD F9E0
```

```
F99E
        DB 60
                                           in a. (60h)
                                                              : Speicher auslesen
F9A0
        05
                                           push de
F9A1
        C5
                                           push bc
F9A2
        CD F9BC
                                           call Sortiere
                                                              : Speicher sortieren
F9A5
        CI
                                           pop bc
F9A6
        D1
                                           pop de
F9A7
        E5
                                           push hl
                                           ex de.hl
                                                            : vertausche DE mit HL
F9A8
        FR
                                           ld de,8
F9A9
        11 0008
                                                            ; lade 8 nach DE
F9AC
        19
                                           add hl.de
                                                            : adddiere HL mit DE
F9AD
        EB
                                           ex de.hl
                                                            : vertausche KL mit DE
F9AE
        E1
                                           id god
F9AF
                                                            : wenn 512 Bit = eine Zeile
        7A
                                           ld a.d
F980
        06 02
                                                            : noch nicht ausgelesen
                                           sub 2h
F9B2
        20 D4
                                           ir nz.NBYTE
                                                            : springe mach
F984
        79
                                           ld a,c
                                                            ; wenn 8 Zeilen ausgelesen
        D6 08
F985
                                           sub 8
                                                            ; springe zurück ins
F9R7
        C8
                                           ret z
                                                            ; Hauptprogramm
F988
        OC
                                           inc c
                                                            ; erhöhe Anzahl ausgelesener Zeilen
F989
        C3 F97E
                                           in Getline
F9BC
        5F
                               Sortiere:
                                                             ; ausgelesener Wert nach e
                                           ld e.a
F9BD
        16 00
                                                             : Zähler auf O
                                           1d d.0
F9BF
        14
                               Sort:
                                           inc d
                                                             : Zähler um 1 erhöhen
                                           1d a,e
F900
        7R
                                                             : aktueller Wert mach a
F9C1
        07
                                           rlca
                                                             ; rotiere Akku links cyclisch
F9C2
        5F
                                           ld e.a
                                                             : rotiertes Byte mach e
F9C3
        7F
                                           ld a,(h1)
                                                             ; Speicherinhalt nach a
F9C4
                                           rla
                                                             ; rotiere Akku links durch Übertragb.
        17
F9C5
        77
                                           ld (hl).a
                                                             ; neuer Speicherinhalt mach KL
F9C6
        23
                                           inc hl
                                                             ; HL - Speicherzelle incrementieren
F9C7
        3E 08
                                           1d a.8
F9C9
        92
                                           sub d
                                                             ; wenn d = 8
                                                             ; neues a von GDP lesen
F9CA
        C2 F9BF
                                           ip nz.Sort
                                           ld bc.Buffer
                                                             : HL = Buffer + 512 (200h)
F9CD
        01 FA11
                                                             ; wenn 512-ten Speicher erreicht
                                           ld a,h
F900
        7C
                                                             : neues GDP-Byte laden und
F9D1
        D6 02
                                           sub 2
                                           sub b
                                                             ; Speicherzelle auf anfangswert
F9D3
        C2 F9DF
                                           jp nz.Sortrset
F9D4
                                                             ; wenn niederwertige Bytes gleich
F907
        70
                                           ld a, l
                                           sub c
                                                             ; dann springe nicht nach
F9D8
        91
        C2 F9DF
                                           ip nz.Sortrset
F909
                                                              ; Speicherzelle auf Anfangswert
F9DC
        21 FA11
                                           ld hl, Buffer
                               Sortrset: ret
F9DF
        C9
                                                              ; Port 70h auslesen
                                           in a, (70h)
        OB 70
                               warten:
F9E0
                                                              ; wenn 4 Bit = 1 dann
                                           and 4
F9E2
        E6 04
F9E4
                                           ret nz
                                                              ; springe zurück
        c٥
```

jr warten

F9E5

18 F9

```
************
                                          : Ausgabe des Zeilenpuffers
F9E7
        E5
                              PrtLine:
                                         push hl
F9E8
        C5
                                         push bc
F9E9
        05
                                         push de
F9EA
        21 FA11
                              Sortiere2: 1d hl, Buffer
                                                            ; erste Speicherzelle nach HL
F9FD
        11 0200
                                         1d de.512
                                                            ; erste Speicherzelle nach DE
F9F0
        7E
                              sort2:
                                                            ; Speicher nach a
                                         ld a, (hl)
F9F1
        2F
                                         cpl
                                                            : Akku negjeren
F9F2
        E5
                                         push hl
                                                            ; Register sichern
F9F3
        C5
                                         push bc
F9F4
        4F
                                         ld c.a
                                                            ; auszudruckender Wert nach c
F9F5
        CD FOOF
                                         call OfCOfh
                                                            ; Byte ausgeben
F9F8
        C1
                                         pop bc
                                                            ; Register restaurieren
F9F9
        E1
                                         pop hl
F9FA
        23
                                         inc hl
                                                            ; Adresse um 1 erhöhen
F9F8
        18
                                         dec de
                                                            : Zähler um 1 erniedrigen
                                         ld a,e
F9FC
        7B
                                                            ; wenn e <> 0 und d <> 0 dann
F9FD
        B2
                                         or d
                                                            : springe nach
                                         jp nz,sort2
F9FE
        C2 F9F0
                                                            : sort2
FA01
        OF OD
                                                            : Carriage Return ausgeben
                                         ld c.Odh
        CD FOOF
FA03
                                         call Of00fh
                                                            ; Byte ausgeben
FA06
        OE OA
                                         ld c.Oah
                                                            : Line Feed ausgeben
FAOR
        CD FGOF
                                         call Of00fh
                                                            ; Byte ausgeben
FAOB
        D1
                                         pop de
FAOC
        C1
                                         pop bc
FAOD
        E1
                                         pop hl
FACE
        C9
                                         ret
        0000
                              OldStack:
FAOF
                                         dw 0
                                                            ; Wert des Stackpointers
FA11
                              Buffer:
                                         ds 540
                                                            : Puffer fuer eine Zeile
FC2D
                                         ds 20
                                                            ; Platz fuer Stack
FC41
                              Stack:
                                         db 0
        00
                                         .Dephase
```

end

hi:

03BD\*

### Hardcopyprogramm für 680xx

Diese Hardcopyroutine für die Prozessoren 680xx läuft unter JADOS, sowie im RDK- Grundprogramm. Unter CP/M68k können damit keine Hardcopys angefertigt werden.

Zum Betrieb mit der CPU68k (Prozessor 68008) müssen beispilgen folgende Vernagestrungen sofillt under

beispielsweise folgende Voraussetzungen erfüllt werden:

- Jumper JMP2 auf der CPU-Platine muß gesteckt werden, da INT und NMI gleichzeitig aktiviert werden müssen.
- Die Rechnerkonfiguration muss aus BANK/BOOT, mind. 256kB RAM ab Adr.00000 und dem Grundprogramm auf der Bank E bestehen.
- Die Ausgabe erfolgt über die parallele Schnittstelle (Port 40h/41h) an einen EPSON- Drucker.
- Auf der Bank E müssen 32k RAM (4 \* 6264) eingesteckt werden.
- Das Programm benötigt als Buffer 16kByte RAM ab der Adresse \$2A000.

Nachdem das Programm eingegeben ist, wird es assembliert und als Bibliothekeintrag aufgerufen.

```
( G D P - Speicher auslesen Vers. SCC )
* Quelltext assemblieren und als Bibliothek im Speicher aufrufen.
* Bildschirmspeicher der GDP mit dem MREE-Signal vom Register 74LS374
   mit Port-Adresse $FFFFFF60 auslesen in Speicher mit 16 KByte
* ab Adresse $2A000 ablegen.
* Beim Invertieren des Speichers oder Ausgabe auf den Bildschirm,
* werden Langworte vom Speicher eingelesen und Vektoren ausgegeben.
* Alle verwendeten IO-Adressen werden indirekt adressiert.
   damit ist das Programm auf allen CPU'S lauffaehig.
 Ora $0
 OFFSET $E0800
      BIBLIOTHEKSKOPF
HEADINT:
 DC.L $55AAD180
                      ** Kennung Bibliothek
 DC.B 'HCOP-INT' * Name
        INITTAST-HEADINT ** Programmstart
 DC.L
 DC.L
       KCENDE-HEADINT
                        ** Laenge
 DC.B 1
 DC.B 0,0,0
 DC.L 0,0
             PORTADRESSEN/BUFFER
GDPPRD EOU $FFFFFF60 * GDP - PORT 74LS374 lesen
       EQU $FFFFFF70 * GDP - PORT
INTVEC EQU $0C ** INT - LVL.5 Grundprogr. (A5)

GDPREGBF EQU $188 ** GDP0 ... GDP15 save (A5)

BUFHC EQU $E0 ** Speicher fuer Hardcopy auf Drucker

** Ulifornicher fuer Sortlerung 8 Byt
                    * Hilfsspeicher fuer Sortierung 8 Byte
      EQU $EA
                    * ROK-GDP Zeichen einlesen
Cl
       EQU 12
                    * RDK-GDP Bildschirm loeschen + Cursor
CLRSCREEN EQU 20
    EQU 22
                     * RDK-GDP Zeichen an Drucker
LO
       EQU 26
                     * RDK-GDP Befehl an GDP
CMD
NEWPAGE EQU 27
                    ** RDK-GDP Schreib- und leseseite setzen
                    *` RDK-GDP Zeichen Ausgabe
C02
      EQU 33
     EQU 49
                    * RDK-GDP Ausgabe auf Bildschirm
CRT
GETBASIS EQU 89
                     ** RDK-GDP Startadresse des Grundprogramms
                     * RDK-GDP RAM-Zeiger A5
SETA5 EQU 91
        >> Verwendeter Speicherbereich, evtl. an eigenes RAM anpassen <<
                     * Start Bildspeicher 16 kByte gross
BILDSP EQU $2A000
              INTERRUPT INITIALISIEREN
INITTAST:
MOVEQ #SETA5.D7
                           * RAM-Adresse RDK-Grundprogr. in A5
TRAP
       #1
BSR.S HCHILFI
                            * Hilfstexte ausgeben
                            * Programmstart nach AO
LEA
       TASTINT(PC),AO
MOVE.W #$4EF9,D0
                            * <4EF9> = Maschinencode <JMP>
MOVE.W DO, INTVEC(A5)
                           *' auf "[NTLV7:" (Ltg. INT + NHI)
                           *` Sprungadr. Programmstart
MOVE.L AO, INTVEC+2(A5)
RTS
```

```
HCHILET:
MOVEO
           #CLRSCREEN.D7
                               * Bildschirm loeschen
 TRAP
           #1
 MOVEO
           #CRT.D7
                               * Ausgabe auf Bildschirm
 TRAP
           #1
 LEA
           HILFTEXT(PC).AO
                               ** tEXTSTART NACH AO
HILFAUS:
MOVE.B
           (A0)+,D0
 REO. S
           HIL FEND
                               ** und ausgeben
MOVEO
           #C02.D7
TRAP
           #1
BRA.S
           HILFAUS
HILFEND:
RTS
HILFTEXT:
DC.B '>>> HCOP-INT ist nun initialisiert, nach jedem Reset bitte neu <<<'
DC.B $A,$D,$A,'Start mit LOW-Impuls auf INT-Leitung, BUS PIN 32',$A,$D,$A
DC.B '> B < auf Tastatur = Ausgabe Speicher auf Bildschirm', $A,$D
DC.B '> I < auf Tastatur = Speicherinhalt invertieren',$A,$D
DC.B '> L < auf Tastatur = Bilschirm loeschen',$A,$D
DC.B '> H < auf Tastatur = Hcopy auf Drucker',$A,$D
DC.B '> CR < auf Tastatur = Ruecksprung in Programm',0
           HAUPTPROGRAMM - REGISTER RETTEN
*----*
TASTINT: ** >>> S T A R T , wird durch "INTLV5:" aufgerufen
MOVEM.L DO-D7/AO-A6,-(A7) * Alle Register auf Stack
MOVEQ #SETA5,D7
                            ** RAM-Adresse RDK-Grundprogramm in A5
TRAP
        #1
MOVEQ #GETBASIS,D7
                            * Grundprogramm-Start mach A0
TRAP
MOVE
        $416(A0).D0
                            ** CPU - Kennung in Wortgroesse
MOVE
        00,06
                            ** D6 = Kennung der CPU
                            * IO-Adresse multiplizieren
MULS
        #GDPPRD,D0
EXG
        DO, A1
                            * Al = Adresse 74LS374 auslesen
MOVE
        06.00
MULS
        #GDP,D0
                            * A2 = Basisadresse GDP
EXG
        DO.A2
                            * GDP-Register retten,
MOVEA.L A2,A0
        D6.A0
                            * aber erstes Register nicht
ADDA
LEA
        GDPREGBF(A5), A3
 MOVEQ #15-4-1,03
 GDPSAVE:
  MOVE.B
             (A0)+,(A3)+
  DBRA.S
            D3.GDPSAVE
                          *** Unterprogramm GDP-Bildspeicher auslesen
 BSR
         BSPAUSL
 BRA.S
         TPXXX
                          *** Unterprogramm Tastatur abfragen
TPEEE:
 MOVEO
         #GETBASIS.D7
                            ** Grundprogramm-Start nach AD
 TRAP
         #1
 MOVE
         $416(A0),D0
                            * CPU - Kennung in Wortgroesse
                            * D6 - Kennung der CPU
 MOVE
         D0.D6
MULS
         #GDPPRD.DO
                            * IO-Adresse multiplizieren
 EXG
         DO, A1
MOVE
         D6.D0
```

```
MULS
         #GDP.DO
                             * A2 = Basisadresse GDP
EXG
         DO, A2
MOVEA.L A2,A0
                             * GDP-Register zurueck.
         D6,A0
                             ** aber erstes Register nicht
ADDA
LEA
         GDPREGBF(A5),A3
MOVEO
         #15-4-1.D3
GDPLOAD:
  MOVE.B
            (A3)+,(A0)+
  DBRA.S D3,GDPLOAD
MOVEM.L (A7)+,D0-D7/A0-A6
                             *` Register zurueck
                             * und wieder ins Programm
RTE
                  TASTATUR ABFRAGEN
TPXXX:
MOVEQ
           #C1,D7
                          *` Neu einlesen
TRAP
           #1
CMP.B
        #$0D.D0
                          *` Falls <CR>, dann Ende
BEQ.S
          TPEEE
ZKLGR:
CMP1.B
          #'a',00
BHS.S
           ZKLEIN
BRA.S
           ZEINGR
ZKLEIN:
           #'z'.D0
CHPI.B
BLS.S
           ZKORIG
BRA.S
           ZEINGR
ZKORIG:
SUBI.B
           #$20,D0
                          * Wenn klein, -$20, dann gross
ZEINGR:
CMP.B
           #'H'.D0
                          * H = Hardcopy auf Drucker
           TP8
BNE.S
BSR
           HCOPYD
BRA.S
           TPXXX
TPB:
CMP.B
           #'B'.D0
                          * B = Hcopy auf Bildschirm
BNE.S
           TPI
BSR
           CRTAUS
BRA.S
           TPXXX
TPI:
CMP.B
           #'I'.D0
                         * I = Hcopy im Speicher invertieren
BNE.S
           TPL
BSR
           HCINVERS
BRA.S
           TPXXX
TPL:
CMP.B
           #'L'.00
                          * L = Bildschirm loeschen
BNE.S
           TPXXX
CLR
                          * Schreib-
           D0
                          ** und Leseseite = 0
CLR
           Dl
MOVEq
           #NEWPAGE,D7
                          * SETZEN
TRAP
           #1
           #$4,D0
                          * Befehl GDP loeschen
MOVE.B
MOVEO
           #CMD.D7
TRAP
           #1
BRA.S
           TPXXX
```

```
t_____t
               GDP - BILDSPEICHER AUSLESEN
*` X. Y - Register des GDP EF9366 (Lesen und Schreiben) ADR. = 68008
* +----- Y = Zeilen X = Punkte wagerecht
* : 7 : 6 : 5 : 4 : 3 : 2 : 1 : 0 : LSB $FFFFFF7B $FFFFF79 ($000 - $OFF)
** *-----
*` : X : X : X : X : X : X : X : X : MSB $FFFFFF7A $FFFFFF78
                                  nicht
                                             2.Bildhaelfte
                                    benutzt Bit 0 = 1 ($100 - $0FF)
BSPAUSL:
       BILDSP.A3
                        * Bildspeicherstart
LEA
       BILOSP,A3 ** Bildspeicherstart #256-1,D2 ** Y-Koordinate (Zeilen)
 MOVE
       ** >>> Routine mehr als 3 mal schneller als "MOVETO" und "CMP" <<<
       D6, D7 ** CPU-Kennung nach D7 und
                                             (MOVETO)
MOVE
                 * multiplizieren mit GDP Y-LSB Req. :
       #$B,D7
MULS
                 * IO-Adresse GDP nach A4
 MOVEA.L A2.A4
ADDA.W D7, A4
                  * und Y-LSB Register addieren ($7B) :
  BTST.B *2.(A2) ** Bit 2 pruefen, wenn 1,
BEQ.S NZEILE ** dann GDP fertig, sonst warten
                   ** LSB Port Y ($78) .
  MOVE.B D2.(A4)
  SUBA.W D6.A4 * Zweimal CPU-Kennung
  SUBA.W D6.A4
                 * sbtrahieren, Port dann = ($79) :
                  *` X-Koordinate
  CLR
        D1
  MOVEQ #64-1,D3 * Bytezaehler (64 *8 = 512)
NBYTE:
    BTST.B #2,(A2) * Bit 2 pruefen, wenn 1,
                                             (MOVETO)
                   ** dann GDP fertig, sonst warten :
    BEQ.S NBYTE
    MOVE.B D1,(A4) ** LSB Port X ($79) (Positionieren) :
    SUBA.W D6.A4
                   * CPU-Kennung subtrahieren = ($79) :
                 * Rotiere rechts 1 Byte
    ROR.W #8,D1
    MOVE.B D1, (A4) * MSB Port X ($78)
    ROL.W #8,D1
                   * Rotiere links wieder zurueck
    ADDA.W D6,A4
                   * CPU-Kennung addieren
    MOVE.B #$F, (A2) * GDP - DMA Speicher auslesen (CMD)
  GDPWO:
    BTST.B #2,(A2) * Bit 2 pruefen wenn 1,
                   * dann GDP fertig, sonst warten
    BEQ.S GDPWO
    MOVE.B (A1).D4 ** Register 74LS374 auslesen (D4)
    MOVE.B D4,(A3)+ ** In Bildspeicher ablegen
         #8.D1 * Naechstes Byte in Zeile
    DBRA.S D3, NBYTE * Bis 64 Stueck (64 * ( = 512)
  ADDA.W D6.A4 ** Zwei mal CPU-Kennung addieren,
  ADDA.W D6.A4 * Zeilen- Port dann wieder = ($7B) :
  DBRA.S D2, NZEILE ** Bis alle 256 Zeilen
RTS
                   SPEICHER AUF BILDSCHIRM
CRTAUS:
 MOVEQ
         #GETBASIS_D7 ** Grundprogramm-Start nach A0
 TRAP
         #1
        $416(A0),D0 * CPU-Kennung in Wortgroesse
 MOVE
       DO,D6
                      ** D6 = Kennung der CPU
 MOVE
 MULS
     #GDP,D0
                      *` 10-Adresse multiplizieren
                      * A2 = Bsisadresse GDP
 FXG
         DO.A2
                      * Bildspeicherstart
       BILDSP,A3
 LEA
        #256-1,02
                      * Y-Koordinate (Zeilen)
 MOVE
```

```
*" >>> Routine mehr als 3 mal schneller als "MOVETO" und "CMP" <<<
MOVE
          D6.D7
                        ** CPU-Kennung nach D7 und
                                                            (MOVETO)
          #$B,D7
                           ** multiplizieren mit GDP Y-LSB Reg.
MULS
                           ** IO-Adresse GDP nach A4
HOVEA.L
          A2.A4
ADDA.W
          D7.A4
                           * und v-1sb register addieren ($7B)
CRTZEILE:
                           * X-Koordinate (Zeilenanfang)
CLR
          O1
GDPW1:
  BTST.B #2.(A2)
                           * Bit 2 pruefen, wenn 1,
  BEO.S
          GDPW1
                           ** dann GDP fertig, sonst warten
                           * LSB-Port Y ($78) (Zeile-Pos.)
  MOVE.B D2.(A4)
                           * Port minus 3 mal
   SUBA.H D6.A4
                           * CPU-Kennung = $78 -> $78
   SUBA.W D6,A4
   SUBA.W D6,A4
   ROR.W
          #8,01
                           * Rotiere rechts ein Byte
  MOVE.B D1,(A4)
                           * MSB Port X ($78) (1.Bildhaelfte)
                           * Rotiere links wieder zurueck
          #8,D1
   ROL.W
                           * LSB Port X ($79) nach A4
   ADDA.W D6.A4
                           ** Langwortzaehler (16 * 32 = 512)
   MOVEQ #16-1,D3
CRTBYTE:
                           * Langwort (32 Bit) nach D4
    MOVE.L
              (A3)+,D4
                              * 32 Punkte (Langwort)
              #32-1,D5
   MOVEO
CRTBYT1:
                              * Bit-Test, Bit: D5, in D4
       BTST
               D5.04
                              * Nicht gesetzt = kein Punkt
       BNE.S
               CRTBYT2
    GDPW2:
                                                                 (MOVETO)
                              * Bit 2 pruefen wenn 1,
       BTST.B #2,(A2)
       BEO.S
               GDPW2
                              * dann GPD fertig, sonst warten
                              ** LSB-Port X ($79) (Positionieren)
                                                                     :
       MOVE.B D1.(A4)
                              * Kurzyektor mit einem Punkt laden
       MOVE.B #$80,00
       BRA.S CRTBITPR
      CRTB1TOA:
                              * Naechstes Bit testen
       BTST.8 05,04
                              ** Sprung wenn kein Punkt,
       BNE.S
               CRTBITNO
       ADDO
                              * sonst X Achse + 1 und
               #1.01
                              * Kurzvektor + 1 Punkt
               #$28,D0
       ADDI
       CMPI_B #$F8.D0
                              * bis max. 4 Punkte,
               CRTB1TKV
                              * dann unbedingt Ausgabe
       BEQ.S
      CRTB1TPR:
       OBRA.S D5, CRTBITDA
      CRTBITNO:
                              * Bitzaehler korrigieren
       ADDO
               #1,05
      CRTBITKV:
       MOVE.B DO. (A2)
                              * 1 - 1 Punkte an GPD ausgeben
      CRTBYT2:
                              * Bit + 1
        ADDO
               #1.D1
       DBRA.S D5.CRTBYT1
                              *~ 32 ma) (Langwort)
      CMPI.W
              #256,D1
                           * zweite Bildhaelfte erreicht ?
                           * dann MSB Port X setzen
      BNE.S
               CRTNOMSB
   GDPW3:
      BTST.B
               #2,(A2)
                           * Bit 2 pruefen wenn 1,
                                                               (MOVETO)
               CDPW3
                           * dann GDP fertig.sonst warten
                                                                   :
      BEQ.S
               D5,A4
                           * MSB Port X ($78) nach A4
                                                                   :
      SUBA.W
                           * Rotiere rechts 1 Byte
      ROR.W
               #8,D1
              D1,(A4)
                           * MSB Port X (478) (Positionieren)
      MOVE.B
                           * Rotiere links wieder zurueck
      ROL.W
               #8,D1
                           * LSB Port X ($79) wieder nach A4
      ADDA.W D6,A4
```

```
CRTNOMSB:
    DBRA.S D3,CRTBYTE ** Naechstes Langwort in Zeile
   ADDA.N D6,A4 "Zwei mal CPU-Kennung addieren,
ADDA.N D6,A4 "Zeilen-Port dann wieder = ($78)
   DBRA.S D2,CRTZEILE * Naechste Zeile
 RTS
*----*
          BILDSPEICHER INVERTIEREN
HCINVERS:
LEA BILDSP, AO
                   * Startadresse
MOVE #32*128-1,D7 * Zaehler
HCINV1:
  MOVE.L (A0),00
                   * Langwort in d0
  NOT.L DO ** invertieren
  MOVE.L DO, (AO)+ * und zurueck, AO erhoehen
  DBRA.S D7, HCINVI * 16 k MAL
RTS
*-----*
               HCOPY AUF DRUCKER
*-----
HCOPYD:
                     * D1,02,03,04 nicht veraendern
LEA DZABST(PC),A1 ** Drucker Zeilenabstand
BSR DRSETZ
                    * und ausfuehren
                    * 01 = Zaehler fuer Bytes in Bildspeicher
CLR D1
MOVE #32-1.03 * 32 * 8 = 256 Zeilen
KOPSP:
  LEA DBITIM(PC),A1 ** Bit Image Graphik laden
  BSR DRSETZ
                   *` und ausfuehren
  MOVE #64-1.D2
                   ** 64 * 8 = 512 Punkte / Zeile
KOPSPO:
   LEA BUFHC+8(A5), A4 * A4 = Hilfsbuffer fuer Hardcopy
   LEA BUF (A5),A2 * A2 - Hilfsbuffer
   LEA BILDSP,A3 • A3 = Bildspeicher Start
ADDA D1,A3 • gelesene Bildpunkte addieren
MOVEQ #8-1,D0 • 8 Bytes fuer Block einlesen
  KOPSP1:
     MOVE.B (A3),(A2)+ * BAILDSPEICHERBYTE NACH A2
     ADDA #64,A3 * A3 + 64 = Bildpunkt naechste Zeile
     DBRA.S DO,KOPSP1
   ADDQ #1,D1 ** Bildpunktzaehler erhoehen
                   "` ruechwaerts abgelegt wird
   BSR.S Sortieren
    MOVEO #8-1,D5 * 8 Bbyte an Drucker
  HCOPY:
    MOVE.B (A4)+,D0
                     * Hilfsspeicher nach do
                    ** und an Drucker ausgeben
    MOVEQ #LO.D7
    TRAP
           #1
    DBRA.S D5.HCOPY
  DBRA.S D2,KCPSPO
    ADD I
                    ** 448 Bildpunkte addieren = 7 Zeilen
           #448.D1
    DBRA.S D3,KOPSP
  LEA DINORM(PC),A1 ** Orucker wieder in normalen
  BSR DRSETZ
                    ** Modus setzen
  RTS
```

```
BITS SORTIEREN UND ABLEGEN
SORTIEREN:
 CLR.L
          D5
                    ** Block mit 8 * 8 Bit
                    * Spaltenzaehler
 CLR.L
          D6
SORT:
   CLR.L
            DΩ
                    ** Register fuer HCOPY-BYTE
   LEA BUF(A5),A2
                    ** Buffer nach A2
   CLR.L
                    * Zeilenzaehler
            D7
 LOAD:
    CLR.L D4
    MOVE.8 (A2),D4 * Byte nach D4
    MOVE.B D4.D5
    ROR.L #1.D4
                    * Aufschieben und
    MOVE.B D4,(A2)+ * zurueckspeichern
    ANDI.B #1.05
                    * Bit 1 markieren
                    * Platz fuer Bit 1
    ROL.B #1,00
    ADD.B D5,D0
                    *` Und Verknuepfen
                    * Bitzaehler
    ADDO
            #1.D7
    CMPI.B #8.D7
                    * Byte fertig ?,
    BLT.S LOAD
   NOT.B DO
                    ** Negieren fuer Drucker
   MOVE.B DO,-(A4)
                    ** In Speicher ablegen
                    * Spaltenzaehler
  ADDO
          #1.06
  CMPI.B #8.D6
                    * Alle Spalten fertig ?
   BLT.S SORT
RTS
*:
                 STEUERZEICHEN AN
                                                  DRUCKER
DRSETZ:
                                * Schicke eine Zeichenserie an den
CLR
              D4
 MOVE.B
               (A1)+.D4
                                ** Drucker, Adresse in Al, erstes Zeichen
 SUBQ.B
                                * - Anzahl der Zeichen in der Serie -1
              #1,D4
DRSETZ1:
  MOVE.B
              (A1)+,D0
                                ** Nach DO und
  MOVEO
              #L0,07
                                *` ausgeben
  TRAP
              #1
  DBRA.S
              D4, DRSETZ1
                                * bis alle
RTS
        >> Je nach Drucker veraendern <<
DZABST: DC.B 4,$D,$18, '3',23
                                                 * CR>, Vorschub 23/216
DBITIM: DC.8 9,$A,$0,$1B, '1',8,$1B,'L',0,2
                                               * Rand 8, Doppelte Dichte
DINORM: DC.B 10,$D,$A,$A,$A,$1B,'$',$7,$7,$7
                                                 ** Vorschub, Init, Bell
HCENDE:
END
```

```
"' (SCROLL Vor-Rück 8-Zeilen V.2.1)
*' Test-Programm für Hardware - Scroll.
*' Es wird ein Text der auf Adresse $10000 ( od. Textstart auf "STXTXT" ) *
*' steht, mit der Hardware-Scoll-Erweiterung (BU8702) der GDP-Karte auf
*' dem Bildschirm ausgegeben. Der Zeilenabstand beträgt 8 Linien.
*' Mit der Variablen "SPEED" ist die Scroll-Geschwindigkeit einstellbar,
*' wenn die Variable "ZEILEN" auf 8 Linien Vorschub steht.
*' Steht die Variable "ZEILEN" auf 2 oder 4 Linien Vorschub, sollte
*' "SPEED" auf O stehen, es wird dann ein Softscroll ausgeführt.
*' <CTRL+E> (Pfeil oben) = Rückwärts, <CTRL+X> (Pfeil unten) = Vorwärts,
*' <SPACE> = Stop, Start und <ESC> = Abbruch werden ausgewertet.
*' Deutsche Sonderzeichen werden berücksichtigt.
*' (C) Hans-Dieter Bulwien 6.08.87 V.2.1
        $2A000
ORG
         BUFFER / PORTADRESSEN
SCROLL EQU $FFFFFF61*CPU *' GDP - Port für Scroll-Addition
KEYDAT EOU SFFFFFF68*CPU *' KEY - Port Daten
KEYRES EQU $FFFFFF69*CPU *' KEY - Port Reset
         EOU $FFFFFF70*CPU *' GDP - Port
GDP
               HARDWARE - SCROLL - ROUTINE
 *_____*
 *' ----- Voreinstellungen:
                        * >>> START <<<
 MOVEM.L DO-D7/AO-A4,-(A7) ** Register auf Stack retten
 LEA GDP,A3 * A3 = 1/0 Adresse des GDP-Port

* LEA TEXT,A4 * A4 = Text-Start -- oder --

MOVEA.L SIXTXT(A5),A4 * A4 = Zeiger auf aktuellen Textstart

MOVEA.L A4,A2 * A2 = Pointer für Startadresse
 MOVEA.L A4,A2
 HWSCR:
 WSCR:
BTST.B #2,(A3)
                      *' Bit 2 prüfen, wenn 1,
                      *' dann GDP bereit, sonst warten
 BEQ.S HWSCR
 MOVE.B #$04.(A3)
                      *' GDP - Bildschirm löschen
```

```
HWSCR1:
                         ** Bit 2 prüfen, wenn 1.
BTST.B #2, (A3)
                         ** dann GDP bereit, sonst warten
BEQ.S HWSCR1
MOVE.B #$11,CPU*$3(A3) *' GDP - Schriftgröße
MOVE.B #$00, SCROLL
                         *' Scroll-Register auf 0
CLR
        D6
                         *' Wenn O, dann noch nicht scrollen
CLR
        D5
MOVE
                         *' Startpunkt Y-Achse
        #248.D2
BSR
        RSSETY
                         *' und Position an GDP
BSR
        HSSETXO
                         *' X-Register GDP auf 0
*' ----- Zeichen ausgeben:
HSAUS:
TST.B D5
                       *' Wenn noch 1. Seite,
                       *' dann nicht warten
        HSNOWAIT
BEO.S
        #SPEED*100.D4 *' Warteschleife zur Beinflussung
MOVE
HSAUSW1:
                       *' der Ausgabe-Geschwindigkeit
NOP
DBRA.S D4, HSAUSW1
HSNOWAIT:
MOVE.B (A4)+,D0
                       *' Zeichen aus Text-Buffer nach 00
                       *' Wenn O-Byte.
TST.B DO
BEO.S HSENDY
                       *' dann Textende erreicht
                       *' Wenn <CR>, dann Zeit
CMPI.B #$OD,DO
                       *' für 85 Zeichen / Zeile abwarten
        HS85Z
BEO.S
BPL.S
        HSAUSW
                       *' Daten-Byte <$7F ?, sonst
                       *' Deutsche Sonderzeichen
        HSGERMAN
BSR
                       *' Zähler Zeichen / Zeile -1
        #1.D7
SUBO
BRA.S HSAUS
HSAUSW:
                       *' Bit 2 prüfen, wenn 1,
BTST.B #2,(A3)
                       *' dann GDP bereit, sonst warten
BEO.S HSAUSW
                       *' ASCII - Zeichen an GDP
MOVE.B DO.(A3)
                       *' Zähler Zeichen / Zeile -1
SUBQ
        #1.D7
        HSAUS
                       *' und nächstes Zeichen holen
BRA.S
*' ----- Evtl. Zeit für 85 Zeichen / Zeile abwarten:
                       *' ( Kann bei Soft-Scroll entfallen )
HS857:
                       *' Wenn noch 1. Seite, dann sofort
TST.B D5
                       *' nächste Zeile positionieren
BEO.S HSSCR1
TST.B D7
                       *' Wenn O, dann Zeile voll
        HSSCR1
 BEO.S
HS85Z1:
        #SPEED*100.D4 *' Warteschleife zur Beinflussung
MOVE
HS85Z2:
                       *' der Ausgabe-Geschwindigkeit
 NOP
DBRA.S D4, HS85Z2
DBRA.S D7.HS85Z1
 BRA.S HSSCR1
                       *' Nächste Zeile positionieren
*' ----- Ausgabe beenden:
HSENDV:
 MOVE.B #2,05
                       *' Kennung für Textende ereicht
 BRA.S HSEND
HSENDR:
 MOVE.8 #3,D5
                       *' Kennung wieder Textanfang
HSEND:
                       *' Tastatur-Port einlesen, wenn 0,
 MOVE.B KEYDAT, DO
                       *' dann kein Zeichen eingegeben
        DO
 TST.B
                       *' Zurück und warten
 BMI.S
        HSEND
 CMPI.B #3,05
                       *' Wenn Textanfang, kein rückwärtsscrollen
 BEQ.S
        HSNURV
                       *' <CTRL+E> rückwärts
 CMPI.B #$05.D0
```

HSRW

BEQ

```
HSNURV:
CMP1.B #2.05
                       *' Wenn Textende, kein vorwärtsscrollen
BEQ.S HSNURR
CMP1.S #$18.DO
                       *' <CTRL+X> vorwärts
BEO.S HSMOSTOP
HSNURR:
MOVE.B #$00, SCROLL
                        *' Scroll-Register auf 0 zurück
MOVEM.L (A7)+,D0-D7/A0-A4 *' Register vom Stack zurück
*' ----- Auswertung <ESC>, <CTRL+E>, <CTRL+X> und <SPACE>:
HSSCR1:
                       *' Tastatur-Port einlesen, wenn 0,
MOVE.B KEYDAT.DO
                       *' dann kein Zeichen eingegeben
TST.B DO
                       *' In Textausgabe nicht anhalten
BMI.S HSNOSTOP
                      *' Wenn <ESC>, dann Abbruch
CMPI.8 #$18,00
BEQ.S HSEND
                       "' Wenn <SPACE>, dann Ausgabe stoppen
CMPI.B #$20.D0
BEQ.S HSWAITKO
                       *' 1. Seite, kein Richtungswechsel
TST.B D5
 BEO.S HSVR2
CMPI.B #$05.D0
                       *' <CTRL+E> rückwärts
        HSRW
 BEQ
 BRA.S HSNOSTOP
HSWA1TKO:
                       *' Tastatur-Port löschen
CLR.B KEYRES
HSWAITK1:
                       *' Tastatur-Port einlesen, wenn 0,
 MOVE.B KEYDAT, DO
                       *' dann kein neues Zeichen eingegeben
 TST.B DO
 BMI.S HSWAITK1
                       *' Zurück und warten
                       *' Wenn <SPACE>, dann Ausgabe fortsetzen
 CMPI.B #$20,D0
                       *' Sonst weiter warten
 BNE.S HSWAITKO
*' ----- Scroll-Richtung auswerten:
HSNOSTOP:
                       *' <CTRL+X> Vorwärts-Scrollen gesetzt ?
 CMPI.B #$18,00
 BEQ.S HSVR1
                       *' <CTRL+E> Rückwärts-Scrollen gesetzt ?
 CMPI.B #$05,06
 BEQ
        RSSCR3
HSVR1:
                       *' War zuletzt Rückwärts-Scrollen gesetzt ?
 CMP1.B #$05,06
 BNE.S HSVR2
                       "' Dann im Text um 32 Zeilen vorrücken
 MOVEQ #32-1,D4
                       *' an unteren Bildrand
HSRW1B:
 MOVE.B (A4)+,D0
                       *' Zeilen-Ende
 CMPI.B #$0A,DO
 BNE.S HSRW1B
 DBRA.S D4, HSRW1B
```

\*' Text-Position -1

SUBQ

#1,A4

```
*' ----- Ausgabe bis 1.Seite voll:
HSVR2:
 CLR.B D6
                       *' Scroll-Richtungserkennung löschen
 MOVEO #85-1.D7
                       *' Zeichen / Zeile Zähler
 CLR.B KEYRES
                       *' Tastatur-Port löschen
                       *' Wenn 0, dann noch 1.Seite
 TST.B
       D5
 BNE.S
        HSSCR3
                      *' sonst scrollen
TST.B D2
                       *' Y-Achse = 0, dann 1.Seite voll
 BEQ.S HSSCR2
                      *' und ab nun scrollen
MOVE
        #3000.D3
                      *' Zähler für Ausgabe-Verzögerung
                      *' Warten am Ende jeder Zeile
HSWAIT1:
  NOP
  DBRA.S D3.HSWAIT1
SUBQ.B #8,D2
                      *' Y-Achse -8 = nächste Zeile
BSR
        HSSETY
                      *' und Position an GDP
BSR · HSSETXO
                       *' X-Register GDP auf 0
ADDO
        #1.A4
                       *' <LF> im Textbuffer überspringen
        HSAUS
                       *' und dann nächste Zeile ausgeben
BRA
*' ----- Ausgabe scrollen vorwärts:
HSSCR2:
                       *' Kennung 1.Seite voll
MOVEQ #1,05
HSSCR3:
                       *' Bit 2 prüfen, wenn 1,
BTST.B #2,(A3)
                      *' dann GDP bereit, sonst warten
BEQ.S HSSCR3
MOVE.B #$01,(A3)
                       * * GOP - Löschmode
 SUBQ.B #8,D2
                      *' Y-Achse -8 = nächste Zeile
 BSR
        HSSETY
        HSSETXO
BSR
MOVEQ #80-1,D3
                      *' 80 Zeichen = Eine Zeile löschen
HSBLK2:
   BTST.8 #2,(A3)
                       *' Bit 2 prüfen, wenn 1,
   BEO.S HSBLK2
                       *' dann GDP bereit, sonst warten
                       *' GDP - 5 * 8 Block zeichnen
   MOVE.B #$0A,(A3)
   DBRA.S D3.HSBLK2
HSSCR4:
                       *' Bit 2 prüfen, wenn 1,
BTST.B #2, (A3)
BEO.S HSSCR4
                       *' dann GDP bereit, sonst warten
                       *' GDP - Schreibmode
MOVE.B #$00,(A3)
                       *' X-Register GDP auf 0
8SR
        HSSETX0
                       *' Y-Achse wieder +8
ADDQ.B #8,D2
"' ----- Scroll-Routine vorwärts:
MOVE.B #ZEILEN.D4
                       ** Zeilenvorschub nach D4
 CMP1.8 #2,D4
                       *' 2 Zeilen ?
 BEQ.S HSZE1L4
 CMP1.B #4.D4
                       *' 4 Zeilen ?
 BEQ.S HSZEIL2
 MOVEO #1-1.D3
                       *' Ein Scroll-Umlauf mit 8 Zeilen
 BRA.S
       HSWAIT2
HSZEIL4:
 MOVEQ #4-1,D3
                       *' Zwei Scroll-Umläufe je 4 Zeilen
 BRA.S HSWAIT2
HSZEIL2:
                       *' Vier Scroll-Umläufe je 2 Zeilen
 MOVEQ #2-1,D3
```

**GES 59** 

```
HSWALL2:
          #$FFFF,DO
                      *' Voreinstellung DO
  MOVE
HSWAIT3:
                      *' Warten auf VSYNC der GDP (BIT = 1)
                      *' Abfragen des GDP-Status-Register
  BTST.B #1, (A3)
                      *' Wenn 0, 00 löschen und warten
  BEO.S HSSYN1
  TST
          00
                      *' Wenn 1, 00 testen, wenn noch $FF, dann
  BNE.S HSSYN2
                      *' war VSYNC sofort da, warten bis
  BRA.S HSWALT4
                      *' nächstes VSYNC-Signal anliegt (20 msec)
HSSYN1:
  CLR
          00
HSSYN2:
  BRA.S HSWAIT3
HSVATTA.
  SUBQ.8 #ZEILEN.D2 *' Verschiebung Linien / Umlauf (8 4 2)
                      *' und in Scroll-Register laden
  MOVE.B D2, SCROLL
  DBRA.S D3, HSWAIT2
                      *' <LF> im Textbuffer überspringen
ADDO
        #1.A4
                      *' und nächste Zeile ausgeben
BRA
        HSAUS
*' ----- Rückwärts - Scrollen:
                      *' Nur bei Richtungswechsel
CMPI.B #$05,D6
                      *' Wenn schon rückwärts,
BEQ.S RSSCR3
                      *' dann Taste ignorieren
MOVE.8 DO.D6
                      *' Scroll-Richtung nach D6 retten
MOVEQ #31-1,D4
                      *' Zunächst im Text 31 Zeilen zurück
HSRW1:
                      *' auf Bildanfang
MOVE.B -(A4).DO
CMP1.B #$0A,D0
                      ** Zeilenende
BNE.S HSRW1
DBRA.S D4, HSRW1
*' ----- Ausgabe scrollen rückwärts:
RSSCR3:
BTST.B #2,(A3)
                      *' Bit 2 prüfen, wenn 1,
BEQ.S RSSCR3
                      *' dann GDP bereit, sonst warten
MOVE.B #$01.(A3)
                      *' GDP - Löschmode
                      *' Zeichen / Zeile Zähler
MOVEQ #85-1,D7
CLR.B KEYRES
                      *' Tastatur-Port löschen
BSR
        HSSETY
BSR
        HSSETX0
MOVEQ #80-1,D3
                      *' 80 Zeichen = Eine Zeile löschen
RSBLK2:
  BTST.B #2.(A3)
                      *' Bit 2 prüfen, wenn 1.
  BEQ.S RSBLK2
                      *' dann GDP bereit, sonst warten
  MOVE.B #$0A.(A3)
                      *' GDP - 5 * 8 Block zeichnen
  DBRA.S D3,RSBLK2
RSSCR4:
BTST.B #2,(A3)
                      "' Bit 2 prüfen, wenn 1,
                      *' dann GDP bereit, sonst warten
BEQ.S RSSCR4
MOVE.B #$00,(A3)
                      *' GDP - Schreibmode
                      "' X-Register GDP auf 0
BSR
       HSSETX0
```

```
*' ----- Scroll-Routine rückwärts
                      *' Zeilenvorschub nach D4
MOVE.B #ZEILEN.D4
                       *' 2 Zeilen ?
CMPI.B #2.D4
BEO.S RSZEIL4
                       *' 4 Zeilen ?
CMPI.B #4.D4
BEQ.S
        RSZEIL2
                       *' Fin Scroll-Umlauf mit 8 Zeilen
MOVEO
        #1-1.D3
BRA.S
        RSWAIT2
RSZE1L4:
                       *' Zwei Scroll-Umläufe je 4 Zeilen
MOVEO #4-1.D3
BRA.S RSWAIT2
RSZEIL2:
                       *' Vier Scroll-Umläufe je 2 Zeilen
 MOVEQ #2-1,D3
RSWAIT2:
   MOVE
          #SFFFF.D0
                       *' Voreinstellung 00
                       *' Warten auf VSYNC der GDP (BIT = 1)
RSWALT3:
                       *' Abfragen des GDP-Status-Register
   BTST.B #1,(A3)
                       *' Wenn O. DO löschen und warten
   BEO.S
          RSSYN1
                       *' Wenn 1, DO testen, wenn noch $FF, dann
   TST
          nn
                       *' war VSYNC sofort da, warten bis
          RSSYN2
   BNE.S
                       *' nächstes VSYNC-Signal anliegt (20 msec)
   BRA.S RSWALT4
RSSYN1:
   CLR
          00
RSSYN2:
   BRA.S RSWAIT3
RSWAIT4:
                      *' Verschiebung Linien / Umlauf (8 4 2)
   ADDQ.B #ZEILEN,D2
                       *' und in Scroll-Register laden
   MOVE.B D2, SCROLL
   DBRA.S D3.RSWAIT2
*' ----- 1m Text nun zwei Zeilen zurück:
 MOVEQ #2-1,D4
RSRW1:
 MOVE.B -(A4).DO
 CMPA.L A4.A2
                       "' Textanfang erreicht ?
 BEQ.S RSANF
 CMPI.B #$OA,DO
                       *' Zeilenende
 BKE.S
         RSRW1
 DBRA.S D4,RSRW1
                       *' Um <LF> im Textbuffer vorrücken
 ADDQ
         #1.A4
         HSAUS
                       *' und nächste Zeile ausgeben
 BRA
** ------ Wenn Text-Anfang wieder erreicht wurde:
RSANF:
                       *' Zeichen aus Text-Buffer nach DO
 MOVE.B (A4)+,D0
 CMPI.B #$0D.00
                       *' Wenn <CR>, dann Ende 1. Zeile
                       *' und fragen ob wieder vorwärts
 BEQ
         HSENDR
                       *' Daten-Byte <$7F ?, sonst
         RSAUSW
 BPL.S
                       *' Deutsche Sonderzeichen
 BSR
         HSGERMAN
 BRA.S
         RSANF
RSAUSH:
 BTST.B #2,(A3)
                       *' Bit 2 prüfen, wenn 1,
 BEQ.S RSAUSW
                       *' dann GDP bereit, sonst warten
                       *' ASCII - Zeichen an GDP
 MOVE.B DO,(A3)
 BRA.S RSANF
                       *' und nächstes Zeichen holen
```

```
X. Y-POSITION GDP - REGISTER
*-----
*'----- Y-Achse in GDP-Register laden:
HSSETY
                    *' A3 - GDP I/O Port
BTST.B #2.(A3) *' Bit 2 prüfen, wenn 1,
BEQ.S HSSETY *' dann GDP bereit, sonst warten
 MOVE.B D2,CPU*$B(A3) *' LSB Port Y
 ROR.W #8,02 *' Rotiere rechts 1 Byte
MOVE.8 D2, CPU*$A(A3) *' MSB Port Y
 ROL.W #8,D2 *' Rotiere links, wieder zurück
RTS
*'---- X-Achse in GDP-Register laden:
HSSETX:
BTST.B #2,(A3)
                     *' Bit 2 prüfen, wenn 1.
BEQ.S HSSETX
                     *' dann GDP bereit, sonst warten
MOVE.B D1,CPU*$9(A3) *' LSB Port X
ROR.W #8.D1 *' Rotiere rechts 1 Byte
MOVE.B D1,CPU*$8(A3) *' MSB Port X
ROL.W #8,D1 ** Rotiere links, wieder zurück
RTS
*' ----- X-Register der GDP auf O setzen:
HSSETXO:
BTST.B #2,(A3) *' Bit 2 pruten, no... -.

*' dann GDP bereit, sonst warten
MOVE.B #$0D,(A3)
                    *' GDP - X-Register auf O setzen
*' ----- X, Y-Register von GDP auslesen:
HSGETXY:
BTST.B #2,(A3) * Bit 2 prüfen, wenn 1,
BEQ.S HSGETXY * dann GDP bereit, sonst warten
                    *' Bit 2 prüfen, wenn 1,
MOVE.B CPU*$8(A3),D1 *' MSB Port X nach D1
                    *' Byte nach links schieben
ROL.W #8.D1
MOVE.B CPU*$9(A3).D1 *' dann LSB Port X
MOVE.B CPU*$A(A3),D2 *' MSB Port Y nach D2
ROL.W #8.D2 *' Byte nach links schieben
MOVE.B CPU*SB(A3),D2 *' dann LSB Port Y
RTS
              DEUTSCHE SONDERZEICHEN
*_____*
*' ----- Sonderzeichen in Tabelle suchen:
                        *' A3 = GDP 1/0 Port
 MOVEM.L DO-D4/A1-A2,-(A7) *' Register auf Stack retten
LEA HSTAB1(PC),A1 "' A1 = Start Zeichen-Tabelle
LEA HSTAB2(PC),A2 "' A2 = Start Matrix-Tabelle
BCLR.B #7,D0 "' Bit 7 auf 0 setzen
 MOVEQ #7-1,D1
                         *' Anzahl der Zeichen
HSGER1A:
 CMP.B (A1)+,D0 ** Zeichen mit Tabellenwert vergleichen,
BEQ.S HSGERIB ** wenn gefunden, ausgeben
ADDO #5.A2 ** Snort Natriv +5 und
  ADDQ #5.A2
  DBRA.S DI.HSGERIA * nächstes Zeichen vergleichen
                         *' Zeichen nicht gefunden
 BRA.S HSGER1C
HSGER18:
                         *' Zeichen nun ausgeben
 BSR.S HSGER2
 MOVEM.L (A7)+,D0-D4/A1-A2 *' Register vom Stack zurück
```

```
*' ----- Sonderzeichen als Matrix an GDP
HSGER2:
        HSGETXY
                           *' Hole Aktuelle X, Y-Position der GDP
 BSR
                           *' Anzahl Spalten
 MOVEO #5-1.D3
HSGER2A:
                           *' Byte der Matrix laden
   MOVE.8 (A2)+,D0
                           *' Anzahl der Zeilen
   MOVEO #8-1.04
  HSGER2B:
                           *' Wenn kein Punkt, dann
     BTST.8 D4,D0
                           *' nächste Y-Position laden
     BEO.S HSGER2C
                           *' Punkt zeichen
     MOVE.B #$80,(A3)
  HSGER2C:
                           * Bit 2 prüfen, wenn 1.
     BTST.B #2.(A3)
     BEO.S HSGER2C
                           *' dann GDP bereit, sonst warten
     ADDQ.B #1,CPU*$B(A3) *' Nur LSB Port Y +1 an GDP
     DBRA.S D4.HSGER2B
 HSGER2D:
                           *' X - Position +1
   ADDO
           #1.D1
BSR
        HSSETX
                         *' X - Position an GDP
                            *' Y - Position an GOP
   BSR
           HSSETY
   DBRA.S D3.HSGER2A
 ADDO
         #1.D1
                            *' X - Position +1 ( 6. Spalte )
                           *' X - Position an GDP
 BSR
         HSSETX
 RTS
*' ----- Tabellen der Sonderzeichen:
HSTAB1: DC.B $5B,$5C,$5D,$7B,$7C,$7D,$7E
                                                       DC.B
HSTAB2:
*01111101, *00001010, *00001001, *00001010, *01111101 *' $58 =
nÄ
DC.8 %00111101,%01000010,%01000010,%01000010,%00111101 *' $5C = Ö
DC.8 %01111101,%01000000,%010000000,%010000000,%01111101 *' $5D = U
DC.B %01110001,%01010100,%01010100,%01111000,%01000001 * $78 = 8
DC.B %00000000, %00111001, %01000100, %01000100, %00111001 *' $7C = 8
DC.B $00111101,$01000000,$01000000,$01111101,$01000000 *' $70 = \bar{u}
DC.B $00000000, $01111111, $00000001, $01001101, $00110010 * $7E = B
        >>> (C) H.-D.BULWIEN 1987 <<<
```

END

#### 9. Diverses

#### 9.1 Ausblick

Korrekturen für dieses Handbuch werden in der Zeitschrift LOOP bekanntgegeben. Man sollte dann die fehlerhaften Stellen von Hand korrigieren.

### 9.2 Kritik

Bitte senden Sie uns die ausgefüllte Kritikkarte, die dem Bausatz beiliegt, zurück. Sie helfen uns, unsere Produkte und unseren Service noch besser zu gestalten. Für Fehlermeldungen und Verbesserungen, die dieses Handbuch betreffen, sind wir immer dankbar!

# 10. Unterlagen zu den verwendeten IC's

## 10.1 TTL-IC's





Sechs Inverter (open Collector)



Positive Logik  $Y = \overline{A}$ 

Typ. Impuls-

Verzögerungszeit: 22 ns

Typ. Leistungsaufnahme:

ifnahme: 60 mW

4 AND-Gatter mit je 2 Eingangen



Typ. Impulsverzogerungszeit 12 ns

Typ Versorgunsstrom





Zwei D-Flipflops mit Preset und Clear



#### Wahrheitstabelle:

|        | Inpu  | Outpo    | Outputs |                |                |
|--------|-------|----------|---------|----------------|----------------|
| Preset | Clear | Clock    | D       | Q              | Q              |
| L      | Н     | ×        | X       | н              | L              |
| Н      | L     | ×        | ×       | L              | н              |
| L      | L     | ×        | X       | H*             | н*             |
| i H    | Н     | Ť        | Н       | н              | L              |
| H      | н     | <b>†</b> | L       | L              | Н              |
| Н      | Н     | L        | X       | Q <sub>O</sub> | Q <sub>O</sub> |

Positive Logik

\*Dieser Zustand ist nicht stabil; d.h. er bleibt nicht erhalten, wenn Preset und/oder Clear maktiv (High) werden

Typ. Impulsverzögerungszeit: 19 ns

Typ. Versorgungsstrom 4 mA

3-Bit Binärdekoder/Demultiplexer (3 zu 8)



## Logiktabelle.

| Inputs        |     |   |         |   | Outputs |    |    |           |    |    |    |    |
|---------------|-----|---|---------|---|---------|----|----|-----------|----|----|----|----|
| Enable Select |     |   | outputs |   |         |    |    |           |    |    |    |    |
| 61            | G2* | С | 8       | A | YO      | Y1 | Y2 | <b>Y3</b> | Y4 | Y5 | Y6 | Y7 |
| X             | Н   | Х | ×       | X | Н       | Н  | Н  | Н         | Н  | Н  | Н  | Н  |
| L             | ×   | × | ×       | × | Н       | н  | н  | н         | Н  | н  | н  | н  |
| H             | L   | L | L       | L | L       | н  | н  | н         | н  | Н  | Н  | н  |
| Н             | L   | L | L       | н | Н       | Ł  | н  | н         | Н  | Н  | н  | н  |
| Н             | L   | L | Н       | L | н       | н  | L  | н         | н  | н  | н  | н  |
| Н             | L   | L | н       | н | н       | Н  | Н  | L         | н  | н  | н  | н  |
| l H           | L   | н | L       | L | н       | Н  | н  | н         | Ł  | Н  | н  | Н  |
| H             | L   | н | L       | н | н       | Н  | н  | н         | Н  | L  | Н  | н  |
| Н             | L   | н | Н       | L | н       | Н  | н  | Н         | н  | н  | L  | н  |
| Н             | L   | н | н       | Н | Н       | Н  | Н  | Н         | Н  | Н  | н  | L  |

Positive Logik

\*G2 = G2A + G2B

Typ impulsverzogerungszeit: 22 ns

Typ Versorgungsstrom . 7 mA

Zwei 4 zu 1 Datenselektor / Multiplexer



Wahrheitstabelle:

| Select<br>Inputs |   | D   | ata inp | etu |    | Strabe | Output |
|------------------|---|-----|---------|-----|----|--------|--------|
| В                | Α | CO  | C1      | C2  | C3 | G      | Υ      |
| ×                | X | ×   | X       | X   | X  | н      | 1 .    |
| L                | Ĺ | L   | X       | ×   | X  | l L    | L      |
| L                | Ĺ | Н   | X       | X   | X  | L      | Н      |
| L                | Н | l x | L       | ×   | X  | L      | L      |
| L                | Н | l x | Н       | X   | ×  | l L    | н      |
| H                | L | l x | X       | L   | X  | L      | L      |
| H                | L | ×   | ×       | н   | ×  | L      | н      |
| H                | Н | ×   | ×       | X   | L  | 1 1    | L      |
| Н                | Н | ×   | X       | ×   | Н  | L      | Н      |

positive Logik



Acht Bit Schieberegister mit Paralleleingabe und Clear



Function Table:

|       | 1      | nputs   | Interna          |        | Output   |         |      |      |
|-------|--------|---------|------------------|--------|----------|---------|------|------|
| Clear | Shift/ | Clock   | Clock            | Serial | Parallel | Outputs |      | 1.0  |
| Clear | Load   | Inhibit | I Clock   Serial |        | QA       | QB      | QН   |      |
| L     | X      | X       | X                | ×      | ×        | L       | L    | L    |
| H     | X      | L       | L                | ×      | X        | QAO     | QBO  | g Ho |
| H     | L      | L       | 1                | X      | ah       | 8       | b    | h HO |
| Н     | Н      | L       | 1                | Н      | X        | Н       | Q An | Q Gn |
| Н     | Н      | L       | 1                | L      | X        | L       | QAn  | QGn  |
| Н     | X      | Н       | 1                | ×      | ×        | QAO     | Q BO | O HO |

Positive Logik

## 8-fach Bus-Transceiver mit 3-state Ausgängen



### Function Table

| ENABLE | DIRECTION<br>CONTROL<br>DIR | OPERATION       |
|--------|-----------------------------|-----------------|
| L      | L                           | B data to A bus |
| L      | H                           | A data to B bus |
| H      | ×                           | Isolation       |

Typ. Impuls-

Verzögerungszeit: 20 ns

Typ. Versor-gungsstrom.

75 mA

8 - Bit D Register mit Clear



### Function Table:

| Inpu  | its   |   | Output |
|-------|-------|---|--------|
| Clear | Clock | D | Q      |
| L     | Х     | Х | L      |
| Н     | Ť     | Н | Н      |
| Н     | Ŷ     | Ļ | L      |
| Н     | L     | X | 0 0    |

Typ. Impuls- Typ Leistungs-Verzögerungszeit. 17,5 ns aufnahme: 85 mW



## Wahrheitstabelle (positive Logik)

| Ein              | Eingänge        |                 |                  | Ausgänge         |                  |                         |                   |                 |                         |
|------------------|-----------------|-----------------|------------------|------------------|------------------|-------------------------|-------------------|-----------------|-------------------------|
|                  |                 |                 |                  | .C0=L            | bzw.             | C2=L                    | CO=H              | bzw.            | C2=H                    |
| A1<br>bzyr<br>A3 | B1<br>bzw<br>B3 | A2<br>bzw<br>A4 | 82<br>bzw.<br>84 | Σ1<br>bzw.<br>Σ3 | Σ2<br>bzw.<br>Σ4 | C2<br>bzw.<br>C4        | Σ1<br>bzw<br>Σ3   | Σ2<br>bzw<br>Σ4 | C2<br>bzw<br>C4         |
|                  |                 |                 |                  |                  |                  | L L L L L L H L L L H H | # L L H H L L H H |                 | L L L L H H H H H H H H |
| H<br>L<br>H      | H<br>H          | H<br>H<br>H     | H<br>H<br>H      | H<br>H<br>L      | L<br>L<br>H      | Н<br>Н<br>Н             | L<br>H            | H<br>H          | H<br>H<br>H             |

Die Zustände von  $\Sigma$ 1,  $\Sigma$ 2 und internem Carry C2 werden durch die Zustände der Eingänge A1, B1, A2, B2 und C0 bestimmt. Die Ausgänge  $\Sigma$ 3,  $\Sigma$ 4 und C4 werden von C2, A3, B3, A4, B4 best

B-Bit D Register mit 3-state-Ausgangen



Logiktabelle

| ос          | СК               | D                | Q                 |
|-------------|------------------|------------------|-------------------|
| 0<br>0<br>0 | †<br>T<br>O<br>X | 1<br>O<br>X<br>X | 1<br>0<br>Qo<br>Z |

Typ. Impuls-Verzögerungszeit 16 ns

Typ. Versorgungsstrom.

2.6 mA

positive Logik:

ja

## 74ALS574

8-8:: D-Flip-Flop mit nichtinvertierenden Ausgangen



## Logiktabelle:

| 00          | CLK       | D                | Q                 |
|-------------|-----------|------------------|-------------------|
| 0<br>0<br>0 | † · · O X | 1<br>0<br>X<br>X | 1<br>0<br>Qo<br>Z |

Typ. Impuls-Verzögerungszeit. 9 ns

Typ. Verlustleistung:

75mW

positive Logik:

ja

3 zu 8 Dekoder



#### 65 536-BIT (65 536-WORD BY 1-BIT) DYNAMIC RAM

#### DESCRIPTION

This is a family of 65 536-word by 1-bit dynamic RAMs, tabricated with the high performance N-channel silicon-gate MOS process, and is ideal for large-capacity memory systems where high speed, low power dissipation, and low costs are essential. The use of double-layer polysilicon process technology and a single-transistor dynamic storage call provide high circuit density at reduced costs, and the use of dynamic circuitry including sense amplifiers assures low power dissipation. Multiplexed address inputs permit both a reduction in pins to the standard 16-pin package configuration and an increase in system densities. The M5K4164S operates on a 5V power supply using the on-chip substrate bias generator.

#### **FEATURES**

| lyte nan e   | Access time<br>(max)<br>(ns) | Cycle time<br>(m n)<br>(iis) | Power dissipation<br>(typ)<br>(inW) |
|--------------|------------------------------|------------------------------|-------------------------------------|
| M5K41645-15  | 150                          | 260                          | 200                                 |
| 145K4164S-20 | 200                          | 330                          | 170                                 |

- Standard 16-pin package
- Single 5V ±10% supply
- Low standby power dissipation: 28.0mW (max)
- Low operating power dissipation: 275mW (max)
- Unlatched output enables two-dimensional chip selection and extended page boundary
- Early-write operation gives common I/O capability
- Read-modify-write, RAS-only refresh, and page-mode
- All input terminals have low input capacitance and are directly TTL-compatible



\* if the pin 1 (REF) function is not used, pin 1 may be left open (not connect).

- Output is three-state and directly TTL-compatible
- 128 refresh cycles every 2ms
- (16K dynamic RAMs M5K4116P, S compatible)
- Pin 1 controls automatic- and self-refresh mode.
- CAS controlled output allows hidden refresh, hidden automatic refresh and hidden self-refresh.
- Output data can be held infinitely by CAS.
- Interchangeable with Mostek's MK4164 and Motorola's MCM 6664 in pin configuration.

#### **APPLICATION**

Main memory unit for computers.



### 10.2 Graphik-Prozessor 9366

#### Register:

Über die Adressen AO bis A3 können die 16 Register von J28 aufgerufen werden. Tabelle 1 zeigt die Register und die dazugehörigen Adressen.

| Numbe      | R FUNCTIONS       | REGISTE                     | STER | REG | RESS | ADD  |      |
|------------|-------------------|-----------------------------|------|-----|------|------|------|
| of<br>bits | Reed Virte        |                             |      |     | 3    | -    | _    |
|            | R/W = 0           | R/W - 1                     |      | 2   | AI   | AZ I | A3 5 |
|            | CMO               | STATUS                      | _0_  | 0   | ٥    | 0 !  | ٥    |
| 7          | nterrupt control) | CTRL I (Write control and i | 1    | 1   | ٥    | ٥    | 0    |
| 4          | type control)     | CTRL 2 (Vector and symbol   | 2    | 0   | -    | 0    | 0    |
|            |                   | CSIZE (Character pize)      | 1    | 1   | -    | 0    | 0    |
| -          |                   | Reserved                    | 4    | 0   | 0    | 1    | 0    |
| 8          |                   | DELTAX                      | 5    | 1.  | ۰    | 1    |      |
| -          |                   | Reserved                    |      | ۰   | 1    | •    | C    |
|            |                   | CELTAY                      | ,    |     | ,    | -    | 0    |
| 1          |                   | X MS9s                      |      | 0   | 0    | 0    | 1    |
| •          |                   | X LSBs                      |      |     | 0    | 0    | 1    |
| 4          |                   | Y M280                      |      | ٥   | 1    | ٥    | 1    |
|            |                   | Y LS8s                      |      | T.  | -    | 0    | , ;  |
| ,          | Reserved          | XLP (Light pen)             | c    | 0   | 0    | 1    | ,    |
|            | Peserved          | YLP (Light pan)             | D    |     | ٥    | -    | 1    |
|            |                   | Reserved                    | E    | 0   | -    |      | 1    |
| -          | -                 | Reserved                    | - 6  | -   | 1    |      | ,    |

Reserved: These addresses are reserved for fusive versions of the circuit. In read mode, output buffi

Bild 14

### Beschreibung der einzelnen Register:

Status und Kommandoregister (Adresse 0):
Diese Register sind die Schlüsselregister zum Baustein. Das
Statusregister kann vom Prozessor gelesen werden – hier
meldet der EF 9366 seinen Status. Das Kommandoregister kann
beschrieben werden – hier übergibt man ein Kommando zum
Baustein.

# Status-Register (lesen): Bedeutung der einzelnen Bits

| Bit 0 High | Ende einer Lichtgriffelsequenz        |
|------------|---------------------------------------|
| Bit 1 High | Vertikal Blank                        |
| Bit 2 High | Bereit für ein neues Kommando         |
| Low        | BUSY (ist beschäftigt)                |
| Bit 3 High | PEN ausserhalb des Anzeigebereiches   |
| Bit 4 High | Lichtgriffel verursachte IRQ (falls   |
|            | freigeg.)                             |
| Bit 5 High | Vertikal Blank verursachte IRQ (falls |
| _          | frei.)                                |
| Bit 6 High | Bereit für neues Kommando verursachte |
| _          | IRQ                                   |
| Bit 7 High | Bit 5,6,7 mit ODER verknüpft:         |

Kommandoregister (Schreiben): Dieses Register hat 5 Funktionen.

| Wert      | Bedeutung                                                                                                                                                                                                                     |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 00h - 0Fh | Kommandos wie Bildschirm, Register löschen<br>usw.                                                                                                                                                                            |
| 10h - 17h | Grundvektorbefehle<br>Ein Vektor wird definiert durch den Betrag<br>in den Registern DELTAX und DELTAY sowie<br>durch das hier vorgebene Vorzeichen.                                                                          |
| 18h - 1Fh | Vektoren mit Richtungsvorgabe<br>Ein Richtungscode (8 Richtungen) wird<br>übergeben, das kleinere der Register DELTAX<br>oder DELTAY ignoriert und der Vektor mit<br>der Länge des größe ren DELTA - Registers<br>gezeichnet. |
| 20h - 7Fh | ASCII - Zeichen werden ausgegeben, Code - Zuordung siehe folgende Tabelle 2.                                                                                                                                                  |
| 80h - FFh | Kurzvektoren<br>In einem Byte ist ein Vektor vollständig<br>definiert.                                                                                                                                                        |



Abb. 5.3.34 befehre Citis FF

Bild 15

## Befehle von 00h bis 0Fh:

| Bit | Bedeutung                                                                                                                                         |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | Im Register CTRL 1 wird das Bit 1 gesetzt; der<br>Schreibstift (=PEN) wird angewählt. Dieses Bit<br>bzwKommando ist vor jedem Schreiben zu geben. |
| 1   | Im Register CTRL 1 wird Bit 1 auf 0 gesetzt; das<br>bedeutet , daß der Radiergummi (ERASER) angewählt<br>wurde.                                   |
| 2   | <pre>Im Register CTRL 1 wird Bit 0 gesetzt - der PEN oder ERASER wird abgesenkt.</pre>                                                            |
| 3   | Im CTRL 1 wird das Bit 0 gelöscht - PEN oder ERASER werden angehoben.                                                                             |
| 4   | Bildschirm löschen.                                                                                                                               |
| 5   | Register X und Y werden rückgesetzt auf 0.                                                                                                        |
| 6   | Bildschirm löschen und rücksetzen der Register X und Y.                                                                                           |
| 7   | Alle Register (außer XLP,YLP) werden zu O gesetzt,<br>Bildschirm löschen.                                                                         |
| 8   | Lichtgriffel initialisieren (GDP - Ausgang WHITE aktivieren, Bildschirm blinkt einen Zyklus weiß).                                                |
| 9   | Lichtgriffel initialisieren.                                                                                                                      |
| A   | 5x8-Bĺock zeichnen. Die Größe des Blockes ist von<br>Register CSIZE abhängig.                                                                     |
| В   | 4x4-Block zeichnen                                                                                                                                |
| С   | Bildschirm scannen - PEN oder ERASER wie in CTRL 1 definiert.                                                                                     |
| D   | Register X auf 0 rücksetzen.                                                                                                                      |
| E   | Register Y auf O rücksetzen.                                                                                                                      |
| F   | Direkter Bildzugriff im nächsten freien Zyklus.                                                                                                   |

### Darstellung von ASCII-Zeichen:

Falls das Bit 7 (das höchstwertige) '0' ist und B6 bis B4 ungleich Null sind, so wird über das Kommandoregister ein ASCII-Zeichen übergeben. Dieses Zeichen wird an der Stelle X,Y mit der im CSIZE-Register angegebenen Größe und der in CTRL 2 definierten Richtung angezeigt. Diese Zeichen werden in einer 5x8-Matrix ausgegeben. Nach der Ausgabe eines Zeichens wird x um 6 Bildpunkte erhöht. Dies verdeutlicht nebenstehendes Bild.

Jeder der ausgegebenen Bildpunkte kann durch einen Block, der PxQ groß ersetzt werden. P und Q können von 1 bis 15 reichen und werden im CSIZE-Register festgelegt. Die Zeichen liegen von 20h bis 7Fh und entsprechen den 96 Standard (USA) ASCII-Zeichen. Ein 97stes Zeichen erzeugt einen 5P x 80- Block kann dazu verwendet werden, und andere Zeichen zu löschen. Das 98ste Zeichen erzeugt ein 4Px4Q-Feld ohne Zwischenraum zum nächsten Zeichen. Mit diesem Zeichen können grobe graphische Zeichnungen (z.B. Balkendiagramme) erzeugt werden. Ein Zeichen kann auf zweierlei Arten gelöscht werden: Entweder mit dem Zeichen OAh, oder indem man das gleiche Zeichen (mit gleichem Startund eingeschaltetem punkt X,Y)ERASER überschreibt.

Hinweis: Das Blank (20h) löscht nicht, sondern positioniert nur den X-Wert ein Zeichen weiter.



Bild 16



 Computed dots, not defined into the ROM (not modifiable)

Bild 17

### Andere Register:

CTRL 1 Steuerregister 1 (Adresse 1) Einige Bits des Registers sind redundant,d.h. sie können auch über das Kontrollregister gesetzt bzw. gelöscht werden. Es sind dies die beiden (wichtigsten) niederwertigen Bits BO und B1.

| Bit              | Bedeutung                                                                                                                                                                                                |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1<br>2<br>3 | HIGH = PEN unten LOW = PEN oben HIGH = PEN LOW = ERASER HIGH = schnell schreiben ohne Ausgangssignal HIGH = geschlossene Bildfläche,d.h. es wird auch geschrieben, wenn MSB X,Y außerhalb der Bildfläche |
| 4<br>5<br>6<br>7 | sind.<br>IRQ - Freigabe für Lichtgriffel<br>IRQ - Freigaben bei VB<br>IRQ - Freigabe bei 'bereit'<br>Nicht verwendet (0)                                                                                 |

CTRL 2 Steuerregister 2 (Adresse 2) Steuerregister 2 steuert die Art der gezeichneten Vektoren (durchgezogen, gepunktet, gestrichelt oder strichpunktiert), sowie die Art der Zeichendarstellung.





CSIZE (Register zur Festlegung der Zeichengröße ) (Adresse 3): In diesem Register wird die Größe der darzustellenden Zeichen übergeben. Die Größe ist in X und Y-Richtung in 16 Schritten wählbar.



P Scaling factor on X axis Q : Scaling factor on Y axis



CSIZE = 1114



CSIZE - 22.4

DELTAX und DELTAY (Adressen 5 und 7):

Diese Register werden bei den Grundvektorbefehlen verwendet und bedeuten die Projektion der Vektorlänge auf die jeweilige Achse. Ihre Bedeutung erhalten diese Register erst bei der Ausgabe von Grundvektoren. Im Befehl wird dann auch das Vorzeichen übergeben. Mit DELTAX und DELTAY = 0 können einzelne diskrete Punkte, deren Lage durch die Register X und Y definiert sind ausgegeben werden.

Lichtgriffel (Adressen C und D):

Hier wird vom Baustein der aktuelle Stand des Lichtgriffels übergeben. Diese Funktion ist allerdings bei der GDP 64k nicht vor- gesehen.

Register X und Y:

Diese Register beinhalten den Standpunkt für jede Operation (Vektor zeichnen oder Schriftausgabe). Die Übergabe erfolgt in 12 Bit; damit ergibt sich ein virtueller Raum von 4096 x 4096 Bit, der vom Baustein auch verwaltet wird. 512 (X) x 256 (Y) Bit werden angezeigt.

|         |   |   | - |   |   |
|---------|---|---|---|---|---|
| MXXX    | 3 | 2 | 1 | 0 | ı |
| v w w v | - |   |   |   | ı |

MSBs

76543210

Vektor-Befehle: Gruppe A

| Vorzeichen |         | Befehl   |          |                        |
|------------|---------|----------|----------|------------------------|
| Delta-x    | Delta-y | dez.     | sedez.   | binär                  |
| +          | +       | 17       | 11       | 0001 0001              |
| -          | +       | 19       | 13       | 0001 0011              |
| +          | -       | 21<br>23 | 15<br>17 | 0001 0101<br>0001 0111 |
| >0         |         | 16       | 10       | 0001 0000              |
| -          | >0      | 18       | 12       | 0001 0010              |
| <0         | <0      | 20       | 14       | 0001 0100              |
|            | -       | 22       | 16       | 0001 0110              |

| Ri | chtu | ng  | dez.   | Befehl sedez. | binär     |
|----|------|-----|--------|---------------|-----------|
| 3  | Uhr  |     | <br>24 | 18            | 0001 1000 |
| 1  | Uhr  | 30' | 25     | 19            | 0001 1001 |
| 12 | Uhr  |     | 26     | 1A            | 0001 1010 |
| 10 | Uhr  | 30' | 27     | 1B            | 0001 1011 |
| 6  | Uhr  |     | 28     | 1C            | 0001 1100 |
| 4  | Uhr  | 30' | 29     | 1D            | 0001 1101 |
| 9  | Uhr  |     | 30     | 1E            | 0001 1110 |
| 7  | Uhr  | 30' | 31     | 1F            | 0001 1111 |
|    |      |     |        |               |           |

### Pinbelegung des EF 9366:



### Pinbelegung IBM- Monitorkabel



Anmerkung: Bei niedrigem Pegel Tiegen die Signal-Spannungen zwischen 0,0 und 0,6 V DC, bet hohem Pegel Tiegen sie zwischen + 2,4 und +3,5 V DC

### 11. Literatur

In unserer Zeitschrift LOOP wird regelmäßig über neue Produkte und Änderungen bzw. Verbesserungen berichtet. Es ist für Sie von großem Vorteil, LOOP zu abonnieren, denn dadurch ist sichergestellt, daß Sie auch immer über die neuesten Informationen verfügen.

Ein LOOP-Abo können Sie bei jeder Bestellung einfach mitbestellen.

Auch auf der Kritikkarte können Sie ein LOOP-Abo ganz einfach bestellen.

Anhang C: Bestückungsplan mit Layout Bestückungsseite



Anhang D: Layout Bestückungsseite



### Anhang E: Layout Lötseite





Graf Elektronik Systeme GmbH

Magnusstraße 13 Postfach 1610 8960 Kempten (Allgäu) Telefon: (08 31) 62 11 Teletex: 831804 = GRAF Telex: 17 831804 = GRAF Datentelefon: (08 31) 6 93 30

Geschäftszeiten: GES GmbH+Verkauf Mo. - Do. 8.00 - 12.00 Uhr, 13.00 - 17.00 Uhr Freitag 8.00 - 12.00 Uhr Telefonservice Filiale Hamburg Ehrenbergstraße 56

2000 Hamburg 50 Telefon: (0 40) 38 81 51

Filiale München:

Georgenstraße 61 8000 München 40 Telefon: (0 89) 2 71 58 58

Öffnungszeiten der Filialen: Montag – Freitag

10.00 – 12.00 Uhr, 13.00 – 18.00 Uhr Samstag 10.00 – 14.00 Uhr