# Platinencomputer - Handbuch

Alexander Wersching und Simon Walter  $2021 \label{eq:wersching}$ 

# Inhaltsverzeichnis

| 1 | Anforderungen und Methode                  | 3                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|---|--------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2 | Spezifikation des Computers                | 3                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.1 Registers                              | 3                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.1.1 Flaggen                              | 4                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.2 Memory                                 | 5                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.2.1 Banking                              | 5                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.2.2 Hardware Stack                       |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|   | 2.3 Input/Output                           |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|   | 2.4 Interrupts                             | 7                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 2.5 Supervisor-/Usermode                   |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|   | 2.6 Instruktions-Satz                      | 8                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| 3 | Kommentar zur Specification                | 8                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   | 3.1 16 bit Daten/Address Länge             | 8                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|   |                                            |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|   | 3.3 Alternative Instruktion Encodierung    |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 4 | Grundlegen Tests der Einzelnen Komponenten | kation des Computers 3   egisters 3   1.1 Flaggen 4   femory 5   2.1 Banking 5   2.2 Hardware Stack 6   aput/Output 7   atterrupts 7   appervisor-/Usermode 8   astruktions-Satz 8   entar zur Specification 8   6 bit Daten/Address Länge 8   egister Anzahl 10   lternative Instruktion Encodierung 11   egen Tests der Einzelnen Komponenten 11   extrictegeräte 11 |  |  |  |
| 5 | Security                                   |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 6 | Perepheriegeräte                           |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| 7 | Quellenverzeichnis                         |                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |

# 1 Anforderungen und Methode

### 2 Spezifikation des Computers

Eine Computer hat eine Reihe verschiedener high-level Aufgaben und Features, die es ihm erlauben seiner Tätigkeiten nach zu gehen! Diese Features können wie folgt auf gegliedert werden: Register, Memory, Banking, Input/Output, Flaggen, Hardware Stack, Interrupts, Supervisor-Mode und das Instructuion Set.

Aber um zuerst ein paar Standarts festzulegen: der Computer hat eine Daten/Adressen Länge von 16 bit, d.h. er kann maximal 16 bit auf einmal operieren bzw. können maximal 16 bit an Daten/Adressen im Computer auf einmal bewegt werden. Mehr dazu in Unterabschnitt 3.1

#### 2.1 Registers

Register sind kleine sehr schnelle Speichereinheiten, die genutzt werden können um Zwischenergebnisse, lokal Variablen, Argumenten für Funktionen zu speichern oder um Daten im Computer zwischen den einzelnen Komponenten zu verschieben. Aus jedem Register kann gelesen (Kopierten des alten Wertes an eine anderen Ort) oder geschrieben werden (den alten Wert mit einem neuen Wert überschreiben)

Der Computers besitzt bei uns 8 verschiedene, jeweils 16 bit lange Register. Jedes Register hat dabei eine eigene Registernumber (= RN). Machen Register erfüllen zudem noch spezielle Aufgaben und sollten auch nur so verwendet werden. Diese Funktionen sind in Tabelle 1 zu sehen.

Mehr zur Registeranzahl in Unterabschnitt 3.2

Die Register A-D sind dabei die Register, welche frei für jede Nutzung zur Verfügung stehen. Es ist stark zu empfehlen die spezialregister (ZERO, IP, SP und FLAG) nicht für die Speicherung von Daten zu verwenden, da dies evt. Programmabläufe stark stören könnte. Sie sind ausdrücklich nur für ihre zugewiesenen Aufgaben da.

Tabelle 1: Registeraufteilung

| RN | Name | Funktion                                                         |
|----|------|------------------------------------------------------------------|
| 0  | ZERO | Konstante 0x0000; Schreiben hat keinen Effekt                    |
| 1  | IΡ   | Instruction Pointer, zeigt auf aktuell auszuführende Instruktion |
| 2  | SP   | Stack Pointer, zeigt auf obersten Wert des Stacks, siehe 2.2.2   |
| 3  | A    | Allzweck Register ohne besonderen Aufgaben                       |
| 4  | В    | ıı .                                                             |
| 5  | С    | ıı .                                                             |
| 6  | D    | ıı .                                                             |
| 7  | FLAG | Enthält alle wichtigen Flaggen, siehe Unterunterabschnitt 2.1.1  |

