# Midterm Review Introduction to Computer Systems, Fall 2022 

Instructor: Travis McGaha

## TAs:

Ali Krema
Audrey Yang
David LuoZhang
Heyi Liu
Katherine Wang
Noam Elul
Ria Sharma

Andrew Rigas
Craig Lee
Eddy Yang
Janavi Chadha
Kyrie Dowling
Patricia Agnes
Sarah Luthra

Anisha Bhatia
Daniel Duan
Ernest Ng
Jason Hom
Mohamed Abaker
Patrick Kehinde Jr.
Sofia Mouchtaris

## Midterm Review: Choose what we do next

Binary \& 2C practice questions
Floating Point practice question
CMOS, PLA, Gate circuits practice

questions $|$| LC4 Programming practice |
| ---: |
| question |
| Control Signals practice quetsion |
| General Q \& A |

## Logistics

* Midterm Exam: This Wednesday "in lecture"
- Details released on the course website
* Midterm Review in recitation
- Tuesdays 6:30-8 pm @ Moore 100a
- Wednesdays 12-1:30 pm @ Moore 100c
* Instructor OH shifted to 1:30-4:30 pm on Wednesday
* HW03 Sample Solutions (and grades probably) posted tonight


## Binary \& 2C

* There are about 195 students in the class and 22 staff. If we wanted to assign each of these individuals a unique numerical ID, how many bits would each ID need to be?
* Translate:
- -1 into 8-bit 2C
- 7 into 4-bit 2c
- 5 into 3bit unsigned


## Floats

* A common way of checking for equality between floats in code is to see if the difference between the two floats exceeds a certain magnitude instead of checking for exact equality. E.g.:

```
bool float_equals(float a, float b) {
    double delta = 0.01f;
    if (abs(a - b) < delta) {
        return true;
    }
    return false;
}
```

*Why is this the case?

## CMOS, PLAS, GATES

* Create a circuit that takes in an unsigned 4-bit input I $\left(I_{3} I_{2} I_{1} I_{0}\right)$, and outputs a 1 if and only if the 4-bit input is a non-zero multiple of 7
- List the outputs that result in a 1 for the output
- Create a corresponding CMOS circuit
- Can assume you have the inverses of the Input bits
- Create a corresponding PLA circuit
- Create a corresponding gate level non-PLA circuit


## CMOS, PLAS, GATES

* Create a circuit that takes in an unsigned 4-bit input I $\left(I_{3} I_{2} I_{1} I_{0}\right)$, and outputs a 1 if and only if the 4-bit input is a non-zero multiple of 7
- List the outputs that result in a 1 for the output
- 7 (0b0111) and 14 (0b1110)


## CMOS

* Create a circuit that takes in an unsigned 4-bit input I $\left(I_{3} I_{2} I_{1} I_{0}\right)$, and outputs a 1 if and only if the 4-bit input is a non-zero multiple of 7 . You can assume you have inverse of the input signals.
- Overall Expression: $\left(\sim I_{3} \& I_{2} \& I_{1} \& I_{0}\right) \mid\left(I_{3} \& I_{2} \& I_{1} \& \sim I_{0}\right)$

CMOS Strategy 1 (Starting with PDN)

* Overall Expression: $\left({ }^{\sim} I_{3} \& I_{2} \& I_{1} \& I_{0}\right) \mid\left(I_{3} \& I_{2} \& I_{1} \&{ }^{\sim} I_{0}\right)$
* PDN Expression:
- $\sim\left(\left(\sim I_{3} \& I_{2} \& I_{1} \& I_{0}\right) \mid\left(I_{3} \& I_{2} \& I_{1} \& \sim I_{0}\right)\right) \quad / /$ negate
- $\sim\left(\sim I_{3} \& I_{2} \& I_{1} \& I_{0}\right) \& \sim\left(I_{3} \& I_{2} \& I_{1} \& \sim I_{0}\right) \quad / / D e$ Morgan's
- ( $\left.I_{3}\left|\sim I_{2}\right| \sim I_{1} \mid \sim I_{0}\right) \&\left(\sim I_{3}\left|\sim I_{2} \sim I_{1}\right| I_{0}\right) \quad / / D e$ Morgan's
* Translated to PDN:



## CMOS Strategy 1 (Starting with PDN)

* Flip PDN into PUN:



## CMOS Strategy 1 (Starting with PDN)

Not the only

