

## Number Systems

| System           | Value                                                             | -x                 | Negation            | Addition                     | Overflow                                                         |
|------------------|-------------------------------------------------------------------|--------------------|---------------------|------------------------------|------------------------------------------------------------------|
| Sign & Magnitude |                                                                   |                    | Invert first bit    |                              |                                                                  |
| 1s Complement    | +ve: same as 2s<br>-ve: $2s + 1$                                  | $2^n -$<br>$x - 1$ | Invert all bits     | If MSB carry out: $\oplus 1$ | Result opposite sign of A and B                                  |
| 2s Complement    | if $x[n-1]: = 2^{n-1}$<br>for i in [n-2..0]:<br>if $x[i]: += 2^i$ | $2^n -$<br>$x$     | Invert all bits + 1 | Ignore MSB carry out         | MSB carry in != MSB carry out<br>Result opposite sign of A and B |
| Excess-n         | $x-n$                                                             |                    |                     |                              |                                                                  |
| IEEE 754         | (Sign) (1.Mantissa) $\times 2^{\text{Exponent}}$                  |                    | Invert first bit    | 1: Sign<br>8: Ex-127<br>Exp  | ---<br>23: Mantissa                                              |

## MIPS

| Operation              | RR1 | RR2 | WR  | WD               | Opr1  | Opr2  | Address         | Write Data |
|------------------------|-----|-----|-----|------------------|-------|-------|-----------------|------------|
| lw \$a, x(\$b)         | \$b | \$a | \$a | Mem([\$b]<br>+x) | [\$b] | x     | [\$b] + x       | [\$a]      |
| beq \$a,\$b, immd      | \$a | \$b | \$b | ?                | [\$a] | [\$b] | [\$a] - [\$b]   | [\$b]      |
| sub \$a, \$b, \$c      | \$b | \$c | \$a | [\$b] - [\$c]    | [\$b] | [\$c] | [\$b] - [\$c]   | [\$c]      |
| addi \$a, \$b,<br>immd | \$b | \$a | \$a | [\$b] + immd     | [\$b] | immd  | [\$b] +<br>immd | [\$a]      |

# MIPS Reference Data

(1)



## CORE INSTRUCTION SET