#### 2.1.1 Flaggen

Das Register FLAG enthält alle Statusflaggen. Eine Flagge kann entweder gesetzt oder nicht gesetzt sein, daher kann jede Flagge als ein Bit repräsentiert werden. Jedes Bit in FLAG stellt daher eine Flagge da. Flaggen werden bei unterschiedlichen Ereignissen geschaltet. Dies und welche Flaggen es gibt ist in Tabelle 2 zusehen

Tabelle 2: Flaggenaufteilung in FLAG

| Bit | Name | Funktion                               | Schaltung                |
|-----|------|----------------------------------------|--------------------------|
| 0   | OF   | Intager Overflow einer Rechenoperation | Bei jeder ALU Operation  |
| 1   | E    | Gleichheit zweier Werte                | TEST arg[0] = arg[1]     |
| 2   | G    | Ungleicheit (>) zweier Werte           | TEST arg[0] > arg[1]     |
| 3   | L    | Ungleicheit (<) zweier Werte           | TEST arg[0] < arg[0]     |
| 4   |      | . ,                                    |                          |
| 5   |      |                                        |                          |
| 6   |      |                                        |                          |
| 7   |      |                                        |                          |
| 8   |      |                                        |                          |
| 9   |      |                                        |                          |
| 10  |      |                                        |                          |
| 11  |      |                                        |                          |
| 12  |      |                                        |                          |
| 13  |      |                                        |                          |
| 14  |      |                                        |                          |
| 15  | SUP  | Supervisor-/Usermode                   | siehe Unterabschnitt 2.4 |

Alle Flaggen, die mit TEST als Schaltung gekennzeichnet werden, werden bei der Aus-

führung der TEST Operation geschaltet.

Das FLAG Register verhält sich ebenfalls wie ein Register, daher können Flagge auch per Hand gesetzt oder nicht gesetzt werden. Eine Ausnahme macht SUP die nur manuel geschaltet werden kann wenn SUP gesetzt ist, siehe Unterabschnitt 2.5

#### 2.2 Memory

Während die Register für lokale Variablen und Zwischenergebnisse gedacht sind, ist Memory (Arbeitsspeicher) für die Speicherung von größeren Datenmengen gedacht.

Es ist in 65536 einzelne und unabhängige Speicherzellen (Jede 16 bit große) aufgeteilt. Jeder Zelle ist einer Addresse, welche von 0 bis 65535 reicht, zugeordnet. Der Computer kann damit auf 65536words oder 131072bytes ( $\approx 131.0 \text{kb}$ ) gleichzeitig zugreifen. <sup>1</sup>. Wichtig ist das die Gesamt Größe theoretisch weitaus größer sein kann, dank Banking siehe Unterunterabschnitt 2.2.1.

Memory wird dabei über LD- und STR-Instruktionen gesteuert. Die LD-Instruktion kopiert einen Wert aus Memory und schreibt ihn in ein Register, während STR an der angebenen Addresse den Wert mit dem eines Register überschreibt.

Dabei ist die Memory Karte in Abbildung 1 zu stehen. Die zwei Hardware Stacks sind dort gekenzeichnet mit ↑, mehr dazu in Unterunterabschnitt 2.2.2

Die mit Supervisor gekennzeichneten Bereich können nur dann gelesen oder geschrieben werden, wenn die SUP Flagge gesetzt ist. Der Bereich, der mit ROM versehen wurde, ist dabei nicht beschreibbar, sondern kann nur gelesen werden. Eine STR Instruktion hat keine Wirkung.

#### 2.2.1 Banking

Banken sind externe Memory Module, die eingesteckt werden können. Alle Banken sind gleich groß (18.4kw = 36.8kb) und der Computer unterstützt maximal 65536 unterschiedliche Banken. Jede Bank hat dabei eine ID (BID), die von 0 bis 65535 reicht.