* Connect PDN and PUN:



## CMOS Strategy 2 (Starting with PUN)

* Take the original expression:
- $\left(I_{3} \& I_{2} \& I_{1} \& \sim I_{0}\right) \mid\left(\sim I_{3} \& I_{2} \& I_{1} \& I_{0}\right)$
* Translate it directly into PDN but add a negation to each input
- This is because PMOS transistors are "naturally negating"
- E.g., $\sim I_{3}$ becomes $\sim \sim I_{3}==I_{3}$



## CMOS Strategy 2 (Starting with PUN)

* Flip PUN to get PDN



## PLA

* Create a circuit that takes in an unsigned 4-bit input I $\left(I_{3} I_{2} I_{1} I_{0}\right)$, and outputs a 1 if and only if the 4-bit input is a non-zero multiple of 7


## Non-PLA

* Create a circuit that takes in an unsigned 4-bit input I $\left(I_{3} I_{2} I_{1} I_{0}\right)$, and outputs a 1 if and only if the 4-bit input is a non-zero multiple of 7


## Gate delay pt. 1

* Given the 4-bit incrementor that we created in lecture, how long do we have to wait to make sure that the output of the incrementor matches the input?
- Assume that each gate has a 1 ns delay
- You can ignore delay from inverters



## Gate delay pt. 2

* The 4-bit incrementor that we created in lecture is currently in a stable state showing the output of $1+0110$. If the A input signals were to simultaneously flip to 0111, what would all signals be after 2 ns
- Assume that each gate has a 1 ns delay
- Ignore delays from inverters
- Carryln $n_{n}$ stays the same $A_{n} C_{\text {in }}$



## LC4 Programming

* Write an asm program that you can assume has:
- RO = addr of start of array
- R1 = length of array that RO refers to
- R2 = addr of start of destination array (you can assume there is enough memory locations "free" to store the resulting array)
- R3 = Filter integer
* Your asm should make a copy of the array referred to by RO into the memory referred to by R1. However, you should not include any value that is less than or equal to the filter integer put in R3.
* You are free to update the registers as long as the memory referred to by R2 is properly updated and the length of the new array is stored in R4 by the end.


## Control Signals

* Bit-wise XOR operations can be used to test for equality. If A XOR B is 0 , then the two values contained the same bit pattern. As a result, Travis wants to add the CMPX instruction, which updates the NZP based off of the XOR of two register values.
- Mnemonic: CMPX Rs, Rt
- Semantics: NZP = sign (Rs ^ Rt)
- Encoding: 0011 ttts ssxx xxxx
* What are the control signals for this instruction?


## General Questions \& Answers

* Take questions/requests from students

