

## LC1 - Beschreibung

### Inhaltsverzeichnis

|                                         |   |
|-----------------------------------------|---|
| 1. Bedienoberfläche .....               | 1 |
| 2. Architektur des LC1-Prozessors ..... | 3 |
| 2.1. Arbeitsweise des Steuerwerks ..... | 4 |
| 2.2. Arbeitsweise des Rechenwerks ..... | 5 |
| Anhang - Maschinenbefehlsliste .....    | 6 |

### 1. Bedienoberfläche

Zum besseren Verständnis der nachfolgenden Ausführungen sollten die LC1-Bedienungsanleitung und die LC1-Befehlsbeschreibung zur Hand genommen werden.

Nach dem Aufruf des Simulators LC1 erscheint das Bild:



Bedeutung der verwendeten Abkürzungen:

|     |                                 |
|-----|---------------------------------|
| A   | register <b>A</b> (accumulator) |
| ADD | <b>add</b>                      |
| AB  | <b>address bus</b>              |
| ALU | <b>arithmetic logic unit</b>    |
| AND | <b>logical AND</b>              |
| AR  | <b>address register</b>         |

```

B      register B
Bpt   breakpoint (dt. Haltepunkt) (-- = nicht gesetzt)
BR    instruction register (dt. Befehlsregister)
CAL   call procedure
CONTROL control unit
D     define
DB    data bus
DR    data register
HLT   Halt (dt.)
IA    interrupt address register
Int   interrupt address register (-- = nicht gesetzt)
INT   interrupt unit
IR    instruction register (dt. Befehlsregister)
JMP   jump
JPS   jump if sign
JPO   jump if overflow
LDA   load register A
LDB   load register B
MAB   move register A to register B
MEMORY memory unit
MOV   move register A to memory
NOT   logical NOT
OF    overflow flag
PC    program counter (instruction pointer)
RET   return from procedure
RRA   rotate right register A
RLA   rotate left register A
SP    stack pointer
SUB   subtract

```

Das Bild zerfällt in 5 Felder:

|    |        |          |          |  |
|----|--------|----------|----------|--|
|    |        | Feld 1   |          |  |
|    |        |          |          |  |
| >_ |        | Register | Mnemonik |  |
|    | Feld 3 | Feld 4   | Feld 5   |  |

**Feld 1** stellt die Schaltung des LC1-Prozessors dar. Der aktuelle Inhalt der Register A, B, BR, DR, IA, PC und SP sowie des Flags OF ist binär angegeben:

```

'☺' = '0'
'☻' = '1'
'-' = nicht gesetzt (nur bei Register IA).

```

Die Verbindung zwischen Adreßbus AB und Datenbus DB am rechten Rand des Feldes 1 ist eine sog. Bridge (Brücke), die z. B. für die Befehle CAL und RET benötigt wird.

**Feld 2** zeigt den aktuellen Inhalt des Speichers in der Form

adr opc dec bin.

adr = absolute Adresse (adr = 0...63).

Nach Eingabe von **v 0** (Default) am LC1-Prompt wird der Inhalt der Speicherzellen 0...24, nach Eingabe von **v 25** der Inhalt der Speicherzellen 25 bis 49 und nach Eingabe von **v 50** der Inhalt der Speicherzellen 50 bis 63 angezeigt.

opc = mnemonischer Operationscode = LDA|LDB|...|HLT|D

Die Operationscodes LDA|LDB|...|HLT bezeichnen den entsprechenden LC1-Befehl und entsprechen damit den linken 4 Bits des Inhalts der Speicherzelle. Der Bezeichner D steht für den Pseudo-Operationscode DEF.

dec = Inhalt der Speicherzelle, dezimal

Bei opc = LDA|LDB|...|HLT wird in dec das Dezimaläquivalent der rechten 6 Bits des Inhalts der Speicherzelle angegeben, für opc = D das Dezimaläquivalent aller 10 Bits des Inhalts der Speicherzelle.

bin = Inhalt der Speicherzelle, binär

**Feld 3** enthält nur den LC1-Prompt, hinter dem die LC1-Kommandos einzugeben sind.

**Feld 4** zeigt den aktuellen, binären Inhalt der Register A, B, DR, AR, IR (= BR), PC und SP. In der letzten Zeile gibt

Bpt dec Int dec

an, ob ein Break point (= Haltepunkt) oder eine Interruptadresse gesetzt worden sind:

dec = -- , nicht gesetzt  
dec = 0...63, auf diese Adresse gesetzt

**Feld 5** faßt die Operationscodes der LC1-Befehle als Gedächtnisstütze zusammen (nur von Bedeutung für die Eingabe von LC1-Maschinenbefehlen direkt am LC1-Prompt).

## 2. Architektur des LC1-Prozessors

Der LC1-Prozessor zerfällt grob in Steuerwerk und Rechenwerk. Zum Steuerwerk zählen wir die eigentliche Steuerung CONTROL und die Register BR, IA, PC und SP, zum Rechenwerk die ALU, die Register A und B und den Speicher MEMORY mit den Registern AR