Der Computer hat zwei Bank-Slots (Slot 1 0x4000 - 0x3fff und Slot 2 0x4000 - 0x57ff). Er kann nun auf jenden dieser Slots eine der theoretisch 65536 Bank legen <sup>2</sup>. Das Banken legen lässt sich über die SBK1- (Select Bank 1) und SBK2- (Select Bank

<sup>&</sup>lt;sup>1</sup>Die Größe messen wir in words (w) oder in kilowords (kw), wobei 1word = 2bytes = 16bit.

<sup>&</sup>lt;sup>2</sup>Es ist dabei möglich die gleiche Bank auf beide Slots zu legen, auch wenn das nur bedingt nützlich ist.



2) Instruktion erreichen. Wenn man somit an diese entsprechende Memory Addressen schreibt, schreibt man in die Bank hinein.

Durch dieses System lassen sich 65536 \* 18.4 kw = 1.2 Gw = 2.4 GB ansprechen.

Das Bankensystem dient zudem dazu Prozesse von einander zu isolieren, da bei nicht gesetzter SUP-Flagge Computer die Bank nicht änderen kann, siehe Unterabschnitt 2.5.

#### 2.2.2 Hardware Stack

Der Stack (oder auch Stapelspeicher) ist eine LIFO (Last In First Out) Datenstruktur. Sie dient hauptsächlich dazu Subroutinen zu verwalten.

Er funktioniert dabei wie ein Münztappel. Es kann ein Wert auf den Stack gelegt werden

(PUSH-Instruktion) oder ein Wert von oben abgehoben werden (POP-Instruktion).

Der Stack liegt dabei physisch in Memory vor. Jedes Element des Stacks okkupiert dabei eine Memoryzelle. Das Stack-Point Register-(SP) hält die Addresse, welche auf den oberste Wert des Stacks zeigt. Der Stack wächst dabei von hohen Addressen zu niedrigen Addressen. PUSH entspricht dabei der Dekrementierung des Stack Pointers um 1 und POP der Inkrementierung um 1.

Fundamental hat der Computer zwei Stacks. Der Supervisor-Stack beginnt bei 0xffff und wird genutzt wenn die SUP Flagge gesetzt ist. Der User-Stack beginnt bei 0x57ff, also am Ende des Bank-Slots 1 und wird genutzt, wenn die SUP Flagge nicht gesetzt ist.

POP und PUSH schalten automatisch zwischen Supervisor-Stack und User-Stack bei Änderung der SUP-Flagge.

#### 2.3 Input/Output

Der Computer hat zudem die Möglichkeit mit verschieden IO-Geräte zu interagieren. Jedes IO-Geräte hat eine ID (IO-ID). Diese reicht von 0 bis 65535. Die Kommunikation zwischen Computer und IO-Geräte funktioniert über IN bzw OUT Instruktion. IN Ließt einen Wert vom IO-Geräte. Und OUT schreibt eine Wert zum IO-Gerät.

Im Supervisormode kann jedes IO-Geräte uneingeschränkt verwendet werden. Im Usermode hingegen sind standartmässig alle IO-Geräte gesperrt. Der Supervisor kann sie dauerhaft freigeben oder sie wieder sperren, mit AIO (Allow Input/Output), für das Aktivieren und DIO (Disallow Input/Output) für das Deaktivieren. Diese Information wird in einem Seperatem Speichermodule gesichert, wobei die Speicheraddresse von der BID (Bank ID) abhängt.

Jedes IO-Geräte hat eine feste unveränderliche Typennummer. Diese lassen sich über die TYPE Instruktion erfahren. Die Typennummer 0x0000 markiert dabei ein nicht eingestecktes Geräte. Mehr zu IO-Geräte in Abschnitt 6

#### 2.4 Interrupts

REWORK!

#### 2.5 Supervisor-/Usermode

REWORK

#### 2.6 Instruktions-Satz

