# $\begin{array}{c} \mathrm{CS}\ 61\mathrm{C} \\ \mathrm{Spring}\ 2023 \end{array}$ ## CALL, Boolean Algebra Discussion 5 ### 1 Pre-Check | This section is designed as a conceptual check for you to determine if you conceptually | |-----------------------------------------------------------------------------------------| | understand and have any misconceptions about this topic. Please answer true/false | | to the following questions, and include an explanation: | - 1.1 The compiler may output pseudoinstructions. - 1.2 The main job of the assembler is to generate optimized machine code. - 1.3 The object files produced by the assembler are only moved, not edited, by the linker. - 1.4 The destination of all jump instructions is completely determined after linking. #### 2 Translation $\fbox{2.1}$ In this question, we will be translating between RISC-V code and binary/hexadecimal values. Translate the following Risc-V instructions into binary and hexadecimal notations - 1 addi s1 x0 -24 = 0b\_\_\_\_\_ = 0x\_\_\_\_\_ 2 sh s1 4(t1) = 0b\_\_\_\_\_ = 0x\_\_\_\_\_ - 2.2 In this question, we will be translating between RISC-V code and binary/hexadecimal values. Translate the following hexadecimal values into the relevant RISC-V instruction. - 1 0x234554B7 = \_\_\_\_\_ - 2 0xFE050CE3 = \_\_\_\_\_ #### 3 RISC-V Addressing We have several addressing modes to access memory (immediate not listed): - 1. Base displacement addressing adds an immediate to a register value to create a data memory address (used for lw, lb, sw, sb). - 2. PC-relative addressing uses the PC and adds the immediate value of the instruction (multiplied by 2) to create an instruction address (used by branch and jump instructions). - 3. Register Addressing uses the value in a register as an instruction address. For instance, jalr, jr, and ret, where jr and ret are just pseudoinstructions that get converted to jalr. - 3.1 What is the range of 32-bit instructions that can be reached from the current PC using a branch instruction? Recall that RISC-V supports 16b instructions via an extension. - 3.2 What is the maximum range of 32-bit instructions that can be reached from the current PC using a jump instruction? - 3.3 Given the following RISC-V code (and instruction addresses), fill in the blank fields for the following instructions (you'll need your RISC-V reference sheet!). Each field refers to a different block of the instruction encoding. | 1 | 0x002cff00: loop: | add t1, t2, t0 | 0x33 | |---|-------------------|--------------------|------| | 2 | 0x002cff04: | jal ra, foo | 0x6F | | 3 | 0x002cff08: | bne t1, zero, loop | 0x63 | | 4 | | | | | 5 | 0x002cff2c: foo: | jr ra | ra = | ### 4 CALL The following is a diagram of the CALL stack detailing how C programs are built and executed by machines. - [4.1] How many passes through the code does the Assembler have to make? Why? - [4.2] Which step in CALL resolves relative addressing? Absolute addressing? - 4.3 Describe the six main parts of the object files outputted by the Assembler (Header, Text, Data, Relocation Table, Symbol Table, Debugging Information). ### 5 Boolean Logic In digital electronics, it is often important to get certain outputs based on your inputs, as laid out by a truth table. Truth tables map directly to Boolean expressions, and Boolean expressions map directly to logic gates. However, in order to minimize the number of logic gates needed to implement a circuit, it is often useful to simplify long Boolean expressions. We can simplify expressions using the nine key laws of Boolean algebra: | Name | AND Form | OR form | |--------------|-----------------------------------------------|-----------------------------------------------| | Commutative | AB = BA | A + B = B + A | | Associative | AB(C) = A(BC) | A + (B + C) = (A + B) + C | | Identity | 1A = A | 0 + A = A | | Null | 0A = 0 | 1 + A = 1 | | Absorption | A(A + B) = A | A + AB = A | | Distributive | (A + B)(A + C) = A + BC | A(B + C) = AB + AC | | Idempotent | A(A) = A | A + A = A | | Inverse | $A(\overline{A}) = 0$ | $A + \overline{A} = 1$ | | De Morgan's | $\overline{AB} = \overline{A} + \overline{B}$ | $\overline{A+B} = \overline{A}(\overline{B})$ | [5.1] Simplify the following Boolean expressions: (a) $$(A+B)(A+\overline{B})C$$ (b) $$\bar{A}\bar{B}\bar{C} + \bar{A}B\bar{C} + AB\bar{C} + A\bar{B}\bar{C} + ABC + A\bar{B}C$$ (c) $$\overline{A(\bar{B}\bar{C} + BC)}$$ (d) $$\overline{A}(A+B) + (B+AA)(A+\overline{B})$$ 5.3 Prove that De Morgan's law can be generalized for the complement of any number of terms. | | Instruction Name Description Type Opcode Funct3 F | | | | | | | Fun et7 | | | | | |------------|---------------------------------------------------|-----|-------|--------|------------------------------------------|-----------------------------------------------------------------------------------------|-------|----------|------|-----|-----|------| | | | | | | ADD | · | | <u> </u> | | | | | | | add | | rs1 | | | rd = rs1 + rs2 | R | | 0011 | | | 0000 | | | sub | | rs1 | | SUBtract | rd = rs1 - rs2 | R | | 0011 | | | 0000 | | | and | | rs1 | | bitwise AND | rd = rs1 & rs2 | R | | 0011 | | | 0000 | | | or | | rs1 | | bitwise OR | rd = rs1 rs2 | R | | 0011 | | | 0000 | | | xor | | rs1 | | bitwise XOR | rd = rs1 ^ rs2 | R | | 0011 | | | 0000 | | | sll | | rs1 | | Shift Left Logical | rd = rs1 << rs2 | R | | 0011 | | | 0000 | | | srl | | rs1 | | Shift Right Logical | rd = rs1 >> rs2 (Zero-extend) | R | | 0011 | | | 0000 | | | sra | | rs1 | | | rd = rs1 >> rs2 (Sign-extend) | R | | 0011 | | | 0000 | | | slt | rd | rs1 | rs2 | Set Less Than (signed) | rd = (rs1 < rs2) ? 1 : 0 | R<br> | 011 | 0011 | 010 | 000 | 0000 | | | sltu | rd | rs1 | rs2 | Set Less Than (Unsigned) | | R | 011 | 0011 | 011 | 000 | 0000 | | ပ | addi | rd | rs1 | imm | ADD Immediate | rd = rs1 + imm | I | 001 | 0011 | 000 | | | | Arithmetic | andi | rd | rs1 | imm | bitwise AND<br>Immediate | rd = rs1 & imm | I | 001 | 0011 | 111 | | | | Ari | ori | rd | rs1 | imm | bitwise OR<br>Immediate | rd = rs1 imm | I | 001 | 0011 | 110 | | | | | xori | rd | rs1 | imm | bitwise XOR<br>Immediate | rd = rs1 ^ imm | I | 001 | 0011 | 100 | | | | | slli | rd | rs1 | imm | Shift Left Logical<br>Immediate | rd = rs1 << imm | * | 001 | 0011 | 001 | 000 | 0000 | | | srli | rd | rs1 | imm | Shift Right Logical<br>Immediate | rd = rs1 >> imm (Zero-extend) | * | 001 | 0011 | 101 | 000 | 0000 | | | srai | rd | rs1 | imm | Shift Right Arithmetic<br>Immediate | rd = rs1 >> imm (Sign-extend) | l* | 001 | 0011 | 101 | 010 | 0000 | | | slti | rd | rs1 | imm | Set Less Than<br>Immediate (signed) | rd = (rs1 < imm) ? 1 : 0 | I | 001 | 0011 | 010 | | | | | sltiu | rd | rs1 | imm | Set Less Than<br>Immediate<br>(Unsigned) | | I | 001 | 0011 | 011 | | | | | 1b | rd | imm | (rs1) | Load Byte | rd = 1 byte of memory at address rs1 + imm, sign-extended | I | 000 | 0011 | 000 | | | | | lbu | rd | imm | (rs1) | Load Byte<br>(Unsigned) | rd = 1 byte of memory at address<br>rs1 + imm, zero-extended | I | 000 | 0011 | 100 | | | | | lh | rd | imm | (rs1) | Load Half-word | rd = 2 bytes of memory starting at address rs1 + imm, sign-extended | I | 000 | 0011 | 001 | | | | 2 | lhu | rd | imm | (rs1) | Load Half-word<br>(Unsigned) | rd = 2 bytes of memory starting at address rs1 + imm, zero-extended | I | 000 | 0011 | 101 | | | | Memory | lw | rd | imm | (rs1) | Load Word | rd = 4 bytes of memory starting at address rs1 + imm | I | 000 | 0011 | 010 | | | | _ | sb | rs2 | 2 imn | n(rs1) | Store Byte | Stores least-significant byte of rs2 at the address rs1 + imm in memory | S | 010 | 0011 | 000 | | | | | sh | rs2 | 2 imn | n(rs1) | Store Half-word | Stores the 2 least-significant bytes of rs2 starting at the address rs1 + imm in memory | S | 010 | 0011 | 001 | | | | | sw | rs2 | 2 imn | n(rs1) | Store Word | Stores rs2 starting at the address rs1 + imm in memory | S | 010 | 0011 | 010 | | | | | Instruction | | Name | Description | Туре | Opcode | Funct3 | |---------|----------------|---------------|---------------------------------------|-----------------------------------------------------------------------------------------------------|------|-----------|--------| | | beq | rs1 rs2 label | Branch if EQual | <pre>if (rs1 == rs2) PC = PC + offset if (rs1 &gt;= rs2) PC = PC + offset if (rs1 &lt; rs2)</pre> | | 110 0011 | 000 | | | bge | rs1 rs2 label | Branch if Greater or Equal (signed) | | | 110 0011 | 101 | | | bgeu | rs1 rs2 label | Branch if Greater or Equal (Unsigned) | | | 110 0011 | 111 | | _ | blt | rs1 rs2 label | Branch if Less Than (signed) | | | 110 0011 | 100 | | Control | bltu | rs1 rs2 label | Branch if Less Than (Unsigned) | PC = PC + offset | В | 110 0011 | 110 | | ပိ | bne | rs1 rs2 label | Branch if Not Equal | if (rs1 != rs2)<br>PC = PC + offset | | 110 0011 | 001 | | | jal rd label | | Jump And Link | rd = PC + 4<br>PC = PC + offset | J | 110 1111 | | | | jalr | rd rs1 imm | Jump And Link Register | rd = PC + 4<br>PC = rs1 + imm | I | 110 0111 | 000 | | | auipc | rd imm | Add Upper Immediate to PC | rd = PC + (imm << 12) | | 001 0111 | | | | lui | rd imm | Load Upper Immediate | rd = imm << 12 | U | 011 0111 | | | Other | ebreak | • | Environment BREAK | Asks the debugger to do something (imm = 0) | I | 111 0011 | 000 | | | ecall | | Environment CALL | Asks the OS to do something (imm = 1) | I | 111 0011 | 000 | | Ext | mul rd rs1 rs2 | | MULtiply (part of mul ISA extension) | rd = rs1 * rs2 | | (omitted) | | | # | Name | Description # Name | | Desc | | | | |--------------------------------------------|------------|----------------------------------|-------------|------------|-----------------|--|--| | <b>x</b> 0 | zero | Constant 0 x16 a6 | | Args | | | | | <b>x</b> 1 | ra | Return<br>Address | * * * * | | | | | | <b>x</b> 2 | sp | Stack<br>Pointer | s2 | | | | | | <b>x</b> 3 | др | Global<br>Pointer | x19 | s3 | | | | | x4 | tp | Thread<br>Pointer | <b>x</b> 20 | s4 | ers | | | | <b>x</b> 5 | t0 | _ | x21 | <b>s</b> 5 | gist | | | | <b>x</b> 6 | t1 | Temporary<br>Registers | x22 | s6 | Re | | | | <b>x</b> 7 | t2 | registers | <b>x</b> 23 | s7 | Saved Registers | | | | <b>x</b> 8 | s0 | Saved | x24 | s8 | Sa | | | | <b>x</b> 9 | s1 | Registers | <b>x</b> 25 | s9 | | | | | <b>x10</b> | <b>a</b> 0 | Function | x26 | s10 | | | | | ×11 | a1 | Arguments<br>or Return<br>Values | <b>x</b> 27 | s11 | | | | | <b>x12</b> | a2 | | x28 | t3 | es | | | | <b>x</b> 13 | <b>a</b> 3 | Function | x29 | t4 | orari | | | | x14 | a4 | Arguments | <b>x</b> 30 | t5 | Temporaries | | | | <b>x</b> 15 | <b>a</b> 5 | | x31 | t6 | 7e | | | | Caller saved registers | | | | | | | | | Callee saved registers (except x0, gp, tp) | | | | | | | | | Pseudoinstruction | tion Name Description | | Translation | |-------------------|------------------------------|-----------------------------------|-----------------------| | beqz rs1 label | Branch if<br>EQuals Zero | if (rs1 == 0)<br>PC = PC + offset | beq rs1 x0 label | | bnez rs1 label | Branch if Not<br>Equals Zero | if (rs1 != 0)<br>PC = PC + offset | bne rs1 x0 label | | j label | Jump | PC = PC + offset | jal x0 label | | jr rs1 | Jump Register | PC = rs1 | jalr x0 rs1 0 | | la rd label | Load absolute<br>Address | rd = &label | auipc, addi | | li rd imm | Load Immediate | rd = imm | lui (if needed), addi | | mv rd rs1 | MoVe | rd = rs1 | addi rd rs1 0 | | neg rd rs1 | NEGate | rd = -rs1 | sub rd x0 rs1 | | nop | No OPeration | do nothing | addi x0 x0 0 | | not rd rs1 | bitwise NOT | rd = ~rs1 | xori rd rs1 -1 | | ret | RETurn | PC = ra | jalr x0 x1 0 | | 31 2 | 5 24 20 1 | 0 15 14 12 11 | 7.6 0 | | 3 | 1 25 | 24 20 | 19 15 | 14 12 | 11 7 | 6 0 | |----|--------------|----------|-------|--------|-------------|--------| | R | funct7 | rs2 | rs1 | funct3 | rd | opcode | | I | imm[11 | :0] | rs1 | funct3 | rd | opcode | | l* | funct7 | imm[4:0] | rs1 | funct3 | rd | opcode | | S | imm[11:5] | rs2 | rs1 | funct3 | imm[4:0] | opcode | | В | imm[12 10:5] | rs2 | rs1 | funct3 | imm[4:1 11] | opcode | | U | | imm[31:1 | 2] | | rd | opcode | | J | im | 19:12] | | rd | opcode | | Immediates are sign-extended to 32 bits, except in I\* type instructions and sltiu.