| Mnemonic | Semantics | Encoding |
| :---: | :---: | :---: |
| NOP | $\mathrm{PC}=\mathrm{PC}+1$ | 0000 000x xxxx xxxx |
| BRp <Label> | ( P) ? PC = PC + $1+($ sext (IMM9) offset to <Label>) | 0000 001i iiii iiii |
| BRz <Label> | ( Z ) ? $\mathrm{PC}=\mathrm{PC}+1+(\operatorname{sext}($ IMM9) offset to <Label>) | 0000 010i iiii iiii |
| BRzp <Label> | ( $\mathrm{Z} \mid \mathrm{P}$ ) ? PC = PC + $1+($ sext (IMM9) offset to <Label>) | 0000 011i iiii iiii |
| BRn <Label> | ( $\mathrm{N} \quad$ ) ? PC = PC + $1+($ sext (IMM9) offset to <Label>) | 0000 100i iiii iiii |
| BRnp <Label> | ( $\mathrm{N} \mid \mathrm{P})$ ? PC = PC + $1+($ sext (IMM9) offset to <Label>) | 0000 101i iiii iiii |
| BRnz <Label> | ( $\mathrm{N} \mid \mathrm{Z}$ ) ? PC = PC + $1+$ (sext (IMM9) offset to <Label>) | 0000 110i iiii iiii |
| BRnzp <Label> | ( $\mathrm{N}\|\mathrm{Z}\| \mathrm{P}$ ) ? PC = PC + $1+($ sext (IMM9) offset to <Label>) | 0000 111i iiii iiii |
| ADD Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs}+\mathrm{Rt}$ | 0001 ddds ss00 Ottt |
| MUL Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs} \mathrm{*} \mathrm{Rt}$ | 0001 ddds ss00 1ttt |
| SUB Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs}$ - Rt | 0001 ddds ss01 Ottt |
| DIV Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs} / \mathrm{Rt}$ | 0001 ddds ss01 1ttt |
| ADD Rd Rs IMM5 | $\mathrm{Rd}=\mathrm{Rs}+\mathbf{s e x t}($ IMM5 $)$ | 0001 ddds ss1i iiii |
| MOD Rd Rs Rt | Rd = Rs \% Rt | 1010 ddds ss11 xttt |
| AND Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs}$ \& Rt | 0101 ddds ss00 Ottt |
| NOT Rd Rs | $\mathrm{Rd}=\sim \mathrm{Rs}$ | 0101 ddds ss00 1xxx |
| OR Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs}$ \| Rt | 0101 ddds ss01 Ottt |
| XOR Rd Rs Rt | $\mathrm{Rd}=\mathrm{Rs} \wedge \mathrm{Rt}$ | 0101 ddds ss01 1ttt |
| AND Rd Rs IMM5 | $\mathrm{Rd}=\mathrm{Rs}$ \& sext (IMM5) | 0101 ddds ss1i iiii |
| LDR Rd Rs IMM6 | $\mathrm{Rd}=$ dmem[Rs + sext(IMM6)] | 0110 ddds ssii iiii |
| STR Rt Rs IMM6 | dmem[Rs + sext(IMM6)] = Rt | 0111 ttts ssii iiii |
| CONST Rd IMM9 | $\mathrm{Rd}=\boldsymbol{s e x t}($ IMM9) | 1001 dddi iiii iiii |
| HICONST Rd UIMM8 | $\mathrm{Rd}=(\mathrm{Rd}$ \& 0xFF) $\mid$ (UIMM8 $\ll 8$ ) | 1101 dddx uuuu uuuu |
| CMP Rs Rt | NZP = sign(Rs - Rt) ${ }^{2}$ | 0010 sss0 0xxx xttt |
| CMPU Rs Rt | NZP $=\operatorname{sign}(u R s-u R t)^{3}$ | 0010 sss0 1xxx xttt |
| CMPI Rs IMM7 | NZP $=$ sign(Rs - IMM7) | 0010 sss1 Oiii iiii |
| CMPIU Rs UIMM7 | NZP = sign(uRs - UIMM7) | 0010 sss1 1uuu uuuu |
| SLL Rd Rs UIMM4 | $\mathrm{Rd}=\mathrm{Rs}$ << UIMM4 | 1010 ddds ss00 uuuu |
| SRA Rd Rs UIMM4 | $\mathrm{Rd}=\mathrm{Rs} \ggg$ UIMM4 | 1010 ddds ss01 uuuu |
| SRL Rd Rs UIMM4 | $\mathrm{Rd}=\mathrm{Rs} \gg$ UIMM4 | 1010 ddds ss10 uuuu |
| JSRR Rs | R7 = PC + 1; PC = Rs | 0100 0xxs ssxx xxxx |
| JSR <Label> | R7 = PC + 1; PC = (PC \& 0x8000) \| ( $($ IMM11 offset to <Label>) << 4) | 0100 1iii iiii iiii |
| JMPR Rs | $\mathrm{PC}=\mathrm{Rs}$ | 1100 Oxxs ssxx xxxx |
| JMP <Label> | $\mathrm{PC}=\mathrm{PC}+1+(\operatorname{sext}($ IMM11 $)$ offset to <Label>) | 1100 1iii iiii iiii |
| TRAP UIMM8 | R7 = PC + 1; PC = (0x8000 \| UIMM8) ; PSR [15] = 1 | 1111 xxxx uuuu uuuu |
| RTI | $\mathrm{PC}=\mathrm{R} 7$; PSR [15] $=0$ | 1000 xxxx xxxx xxxx |