| NAME, MNEMONIC                                                      | FOR-MAT | OPERATION (in Verilog)                                      | OPCODE / FUNCT (Hex)      |
|---------------------------------------------------------------------|---------|-------------------------------------------------------------|---------------------------|
| Add                                                                 | add     | R[Rd] = R[rs] + R[rt]                                       | (1) 0 / 20 <sub>hex</sub> |
| Add Immediate                                                       | addi    | I R[rt] = R[rs] + SignExtImm                                | (1,2) 8 <sub>hex</sub>    |
| Add Imm. Unsigned                                                   | addiu   | I R[rt] = R[rs] + SignExtImm                                | (2) 9 <sub>hex</sub>      |
| Add Unsigned                                                        | addu    | R R[Rd] = R[rs] + R[rt]                                     | 0 / 21 <sub>hex</sub>     |
| And                                                                 | and     | R R[Rd] = R[rs] & R[rt]                                     | 0 / 24 <sub>hex</sub>     |
| And Immediate                                                       | andi    | I R[rt] = R[rs] & ZeroExtImm                                | (3) c <sub>hex</sub>      |
| Branch On Equal                                                     | beq     | I if(R[rs]==R[rt])<br>PC=PC+4+BranchAddr                    | (4) 4 <sub>hex</sub>      |
| Branch On Not Equal                                                 | bne     | I if(R[rs]!=R[rt])<br>PC=PC+4+BranchAddr                    | (4) 5 <sub>hex</sub>      |
| Jump                                                                | j       | J PC=JumpAddr                                               | (5) 2 <sub>hex</sub>      |
| Jump And Link                                                       | jal     | J R[31]=PC+8;PC=JumpAddr                                    | (5) 3 <sub>hex</sub>      |
| Jump Register                                                       | jr      | R PC=R[rs]                                                  | 0 / 08 <sub>hex</sub>     |
| Load Byte Unsigned                                                  | lbu     | I R[rt]={24'b0,M[R[rs]]+SignExtImm}(7:0)}                   | (2) 24 <sub>hex</sub>     |
| Load Halfword Unsigned                                              | lhu     | I R[rt]={16'b0,M[R[rs]]+SignExtImm}(15:0))                  | (2) 25 <sub>hex</sub>     |
| Load Linked                                                         | ll      | I R[rt] = M[R[rs]]+SignExtImm                               | (2,7) 30 <sub>hex</sub>   |
| Load Upper Imm.                                                     | lui     | I R[rt] = {imm, 16'b0}                                      | f <sub>hex</sub>          |
| Load Word                                                           | lw      | I R[rt] = M[R[rs]]+SignExtImm                               | (2) 23 <sub>hex</sub>     |
| Nor                                                                 | nor     | R R[Rd] = ~ (R[rs]   R[rt])                                 | 0 / 27 <sub>hex</sub>     |
| Or                                                                  | or      | R R[Rd] = R[rs]   R[rt]                                     | 0 / 25 <sub>hex</sub>     |
| Or Immediate                                                        | ori     | I R[rt] = R[rs]   ZeroExtImm                                | (3) d <sub>hex</sub>      |
| Set Less Than                                                       | slt     | R R[Rd] = (R[rs] < R[rt]) ? 1 : 0                           | 0 / 2a <sub>hex</sub>     |
| Set Less Than Imm.                                                  | slti    | I R[rt] = (R[rs] < SignExtImm) ? 1 : 0 (2)                  | a <sub>hex</sub>          |
| Set Less Than Imm. Unsigned                                         | sltiu   | I R[rt] = (R[rs] < SignExtImm)<br>? 1 : 0                   | (2,6) b <sub>hex</sub>    |
| Set Less Than Unsigned                                              | sltu    | R R[Rd] = (R[rs] < R[rt]) ? 1 : 0                           | (6) 0 / 2b <sub>hex</sub> |
| Shift Left Logical                                                  | sll     | R R[Rd] = R[rt] << shampt                                   | 0 / 00 <sub>hex</sub>     |
| Shift Right Logical                                                 | srl     | R R[Rd] = R[rt] >> shampt                                   | 0 / 02 <sub>hex</sub>     |
| Store Byte                                                          | sb      | I M[R[rs]]+SignExtImm](7:0)= R[rt](7:0)                     | (2) 28 <sub>hex</sub>     |
| Store Conditional                                                   | sc      | I M[R[rs]]+SignExtImm] = R[rt];<br>R[rt] = (atomic) ? 1 : 0 | (2,7) 38 <sub>hex</sub>   |
| Store Halfword                                                      | sh      | I M[R[rs]]+SignExtImm](15:0) = R[rt](15:0)                  | (2) 29 <sub>hex</sub>     |
| Store Word                                                          | sw      | I M[R[rs]]+SignExtImm] = R[rt]                              | (2) 2b <sub>hex</sub>     |
| Subtract                                                            | sub     | R R[Rd] = R[rs] - R[rt]                                     | (1) 0 / 22 <sub>hex</sub> |
| Subtract Unsigned                                                   | subu    | R R[Rd] = R[rs] - R[rt]                                     | 0 / 23 <sub>hex</sub>     |
| (1) May cause overflow exception                                    |         |                                                             |                           |
| (2) SignExtImm = { 16{immediate[15]}, immediate }                   |         |                                                             |                           |
| (3) ZeroExtImm = { 16{1b'0}, immediate }                            |         |                                                             |                           |
| (4) BranchAddr = { 14{immediate[15]}, immediate, 2'b0 }             |         |                                                             |                           |
| (5) JumpAddr = { PC+4[31:28], address, 2'b0 }                       |         |                                                             |                           |
| (6) Operands considered unsigned numbers (vs. 2's comp.)            |         |                                                             |                           |
| (7) Atomic test&set pair; R[rt] = 1 if pair atomic, 0 if not atomic |         |                                                             |                           |

## BASIC INSTRUCTION FORMATS

|          |        |       |       |         |       |           |   |
|----------|--------|-------|-------|---------|-------|-----------|---|
| <b>R</b> | opcode | rs    | rt    | rd      | shamt | funct     |   |
|          | 31     | 26 25 | 21 20 | 16 15   | 11 10 | 6 5       | 0 |
| <b>I</b> | opcode | rs    | rt    |         |       | immediate |   |
|          | 31     | 26 25 | 21 20 | 16 15   |       |           | 0 |
| <b>J</b> | opcode |       |       | address |       |           |   |
|          | 31     | 26 25 |       |         |       |           | 0 |

Copyright 2009 by Elsevier, Inc., All rights reserved. From Patterson and Hennessy, Computer Organization and Design, 4th ed.

## ARITHMETIC CORE INSTRUCTION SET

| OPCODE / FMT / FT  | / FUNCT (Hex)                                                                                                                      |
|--------------------|------------------------------------------------------------------------------------------------------------------------------------|
| Branch On FP True  | bcl if(FPcond)PC=PC+4+BranchAddr (4)                                                                                               |
| Branch On FP False | bclf if(!FPcond)PC=PC+4+BranchAddr(4)                                                                                              |
| Divide             | div R Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt] 0/-/-/1a                                                                                      |
| Divide Unsigned    | divu R Lo=R[rs]/R[rt]; Hi=R[rs]%R[rt] (6) 0/-/-/1b                                                                                 |
| FP Add Single      | add.s FR F[fd] = F[fs] + F[ft] 11/10/-/0                                                                                           |
| FP Add             | add.d FR {F(fd),F(fd+1)} = {F(fs),F(fs+1)} + {F(ft),F(ft+1)} 11/11/-/0                                                             |
| Double             | c.x.s* FR FPcond = {F(fs) op F(ft)} ? 1 : 0 11/10/-/y                                                                              |
| FP Compare Single  | c.x.d* FR FPcond = {{F(fs),F(fs+1)}} op {{F(ft),F(ft+1)}} ? 1 : 0 * (x is eq, lt, or le) (op is ==, <, or <=) (y is 32, 3c, or 3e) |
| FP Divide Single   | div.s FR F[fd] = F[fs] / F[ft] 11/10/-/3                                                                                           |
| FP Divide          | div.d FR {F(fd),F(fd+1)} = {F(fs),F(fs+1)} / {F(ft),F(ft+1)} 11/11/-/3                                                             |
| FP Multiply Single | mul.s FR F[fd] = F[fs] * F[ft] 11/10/-/2                                                                                           |
| FP Multiply        | mul.d FR {F(fd),F(fd+1)} = {F(fs),F(fs+1)} * {F(ft),F(ft+1)} 11/11/-/2                                                             |
| FP Subtract Single | sub.s FR F[fd]=F[fs] - F[ft] 11/10/-/1                                                                                             |
| FP Subtract        | sub.d FR {F(fd),F(fd+1)} = {F(fs),F(fs+1)} - {F(ft),F(ft+1)} 11/11/-/1                                                             |
| Double             | load FP Single lwc1 I F[rt]=M[R[rs]+SignExtImm] (2) 31/-/-/--                                                                      |
| Load FP            | load FP ldc1 I F[rt]=M[R[rs]+SignExtImm]; F[rt+1]=M[R[rs]+SignExtImm+4] (2) 35/-/-/--                                              |
| Double             | move mfc0 R R[Rd] = Hi 0 / -/-/10                                                                                                  |
| Move From Hi       | mfl0 R R[Rd] = Lo 0 / -/-/12                                                                                                       |
| Move From Lo       | mfc0 R R[Rd] = CR[rs] 10 / 0/-/0                                                                                                   |
| Move From Control  | mfl0 R {Hi,Lo} = R[rs] * R[rt] 0 / -/-/18                                                                                          |
| Multiply           | mult R {Hi,Lo} = R[rs] * R[rt] (6) 0 / -/-/19                                                                                      |
| Multiply Unsigned  | multu R {Hi,Lo} = R[rs] * R[rt] 0 / -/-/19                                                                                         |
| Shift Right Arith. | sra R R[Rd] = R[rt] >> shampt 0 / -/-/3                                                                                            |
| Store FP Single    | swci I M[R[rs]]+SignExtImm] = F[rt] (2) 39/-/-/--                                                                                  |
| Store FP           | sdci I M[R[rs]]+SignExtImm] = F[rt]; M[R[rs]+SignExtImm+4] = F[rt+1] 3d/-/-/--                                                     |

## FLOATING-POINT INSTRUCTION FORMATS

|           |        |       |       |       |           |       |   |
|-----------|--------|-------|-------|-------|-----------|-------|---|
| <b>FR</b> | opcode | fmt   | ft    | fs    | fd        | funct |   |
|           | 31     | 26 25 | 21 20 | 16 15 | 11 10     | 6 5   | 0 |
| <b>FI</b> | opcode | fmt   | ft    |       | immediate |       | 0 |
|           | 31     | 26 25 | 21 20 | 16 15 |           |       |   |

## PSEUDOINSTRUCTION SET

| NAME                         | MNEMONIC | OPERATION                   |
|------------------------------|----------|-----------------------------|
| Branch Less Than             | blt      | if(R[rs]<R[rt]) PC = Label  |
| Branch Greater Than          | bgt      | if(R[rs]>R[rt]) PC = Label  |
| Branch Less Than or Equal    | ble      | if(R[rs]<=R[rt]) PC = Label |
| Branch Greater Than or Equal | bge      | if(R[rs]>=R[rt]) PC = Label |
| Load Immediate               | li       | R[Rd] = immediate           |
| Move                         | move     | R[Rd] = R[rs]               |

## REGISTER NAME, NUMBER, USE, CALL CONVENTION

| NAME      | NUMBER | USE                                                   | PRESERVED ACROSS A CALL? |
|-----------|--------|-------------------------------------------------------|--------------------------|
| \$zero    | 0      | The Constant Value 0                                  | N.A.                     |
| \$at      | 1      | Assembler Temporary                                   | No                       |
| \$v0-\$v1 | 2-3    | Values for Function Results and Expression Evaluation | No                       |
| \$a0-\$a3 | 4-7    | Arguments                                             | No                       |
| \$t0-\$t7 | 8-15   | Temporaries                                           | No                       |
| \$s0-\$s7 | 16-23  | Saved Temporaries                                     | Yes                      |
| \$t8-\$t9 | 24-25  | Temporaries                                           | No                       |
| \$k0-\$k1 | 26-27  | Reserved for OS Kernel                                | No                       |
| \$gp      | 28     | Global Pointer                                        | Yes                      |
| \$sp      | 29     | Stack Pointer                                         | Yes                      |
| \$fp      | 30     | Frame Pointer                                         | Yes                      |
| \$ra      | 31     | Return Address                                        | Yes                      |

|        | EX Stage |        |       |     | MEM Stage |           |        | WB Stage  |           |
|--------|----------|--------|-------|-----|-----------|-----------|--------|-----------|-----------|
|        | RegDst   | ALUSrc | ALUOp |     | Mem Read  | Mem Write | Branch | MemTo Reg | Reg Write |
|        |          |        | op1   | op0 |           |           |        |           |           |
| R-type | 1        | 0      | 1     | 0   | 0         | 0         | 0      | 0         | 1         |
| lw     | 0        | 1      | 0     | 0   | 1         | 0         | 0      | 1         | 1         |
| sw     | X        | 1      | 0     | 0   | 0         | 1         | 0      | X         | 0         |
| beq    | X        | 0      | 0     | 1   | 0         | 0         | 1      | X         | 0         |

|        | Opcode<br>( Op[5:0] == Inst[31:26] ) |     |     |     |     |     | Value in<br>Hexadecimal |
|--------|--------------------------------------|-----|-----|-----|-----|-----|-------------------------|
|        | Op5                                  | Op4 | Op3 | Op2 | Op1 | Op0 |                         |
| R-type | 0                                    | 0   | 0   | 0   | 0   | 0   | 0                       |
| lw     | 1                                    | 0   | 0   | 0   | 1   | 1   | 23                      |
| sw     | 1                                    | 0   | 1   | 0   | 1   | 1   | 2B                      |
| beq    | 0                                    | 0   | 0   | 1   | 0   | 0   | 4                       |





Add





Load Word



Store Word

| Opcode | ALUop | Instruction Operation | Funct field | ALU action       | ALU control |
|--------|-------|-----------------------|-------------|------------------|-------------|
| lw     | 00    | load word             | xxxxxx      | add              | 0010        |
| sw     | 00    | store word            | xxxxxx      | add              | 0010        |
| beq    | 01    | branch equal          | xxxxxx      | subtract         | 0110        |
| R-type | 10    | add                   | 10 0000     | add              | 0010        |
| R-type | 10    | subtract              | 10 0010     | subtract         | 0110        |
| R-type | 10    | AND                   | 10 0100     | AND              | 0000        |
| R-type | 10    | OR                    | 10 0101     | OR               | 0001        |
| R-type | 10    | set on less than      | 10 1010     | set on less than | 0111        |

| ALUcontrol |         |           | Function |
|------------|---------|-----------|----------|
| Ainvert    | Binvert | Operation |          |
| 0          | 0       | 00        | AND      |
| 0          | 0       | 01        | OR       |
| 0          | 0       | 10        | add      |
| 0          | 1       | 10        | subtract |
| 0          | 1       | 11        | slt      |
| 1          | 1       | 00        | NOR      |



| Dependency | Solution | Inst | Stall | Dependency | Solution | Inst | Stall |
|------------|----------|------|-------|------------|----------|------|-------|
| Data       | None     | add  | 2     | Control    | Early    |      | 1     |
| Data       | None     | lw   | 2     | Control    | Early    | add  | 2     |
| Data       | Fwd      | add  | 0     | Control    | Early    | lw   | 3     |
| Data       | Fwd      | lw   | 1     | Control    | Predict  | YES  | 0     |
| Control    | None     | ALL  | 3     | Control    | Delay    |      | 0     |

# Boolean Algebra

|                                               |                                             |
|-----------------------------------------------|---------------------------------------------|
| <b>Identity laws</b>                          |                                             |
| $A + 0 = 0 + A = A$                           | $A \cdot 1 = 1 \cdot A = A$                 |
| <b>Inverse/complement laws</b>                |                                             |
| $A + A' = 1$                                  | $A \cdot A' = 0$                            |
| <b>Commutative laws</b>                       |                                             |
| $A + B = B + A$                               | $A \cdot B = B \cdot A$                     |
| <b>Associative laws *</b>                     |                                             |
| $A + (B + C) = (A + B) + C$                   | $A \cdot (B \cdot C) = (A \cdot B) \cdot C$ |
| <b>Distributive laws</b>                      |                                             |
| $A \cdot (B + C) = (A \cdot B) + (A \cdot C)$ | $A + (B \cdot C) = (A + B) \cdot (A + C)$   |

|                                                                 |                                                       |
|-----------------------------------------------------------------|-------------------------------------------------------|
| <b>Idempotency</b>                                              |                                                       |
| $X + X = X$                                                     | $X \cdot X = X$                                       |
| <b>One element / Zero element</b>                               |                                                       |
| $X + 1 = 1$                                                     | $X \cdot 0 = 0$                                       |
| <b>Involution</b>                                               |                                                       |
| $(X')' = X$                                                     |                                                       |
| <b>Absorption 1</b>                                             |                                                       |
| $X + X \cdot Y = X$                                             | $X \cdot (X + Y) = X$                                 |
| <b>Absorption 2</b>                                             |                                                       |
| $X + X' \cdot Y = X + Y$                                        | $X \cdot (X' + Y) = X \cdot Y$                        |
| <b>DeMorgans' (can be generalised to more than 2 variables)</b> |                                                       |
| $(X + Y)' = X' \cdot Y'$                                        | $(X \cdot Y)' = X' + Y'$                              |
| <b>Consensus</b>                                                |                                                       |
| $X \cdot Y + X' \cdot Z + Y \cdot Z = X \cdot Y + X' \cdot Z$   | $(X+Y) \cdot (X'+Z) \cdot (Y+Z) = (X+Y) \cdot (X'+Z)$ |

| x | y | Minterms      |          | Maxterms |          |
|---|---|---------------|----------|----------|----------|
|   |   | Term          | Notation | Term     | Notation |
| 0 | 0 | $x' \cdot y'$ | m0       | $x+y$    | M0       |
| 0 | 1 | $x' \cdot y$  | m1       | $x+y'$   | M1       |
| 1 | 0 | $x \cdot y'$  | m2       | $x'+y$   | M2       |
| 1 | 1 | $x \cdot y$   | m3       | $x'+y'$  | M3       |

**Duality:** If the AND/OR operators and 0/1 identity elements are interchanged, it remains valid  
 $x+1 = 1 \rightarrow x \cdot 0 = 0$

# Logic Circuits



Half Adder



| x | y | z | C | S |
|---|---|---|---|---|
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 1 | 0 | 1 |
| 0 | 1 | 0 | 0 | 1 |
| 0 | 1 | 1 | 1 | 0 |
| 1 | 0 | 0 | 0 | 1 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 1 | 0 |
| 1 | 1 | 1 | 1 | 1 |



|   | yz | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| x | 0  |    |    | 1  |    |
|   | 1  | 1  | 1  | 1  | 1  |

$C = xy + xz + yz$

|   | yz | 00 | 01 | 11 | 10 |
|---|----|----|----|----|----|
| x | 0  |    | 1  |    |    |
|   | 1  | 1  | 1  | 1  |    |

$S = x'y'z + x'yz' + xy'z' + xyz$



**Magnitude Comparator**

$A_3 \cdot B_3'$

$$\begin{aligned}
 & A_3 \cdot B_3' + x_3 \cdot A_2 \cdot B_2 \\
 & + x_3 \cdot x_2 \cdot A_1 \cdot B_1 \\
 & + x_3 \cdot x_2 \cdot x_1 \cdot A_0 \cdot B_0
 \end{aligned}$$

(A < B)

$$\begin{aligned}
 & A_3 \cdot B_3' + x_3 \cdot A_2 \cdot B_2' \\
 & + x_3 \cdot x_2 \cdot A_1 \cdot B_1' \\
 & + x_3 \cdot x_2 \cdot x_1 \cdot A_0 \cdot B_0'
 \end{aligned}$$

(A > B)

(A = B)

Let  $A = A_3A_2A_1A_0$ ,  $B = B_3B_2B_1B_0$ ;  $x_i = A_i \cdot B_i + A_i' \cdot B_i'$

$x_3 \cdot x_2 \cdot x_1 \cdot x_0$

## Functions using MSI

Demultiplexers are similar to a decoder (select) with enable (data)

Multiplexers are similar to a decoder (select) added with  $2^n$  input lines (input)

$$f(Q, X, P) = \sum m(0, 1, 4, 6, 7) = \prod M(2, 3, 5)$$



(a) Active-high decoder with OR gate.



(b) Active-low decoder with NAND gate.



(c) Active-high decoder with NOR gate.



(d) Active-low decoder with AND gate.

$$F(A, B, C) = \sum m(1, 3, 5, 6)$$

This method works because:

$$\begin{aligned} \text{Output} = & I_0 \cdot m_0 + I_1 \cdot m_1 + I_2 \cdot m_2 + I_3 \cdot m_3 \\ & + I_4 \cdot m_4 + I_5 \cdot m_5 + I_6 \cdot m_6 + I_7 \cdot m_7 \end{aligned}$$

Supplying '1' to  $I_1, I_3, I_5, I_6$ , and '0' to the rest:

$$\text{Output} = m_1 + m_3 + m_5 + m_6$$



## Sequential Logic

| $J$ | $K$ | $Q(t+1)$ | Comments  |
|-----|-----|----------|-----------|
| 0   | 0   | $Q(t)$   | No change |
| 0   | 1   | 0        | Reset     |
| 1   | 0   | 1        | Set       |
| 1   | 1   | $Q(t)'$  | Toggle    |

| $S$ | $R$ | $Q(t+1)$ | Comments      |
|-----|-----|----------|---------------|
| 0   | 0   | $Q(t)$   | No change     |
| 0   | 1   | 0        | Reset         |
| 1   | 0   | 1        | Set           |
| 1   | 1   | ?        | Unpredictable |

| $D$ | $Q(t+1)$ |       |
|-----|----------|-------|
| 0   | 0        | Reset |
| 1   | 1        | Set   |

| $Q$ | $Q^+$ | $J$ | $K$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   | X   |
| 0   | 1     | 1   | X   |
| 1   | 0     | X   | 1   |
| 1   | 1     | X   | 0   |

JK Flip-flop

| $T$ | $Q(t+1)$ |           |
|-----|----------|-----------|
| 0   | $Q(t)$   | No change |
| 1   | $Q(t)'$  | Toggle    |

| $Q$ | $Q^+$ | $S$ | $R$ |
|-----|-------|-----|-----|
| 0   | 0     | 0   | X   |
| 0   | 1     | 1   | 0   |
| 1   | 0     | 0   | 1   |
| 1   | 1     | X   | 0   |

SR Flip-flop

| $Q$ | $Q^+$ | $D$ |
|-----|-------|-----|
| 0   | 0     | 0   |
| 0   | 1     | 1   |
| 1   | 0     | 0   |
| 1   | 1     | 1   |

D Flip-flop

| $Q$ | $Q^+$ | $T$ |
|-----|-------|-----|
| 0   | 0     | 0   |
| 0   | 1     | 1   |
| 1   | 0     | 1   |
| 1   | 1     | 0   |

T Flip-flop

## Cache



Direct Mapped Cache





| Miss       | Description                      | Replacement Policy                          |
|------------|----------------------------------|---------------------------------------------|
| Compulsory | First access to a block          | Least Recently Used                         |
| Conflict   | Block has been replaced in cache | First in First Out                          |
| Capacity   | Cache cannot contain all blocks  | Random Replacement<br>Least Frequently Used |