Alle zuverfügenung stehenden Instruktion sind in Tabelle 3. Die Ins-ID, steht für Instruktions-ID, welecher jeder Instruktion eine zugeordnet ist. op1, op2 und op3 sind dabei die möglich parameter der Instruktion. Sie können dabei Register (reg1, reg2 oder reg3) sein oder ein Konstante (c).

# 3 Kommentar zur Specification

#### 3.1 16 bit Daten/Address Länge

Die Address- und Datenlänge besagt viele Binäre Ziffern (bits) für eine Address und Daten verwendet werden. Je mehr Ziffern man verwendet desto größere Zahlen können in einer Operation verarbeitet werden wobei die maximal repräsentierbare Zahle  $2^n - 1$  ist wenn n die Anzahl der Binary Ziffern (= Bits) ist und wenn man mit 0 anfängt zu zählen. Sie Tabelle 4

Ein eine n stellige Binär Zahl wobei n teilbar durch 8 ist, ist dabei relative angenehm, 8 bit = 1 byte. Das byte ist dabei die Basis Einheit für so gut wie alle informationstechnischen Standards. Daher ist es gute eine solches n zu wählen. Zudem kommen einige elementar ICs, z.B. Buffer oder Register, immer mit 8 bits.

Jedoch gilt je mehr Bits man verwendet, desto mehr Schaltung brauchen man, desto mehr Stromverbrauch. Da wir wie zwar nicht speziell auf Platz und Stromverbrauch optimieren, aber trozdem ein limitiertes Buget haben, können wir auch nicht eine belibig große Daten/Address Länge wählen.

Wir haben uns daher für 16 bit entschieden, der Codea man laut Tabelle 4 Zahlen bis zwischen 0 und 65535 darstellen kann. Diese Menge ist gerade große genug, um für die meisten Programme große genüge Zahl abzubilden <sup>3</sup>.

<sup>&</sup>lt;sup>3</sup>Für Programme die Zahlen welche > 65535 darstellen wohlen ist es ratsam immer zwei oder mehr Spreichereinheiten zunehmen oder bei Berechnungen, selbige auf zwei oder mehr Schritte auf zuteilen

Tabelle 3: Instruktions-Satz

| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | Tabelle 3. Instruktions-Satz |      |          |          |          |                                       |
|---------------------------------------------------------------|------------------------------|------|----------|----------|----------|---------------------------------------|
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | Ins-ID                       |      | op1      | op2      | op3      | 0                                     |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$          | 0x00                         | NOP  |          |          |          | Kein Effekt                           |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$          | 0x01                         |      | reg1     | m reg2/c |          | ,                                     |
| $\begin{array}{cccccccccccccccccccccccccccccccccccc$          | 0x02                         | ADD  | reg1     | reg2     | m reg3/c | reg1 = reg2 + reg3/c                  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x03                         | SUB  | reg1     | reg2     | m reg3/c | reg1 = reg2 - reg3/c                  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x03                         | MUL? | reg1     | reg2     | m reg3/c | reg1 = reg2 * reg3/c                  |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x05                         | DIV? | reg1     | reg2     | - '      | /                                     |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x06                         | XOR  | reg1     | reg2     | m reg3/c | $reg1 = reg2 \oplus reg3/c$           |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x07                         | AND  | reg1     | reg2     | m reg3/c | $reg1 = reg2 \wedge reg3/c$           |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x08                         | OR   | reg1     | reg2     | m reg3/c | $reg1 = reg2 \lor reg3/c$             |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | 0x09                         | NOT  | reg1     | m reg2/c |          | $reg1 = \neg reg2/c$                  |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | 0x0a                         | STR  | reg1     | reg2     | reg3/c   | m [memory[reg2+reg3/c]=reg1           |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x0b                         | LD   | reg1     | reg2     | m reg3/c | m reg1 = memory[reg2 + reg3/c]        |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x0c                         | BNK1 | m reg1/c |          |          | Setzt BID für Bank-Slot1              |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | 0x0d                         | BNK2 | reg1/c   |          |          | Setzt BID für Bank-Slot2              |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | 0x0e                         | PUSH | reg1/c   |          |          | SP-; memory[SP] = reg1                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x $0$ f                     | POP  | reg1     |          |          | reg1 = memory[SP]; SP++               |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$         | 0x10                         | PEEK | reg1     |          |          | reg1 = memory[SP]                     |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x11                         | CALL | m reg1/c |          |          | memory[SP] = IP; SP++;                |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        |                              |      |          |          |          | m IP = reg1/c                         |
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$         | 0x12                         | RET  |          |          |          | IP = memory[SP]; SP++                 |
|                                                               | 0x12                         | TEST | reg1     | reg2/c   |          | Vergleicht reg1 und reg2/c            |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x13                         | JE   | m reg1/c |          |          | $IP = reg1/c 	ext{ if } E$            |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x14                         | JO   | m reg1/c |          |          | IP = reg1/c  if  O                    |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x15                         | JG   | m reg1/c |          |          | $IP = reg1/c 	ext{ if } G$            |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$        | 0x16                         | JL   | m reg1/c |          |          | $IP = reg1/c 	ext{ if } L$            |
| 0x18AIOreg1Aktiviert IO[reg1]0x19DIOreg1Deaktivieren IO[reg1] | 0x16                         | IN   | reg1     | reg2     |          | reg1 = IO[reg2]                       |
| 0x19 DIO reg1 Deaktivieren IO[reg1]                           | 0x17                         | OUT  | reg1/c   | reg2     |          | $\mathrm{IO[reg2]} = \mathrm{reg1/c}$ |
|                                                               | 0x18                         | AIO  | reg1     |          |          | Aktiviert IO[reg1]                    |
| 0x1a   TYPE reg1 reg2   reg1 = Type von IO[reg2]              | 0x19                         | DIO  | reg1     |          |          |                                       |
|                                                               | 0x1a                         | TYPE | reg1     | reg2     |          | reg1 = Type von IO[reg2]              |

Die Entscheidung zur größe der Daten/Address Länge ist eine sehr ausschlag gebende, daher haben wir diese zuerst festgelegt. Sie wird für viele weitere Entscheidung eine wichtige Rolle spielen. Wichtig ist nur das wir maximal 65536 Zustände oder Zahlen von 0 bis 65535 darstellen können mit unseren 16 bit

Tabelle 4: Maximalerepersäntierbare Zahlen (startend mit 0)

| n  | $n^2 - 1$            |
|----|----------------------|
| 2  | 3                    |
| 4  | 15                   |
| 8  | 255                  |
| 16 | 65535                |
| 32 | 4294967295           |
| 64 | 18446744073709551615 |

#### 3.2 Register Anzahl

Der Computer hat 8 Register. Wir haben uns für Acht ausfolgenden Gründen entschieden: Zu erst die minimale Anzahl anregisteren die wirklich gebraucht würde, ist 5! Man braucht mindestens zwei all Zweck Register um binäre Rechenoperation durch zu führen, einen Stackpointer, einen Instruktion Point und einen Ort wo man die Flaggen speichern kann <sup>4</sup>.

Fünf lässt sich nicht mehr mit 2 bits repräsentieren  $(2^2 = 4)$ , daher muss man 3 bit  $(2^2 = 8)$  nehmen. Der Grund warum wir nicht mehr genomen haben hat mit der Encodierung von Instruktionen zutun siehe Unterabschnitt 3.3. Somit haben sich 8 Register als das Optimum ergeben

<sup>&</sup>lt;sup>4</sup>Theorthisch ist es möglich das Flaggen Register wegzulassen, wir haben uns aber für eine solches Register entschieden siehe ??

Tabelle 5: Typennummern

| Typennummer | Typename | Hinweis          |
|-------------|----------|------------------|
| 0x0000      | NC       | Keine Verbindung |
| 0x0001      |          |                  |
|             |          | Nicht Besetzt    |
| 0xffff      |          |                  |

# 3.3 Alternative Instruktion Encodierung

- 4 Grundlegen Tests der Einzelnen Komponenten
- 5 Security
- 6 Perepheriegeräte
- 7 Quellenverzeichnis