| Signal Name | \# of bits | Value | Action |
| :---: | :---: | :---: | :---: |
| PCMux.CTL | 3 | 0 | Value of NZP register compared to bits I[11:9] of the current instruction if the test is satisfied then the output of TEST is 1 and NextPC = BRANCH Target, $(\mathrm{PC}+1)+\mathrm{SEXT}(\mathrm{IMM} 9)$; otherwise the output of TEST is 0 and NextPC $=\mathrm{PC}+1$ |
|  |  | 1 | Next PC = PC+1 |
|  |  | 2 | Next PC $=(\mathrm{PC}+1)+$ SEXT(IMM11) |
|  |  | 3 | Next PC = RS |
|  |  | 4 | Next PC $=(0 \times 8000 \mid$ UIMM8) |
|  |  | 5 | Next PC $=($ PC \& 0x8000) \| $($ IMM11 $\ll 4$ ) |
| rsMux.CTL | 2 | 0 | rs.addr $=$ I[8:6] |
|  |  | 1 | rs.addr $=0 \times 07$ |
|  |  | 2 | rs.addr $=$ I[11:9] |
| rtMux.CTL | 1 | 0 | rt.addr $=$ I[2:0] |
|  |  | 1 | rt.addr $=$ I[11:9] |
| rdMux.CTL | 1 | 0 | rd.addr = I[11:9] |
|  |  | 1 | rd.addr $=0 \times 07$ |
| regFile.WE | 1 | 0 | Register file not written |
|  |  | 1 | Register file written: rd.addr indicates which register is updated with the value on the Write Input |
| regInput.Mux.CTL | 2 | 0 | Write Input = ALU output |
|  |  | 1 | Write Input = Output of Data Memory |
|  |  | 2 | Write Input = PC + 1 |
| NZP.WE | 1 | 0 | NZP register not updated |
|  |  | 1 | NZP register updated from Write Input to register file |
| DATA.WE | 1 | 0 | Data Memory not written |
|  |  | 1 | Data Input written into location on Data Address lines |
| Privilege.CTL | 2 | 0 | PSR[15] = 0 - Clear privilege bit |
|  |  | 1 | PSR[15] = 1 - Set privilege bit |
|  |  | 2 | PSR[15] unchanged - no change to privilege bit |


| Signal Name | \# of bits | Value | Action |
| :---: | :---: | :---: | :---: |
| ALU.CTL | 6 |  |  |
| Arithmetic 0ps |  | 0 | $\mathrm{C}=\mathrm{A}+\mathrm{B}$ : Addition |
|  |  | 1 | $\mathrm{C}=\mathrm{A} * \mathrm{~B}$ : Multiplication |
|  |  | 2 | C $=$ A - B : Subtraction |
|  |  | 3 | $\mathrm{C}=\mathrm{A} / \mathrm{B}$ : Division |
|  |  | 4 | $\mathrm{C}=\mathrm{A} \% \mathrm{~B}$ : Modulus |
|  |  | 5 | $\mathrm{C}=\mathrm{A}+\mathrm{SEXT}(\mathrm{B}[4: 0])$ |
|  |  | 6 | $\mathrm{C}=\mathrm{A}+\mathrm{SEXT}(\mathrm{B}[5: 0])$ |
| Logical Ops |  | 8 | C = A AND B : Bitwise Logical Product |
|  |  | 9 | C = NOT A: Bitwise Negation |
|  |  | 10 | C = A OR B: Bitwise Logical Sum |
|  |  | 11 | C = A XOR B: Bitwise Exclusive OR |
|  |  | 12 | $\mathrm{C}=\mathrm{A}$ AND SEXT (B[4:0]) |
| Comparator Ops |  | 16 | $C=$ signed-CC(A-B) $[-1,0,+1]$ |
|  |  | 17 | $\mathrm{C}=$ unsigned-CC(A-B) $[-1,0,+1]$ |
|  |  | 18 | $\mathrm{C}=$ signed-CC(A-SEXT(B[6:0]) ) [-1, 0, +1] |
|  |  | 19 | $\mathrm{C}=$ unsigned-CC(A-SEXT(B[6:0]) $][-1,0,+1]$ |
| Shifter Ops |  | 24 | $\mathrm{C}=\mathrm{A} \ll \mathrm{B}$ [3:0] : Shift Left Logical |
|  |  | 25 | $\mathrm{C}=\mathrm{A} \ggg \mathrm{B}$ [3:0] : Shift Right Arithmetic |
|  |  | 26 | $\mathrm{C}=\mathrm{A} \gg \mathrm{B}[3: 0]$ : Shift Right Logical |
| Constant Ops |  | 32 | $\mathrm{C}=$ SEXT $(\mathrm{B}[8: 0])$ |
|  |  | 33 | $\mathrm{C}=(\mathrm{A} \& 0 \times \mathrm{FF}) \mid(\mathrm{B}[7: 0] \ll 8)$ |