und DR.

## 2.1. Arbeitsweise des Steuerwerks

Das Abarbeiten eines Maschinenbefehls erfolgt in zwei Phasen, der Fetchphase und der Executephase. In der Fetchphase wird der Befehl aus dem Speicher ausgelesen, in der Executephase wird er ausgeführt.



Die Arbeitsweise soll mit einer PASCAL-ähnlichen Notation des Ablaufs erläutert werden. Das Befehlsregister BR ist aufgeteilt in die linken, d. h. ersten 4 Bits, die den Operationscode opc des Maschinenbefehls aufnehmen ( $opc = \alpha_4/BR$ ), und die rechten, d. h. letzten 6 Bits für die Operandenadresse opdadr ( $opdadr = \omega_6/BR$ ).

Nach dem Einschalten (start) werden die Register PC und SP initialisiert. Danach tritt der Prozessor in eine unendliche Schleife aus Fetchphase und Executephase ein. In der Fetchphase wird aus der Speicherzelle, deren Adresse im Register PC steht, ein Befehl ausgelesen und ins Befehlsregister BR geladen. Anschließend wird das Register PC inkrementiert. In der Executephase wird der im Befehlsregister BR stehende Befehl ausgeführt. Abhängig vom aktuellen Operationscode wird eine Folge von "Mikrooperationen" abgearbeitet, die den Maschinenbefehl realisieren.

```

start:  PC := 0;
        SP := 63;                                ] Initialisierung
;
loop:   AR := PC;
        DR := MEMORY(AR);
        BR := DR;
        PC := PC + 1;                            ] Fetchphase
;
        case opc of
            '0000': AR := opdadr;      {LDA}    ] Executephase
                DR := MEMORY(AR);
                A := DR;
            '0001': AR := opdadr;      {LDB}    s. Anlage
                DR := MEMORY(AR);
                B := DR;
            '0011': B := A;           {MAB}
            '1000': PC := opdadr;      {JMP}
            .....
        end;                                ]
;
        goto loop;
  
```

## 2.2. Arbeitsweise des Rechenwerks



Im Mittelpunkt steht die ALU mit ihren 10-Bit-Eingangssports ALU1 und ALU2, dem 10-Bit-Ausgangsport ALU3, den Steuereingängen S und dem Flagausgang OF (overflow flag). Die Eingangssports sind mit den Datenausgängen der Register A bzw. B verbunden, das Ausgangsport mit den Dateneingängen des Registers A. Das Rechenwerk weist damit die für Ein-Adreß-Maschinen (Akkumulatormaschinen) typische Struktur auf. Das Register A ist der sog. Akkumulator. Die Funktion der ALU wird über die Steuereingänge S der ALU ausgewählt:

| opc | Funktion       |                               |
|-----|----------------|-------------------------------|
| ADD | Addition       | ALU3 := ALU1 + ALU2           |
| SUB | Subtraktion    | ALU3 := ALU1 - ALU2           |
| AND | Konjunktion    | ALU3 := ALU1 & ALU2, bitweise |
| NOT | Negation       | ALU3 := NOT ALU1, bitweise    |
| RRA | Rechtsrotation | ALU3 := RR(ALU1, n)           |
| RLA | Linksrotation  | ALU3 := RL(ALU1, n)           |

Die in der schematischen Darstellung des Rechenwerks eingezeichneten Datenwege sind ungesteuert ( $A \rightarrow ALU1$ ,  $B \rightarrow ALU2$ ) oder abhangig vom Operationscode gesteuert (alle anderen):

| opc | aktive Datenwege |         |   |         |
|-----|------------------|---------|---|---------|
| LDA | A := DR          | -       | - | -       |
| LDB | -                | B := DR | - | -       |
| MOV | -                | -       | - | DR := A |
| MAB | -                | B := A  | - | -       |
| ADD | A := ALU3        | -       | - | -       |
| SUB | A := ALU3        | -       | - | -       |
| AND | A := ALU3        | -       | - | -       |
| NOT | A := ALU3        | -       | - | -       |
| RRA | A := ALU3        | -       | - | -       |
| RLA | A := ALU3        | -       | - | -       |

Die beiden Flags SF und OF werden auf unterschiedliche Weise gebildet. SF ist identisch mit dem höchstwertigen Bit des Registers A, d. h.  $SF = A(9)$ . Jeder Maschinenbefehl, der den Inhalt

des Registers A verändern kann, beeinflußt auch das Flag SF (LDA, ADD, SUB, AND, NOT, RRA, RRL). Die Eigenschaft des LC1, daß der Ladebefehl LDA das Flag SF beeinflußt, ist eine Besonderheit des LC1, die bei INTEL-Prozessoren nicht zu finden ist! Sie führt zu sehr kompakten Programmen. OF wird nur durch die Befehle ADD und SUB beeinflußt. Die Tabelle stellt die möglichen Fälle zusammen:

