## Computer Systems and Networks ECPE 170 – Jeff Shafer – University of the Pacific # MARIE Instruction Decoding ## Schedule - Today - MARIE instruction decoding hardware - Plus Quiz 3! - **Thursday** Begin Chapter 5 - Closer look at instruction sets ## Homework 4.33 Review ``` / Top of list pointer Addr, Hex Node2, Hex 0032 / Node's data is the character "2." / Address of Node3. Hex Node4, Hex 0034 / Character "4." Hex Node1, Hex 0031 / Character "1" Hex Node3, Hex 0033 / Character "3" Hex Node5, Hex 0035 / Character "5" Hex 0000 / Indicates terminal node. ``` ## Instruction Decoding - Role of processor control unit - Keeps operations synchronized - Make sure that bits flow to the correct components at the correct time - How can we build this control unit? - **7** Hardwired control, or - Microprogrammed control - The result is the same control signals! - Remember the register transfer language description of each MARIE instruction? - **7** Table 4.7 - This is what the control unit manages - Each microoperation consists of a distinctive signal pattern that is interpreted by the control unit and results in the execution of an instruction - **7** RTL for the Add instruction: ``` MAR ← X MBR ← M[MAR] AC ← AC + MBR ``` - MARIE registers and main memory have a unique datapath address - This address is issued as control signals by the control unit - How many signal lines does MARIE's control unit need to manage registers/main memory? 16-bit bus - Two sets of three signals each - **7** {P2, P1, P0} - Controls reading from memory or a register - **7** {P5, P4, P3} - Controls writing to memory or a register - What does this look like in detail? - MBR shown next 16-bit bus ## Memory Buffer Register (MBR) Closeup - Control unit must manage more than just registers/ main memory - What about the ALU modes? - ALU has only four operations - Add, subtract, clear, and "do nothing" - ALU controls: $A_0 A_1$ | ALU Control<br>Signals | | | |------------------------|------------------|----------------------------------------------------------------| | $A_0$ | A <sub>1</sub> | ALU Response | | 0<br>1<br>0<br>1 | 0<br>0<br>1<br>1 | Do Nothing<br>AC ← AC + MBR<br>AC ← AC – MBR<br>AC ← 0 (Clear) | - How does the control unit perform operations in sequence? - Longest instruction is JNS (look at RTL in Table 4.7) - 7 steps - Need a 3-bit counter wired to a 3-8 decoder - Counter reset for shorter instructions - Output of decoder is "timing" signals: T<sub>0</sub> T<sub>7</sub> - The entire set of MARIE's control signals consists of: - Register controls - P<sub>0</sub> through P<sub>5</sub> - ALU controls - $A_0$ through $A_1$ - 7 Timing - $T_0$ through $T_7$ - Counter reset C<sub>r</sub> #### **ADD Instruction Control** - ADD instruction RTL - **7** MAR ← X - MBR ← M[MAR] - **7** AC ← AC + MBR - After the add instruction is fetched, the address (X) is in the rightmost 12 bits of the IR - IR datapath address is 7 - Raise signals P2, P1, and P0 to read from IR - X is copied to the MAR - MAR datapath address is 1 - Raise signal P3 to write to MAR #### **ADD Instruction Control** - Complete signal sequence for ADD instruction - **7** P3 P2 P1 P0 T0: MAR ← X - **P4 P3 T1:** $MBR \leftarrow M[MAR]$ - $\nearrow$ A0 P5 P1 P0 T2: AC $\leftarrow$ AC + MBR - **7** Cr T3: [Reset counter] - These signals are ANDed with combinational logic to bring about the desired machine behavior #### **ADD Instruction Control** - Add instruction timing diagram - Notice the concurrent signal states during each machine cycle: C0 through C3. P3 P2 P1 P0 T0: MAR $\leftarrow$ X P4 P3 T1: MBR $\leftarrow$ M[MAR] A0 P5 P1 P0 T2: AC $\leftarrow$ AC + MBR Cr T3: [Reset counter] - This signal pattern needs to be produced regardless of whether the processor uses *hardwired* or *microprogrammed* control - Hardwired control unit - Control unit is pure digital logic - Microprogrammed control unit - → A tiny program (called "microcode") saved in ROM - Even more rudimentary than assembly language! - Microinstructions are fetched, decoded, and executed in the same manner as regular instructions - Control unit works like a processor-in-miniature # Hardwired vs Microprogrammed #### Hardwired - "Faster" (historically) - Simple - Fixed requires redesigning circuit to change operation All modern processors use some form of microprogramming for control #### Microprogrammed - "Slower" (historically due to extra level of instruction interpretation) - Flexible Changing firmware alters the way processor executes instruction - If firmware is in flash, you can reprogram processor to fix bugs! - Scalable Supports complicated instructions with minimal hardware overhead ## Quiz 3 – MARIE Stack - Operations: - **7** PUSH - PEEK - **7** POP - Two key stack variables - **♂** StackBasePtr Pointer to base of stack - StackCtr Count of current number of elements in stack - Start of program - Nothing on the stack! - Base pointer points to base of stack - Counter is 0 | Sta | ckF | 3as | eΡ | tr | |-----|-----|-----|----|----| #### StackCtr | Address | Contents | |---------|-------------| | 000 | [[Program]] | | 001 | [[Program]] | | | [[Program]] | | 100 | 102 | | 101 | 0 | | 102 | | | 103 | | | 104 | | **Computer Systems and Networks** Fall 201 **Contents** **Address** - Push [55] operation - Results after push - Counter is now 1 - Stack element 0 created - Where does the element go? - Mem[102+0] Value of counter before incrementing! | 71441 233 | Contents | |-----------|-------------| | 000 | [[Program]] | | 001 | [[Program]] | | | [[Program]] | | 100 | 102 | | 101 | 1 | | 102 | 55 | | 103 | | | 104 | | **StackBasePtr** **StackCtr** Stack[0] - Push [66] operation - Results after push - Counter is now 2 - Stack element 1 created | | Address | Contents | |--------------|---------|-------------| | | 000 | [[Program]] | | | 001 | [[Program]] | | | | [[Program]] | | StackBasePtr | 100 | 102 | | StackCtr | 101 | 2 | | Stack[0] | 102 | 55 | | Stack[1] | 103 | 66 | | | 104 | | - Peek operation - Results after peek - Counter is unchanged - Stack is unchanged - **7** Element 66 is available - Where did we find 66? - **7** Mem[102+(2-1)] | | Address | Contents | |--------------|---------|-------------| | | 000 | [[Program]] | | | 001 | [[Program]] | | | | [[Program]] | | StackBasePtr | 100 | 102 | | StackCtr | 101 | 2 | | Stack[0] | 102 | 55 | | Stack[1] | 103 | 66 | | | 104 | | **Contents** - Pop operation - Results after pop - Counter is now 1 - Stack is unchanged - Don't need to modify the stack in memory - 66 can persist as garbage value beyond current top of stack | | Address | |---|---------| | | 000 | | | 001 | | | ••• | | | 100 | | I | 101 | | | 102 | | | 103 | | Î | 1 0 1 | **StackBasePtr** StackCtr Stack[0] [[Program]] [[Program]] [[Program]] 102 55 66 104