| opc | ALU1 | ALU2 | ALU3 | OF |
|-----|------|------|------|----|
| ADD | < 0  | < 0  | < 0  | 0  |
|     | < 0  | < 0  | ≥ 0  | 1  |
|     | < 0  | ≥ 0  |      | 0  |
|     | ≥ 0  | < 0  |      | 0  |
|     | ≥ 0  | ≥ 0  | < 0  | 1  |
|     | ≥ 0  | ≥ 0  | ≥ 0  | 0  |
| SUB | < 0  | < 0  |      | 0  |
|     | < 0  | ≥ 0  | < 0  | 0  |
|     | < 0  | ≥ 0  | ≥ 0  | 1  |
|     | ≥ 0  | < 0  | < 0  | 1  |
|     | ≥ 0  | < 0  | ≥ 0  | 0  |
|     | ≥ 0  | ≥ 0  |      | 0  |

## Anhang

### Maschinenbefehlsliste

| Format | Notation         | Bemerkung                                     |
|--------|------------------|-----------------------------------------------|
| 1      | adr opc          | opc = MAB   ADD   SUB   AND   NOT   RET   HLT |
| 2      | adr opc opdadadr | opc = LDA   LDB   MOV   JMP   JPS   JPO   CAL |
| 3      | adr opc n        | opc = RRA   RRL                               |
| 4      | adr opc const    | opc = DEF                                     |

adr = 0,1,...,63  
 opc = LDA | LDB | ... | HLT | DEF  
 opdadadr = 0,1,...,63  
 n = 0,1,...,63  
 const = -512,-511,...,511

- Befehlsadresse  
 - Operationscode  
 - Operandenadresse (opc = LDA | LDB | MOV)  
 - Sprungadresse (opc = JMP | JPS | JPO)  
 - Unterprogrammadresse (opc = CAL)  
 - Rotationsweite  
 - Konstante

| Befehl       | Mikrooperationen                              | Funktion              | Flags |
|--------------|-----------------------------------------------|-----------------------|-------|
| LDA opdadadr | AR := opdadadr<br>DR := MEMORY(AR)<br>A := DR | A := MEMORY(opdadadr) | SF    |
| LDB opdadadr | AR := opdadadr<br>DR := MEMORY(AR)<br>B := DR | B := MEMORY(opdadadr) | -     |

| Befehl     | Mikrooperationen                                                         | Funktion                                                                              | Flags  |
|------------|--------------------------------------------------------------------------|---------------------------------------------------------------------------------------|--------|
| MOV opdadr | AR := opdadr<br>DR := A<br>MEMORY(AR) := DR                              | MEMORY(opdadr) := A                                                                   | -      |
| MAB        | B := A                                                                   | B := A                                                                                | -      |
| ADD        | ALU1 := A<br>ALU2 := B<br>ALU3 := ALU1 + ALU2<br>A := ALU3               | A := A + B                                                                            | SF, OF |
| SUB        | ALU1 := A<br>ALU2 := B<br>ALU3 := ALU1 - ALU2<br>A := ALU3               | A := A - B                                                                            | SF, OF |
| AND        | ALU1 := A<br>ALU2 := B<br>ALU3 := ALU1 & ALU2<br>A := ALU3               | A := A & B, bitweise                                                                  | SF     |
| NOT        | ALU1 := A<br>ALU3 := NOT ALU1<br>A := ALU3                               | A := NOT A, bitweise                                                                  | SF     |
| JMP opdadr | PC := opdadr                                                             | PC := opdadr                                                                          | -      |
| JPS opdadr | if SF = 1<br>then PC := opdadr                                           | if SF = 1<br>then PC := opdadr                                                        | -      |
| JPO opdadr | if OF = 1<br>then PC := opdadr                                           | if OF = 1<br>then PC := opdadr                                                        | -      |
| CAL opdadr | DR := PC<br>AR := SP<br>MEMORY(AR) := DR<br>SP := SP - 1<br>PC := opdadr | MEMORY(SP) := PC<br>SP := SP - 1<br>PC := opdadr                                      | -      |
| RET        | SP := SP + 1<br>AR := SP<br>DR := MEMORY(AR)<br>PC := DR                 | SP := SP + 1<br>PC := MEMORY(SP)                                                      | -      |
| RRA n      | ALU1 := A<br>ALU3 := RR(ALU1, n)<br>A := ALU3                            | A(9...0) := A(0), A(9...1)<br>n-mal                                                   | SF     |
| RLA n      | ALU1 := A<br>ALU3 := RL(ALU1, n)<br>A := ALU3                            | A(9...0) := A(8...1), A(9)<br>n-mal                                                   | SF     |
| HLT        | HALT                                                                     | stoppt die Arbeit<br>des Prozessors                                                   | -      |
| DEF const  | Definiere<br>Konstante                                                   | ordnet die definierte Kon-<br>stante der durch adr fest-<br>gelegten Speicherzelle zu | -      |