New Designed Single Cycle Datapath: draw.io link
The project involved extending the processor to support six new instructions: brv, jmxor, nori, blezal, jalpc, and baln. This required modifications to the control logic, the addition of new multiplexers, and the inclusion of status register flags to handle the specific behaviors of these instructions.
brv: R-type instruction that branches to the address in register $rs if the overflow status flag (V) is set.
jmxor: R-type instruction that jumps to the address found in memory at the address calculated by XORing $rs and $rt, and stores the link address in register $31.
nori: I-type instruction that performs a NOR operation between the value in $rs and a zero-extended immediate, storing the result in $rt.
blezal: I-type instruction that branches to a PC-relative address if the value in $rs is less than or equal to zero, and stores the link address in register $25.
jalpc: I-type instruction that jumps to a PC-relative address and stores the link address in $rt.
baln: J-type instruction that branches to a pseudo-direct address if the negative status flag (N) is set, storing the link address in register $31.
The new design is built on the foundation of a single-cycle datapath. Components necessary for Zero extension and pseudo direct addressing have been added to accommodate the new instructions. Status registers have been implemented within the ALU based on the values of the previous instruction. Instructions that use PC-relative addressing are connected to pcsrc0 via an OR gate, while jump instructions are connected to pcsrc1 via another OR gate. Multiplexers have been expanded as needed to ensure the proper operation of all instructions in the design. By providing the function code as an input to the control unit, control signal adjustments have been configured for the new R-type instructions. Additionally, the bit width of the ALUop signal has been increased from 2 to 3 bits.
The parts used by the new instructions were determined according to their instruction formats.
The ALUop bit width was expanded to 3 bits. Accordingly, the signals coming from the ALU CONTROL were customized.
The signals coming from the control unit were customized according to the instructions. This made the implementation of the control unit easier.
Insturcion: 01094020 → add $8, $8,$9
Insturcion: 01000014 → brv $8
Insturcion: 01ce7020 → add $14, $14, $14
In this example, our first instruction, add $8, $8, $9, accounts for the condition where there is no overflow. So, the next instruction, which is brv, will not jump to the address in $8, which is 0x0000003C. The next instruction, add $14, $14, $14, causes an overflow. This overflow is written to the statusV register for use in the following instruction. When the brv instruction is encountered again, it will jump to the value in register $8. Therefore, our new PC will be 0x0000003C.
Insturcion: 014b0022 → jmxor $10, $11
The jmxor instruction jumps to the address obtained by applying the XOR operation to the values in registers $rs and $rt. The next address is stored in register $31.
For instance, consider the instruction 0x014B0021.
$rs is $10
$10: 0000 0000 0000 0000 0000 0000 0000 0010
$rt is $11
$11: 0000 0000 0000 0000 0000 0000 0000 1000
Performing the XOR operation:
$10 :0000 0000 0000 0000 0000 0000 0000 0010
$11 :0000 0000 0000 0000 0000 0000 0000 1000
XOR : 0000 0000 0000 0000 0000 0000 0000 1010 → 0x0000000A
Current PC: 0000 0000 0000 0000 0000 0000 0000 0100
PC + 4: 0000 0000 0000 0000 0000 0000 0000 1000 → 0x00000008 is stored in $31.
The program then jumps to 0x0000000A.
Instruction: 3dae894a → nori $14, $13, 0x894a
(001111 01101 011101 1001 1001 0100 1010)
The nori instruction applies the NOR operation to the data of the $rs register and the zero-extended label (0x894A), then writes the result to the $rt register.
For instance, let's consider the instruction with the hex code 0x3DAE894A.
Label: 0x894A
$13 (rs): 0x00000000
$14 (rt): (result destination register)
Performing the NOR operation:
Label: 0000 0000 0000 0000 1000 1001 0100 1010
$13 (rs): 0000 0000 0000 0000 0000 0000 0000 0000
NORI: 1111 1111 1111 1111 0111 0110 1011 0101 → 0xFFFF76B5
So, 0xFFFF76B5 is stored in $14 (rt).
Instruction: 7c0f0002 → jalpc $15, 0x0002
The Jalpc instruction jumps to a PC-relative address (BTA) and links the address to $rt.
For instance, let's consider the instruction with the hex code 0x7C0F0002.
0x0002 is our target address.
Target : 0000 0000 0000 0000 0000 0000 0000 0010
To go to PC-related address we must shift by two the target and add to the PC+4
PC+4 : 0000 0000 0000 0000 0000 0000 0000 0100
Target *4 : 0000 0000 0000 0000 0000 0000 0000 1000
Total : 0000 0000 0000 0000 0000 0000 0000 1100
After determining the destination address we go there by adding 4:
Next PC: 0000 0000 0000 0000 0000 0000 0001 0000 → 0x00000010
And the previous address is stored in $rt register which in our case it’s $15 register and it’s content is
PC+4: 0000 0000 0000 0000 0000 0000 0000 1000 → 0x00000008
Instruction: 0x91c00004 → blezal $14, 0x0004
Instruction: 0x91400004 → blezal $10, 0x0004
Instruction: 0x91800004 → blezal $12, 0x0004
Blezal instruction checks if R[rs] is smaller or equal to 0 if it is it jumps to do PC-relative address. The link address is stored $25 register.
For instance,
Let's consider the instruction with the hex code 0x91C00004.
$14 (rs): 1000 0000 0000 0000 0000 0000 0000 → negative so instruction will jump to new address
LABEL: 0000 0000 0000 0000 0000 0000 0100
PC+4 : 0000 0000 0000 0000 0000 0000 1000 → 0x00000008 stored in $25 register
LABEL x 4: 0000 0000 0000 0000 0000 0001 0000
New PC : 0000 0000 0000 0000 0000 0001 1000 → 0x00000018
Let's consider the instruction with the hex code 0x91400004.
$10 (rs) : 0000 0000 0000 0000 0000 0000 0002 → positive so instruction will not jump to new address
LABEL : 0000 0000 0000 0000 0000 0000 0100
PC+4 : 0000 0000 0000 0000 0000 0000 1000 → 0x00000008 (nothing change)
Let's consider the instruction with the hex code 0x91800004.
$12 (rs): 0000 0000 0000 0000 0000 0000 0000 → zero so instruction will jump to new address
LABEL: 0000 0000 0000 0000 0000 0000 0100
PC+4 : 0000 0000 0000 0000 0000 0000 1000 → 0x00000008 stored in $25 register
LABEL x 4: 0000 0000 0000 0000 0000 0001 0000
New PC : 0000 0000 0000 0000 0000 0001 1000 → 0x00000018
First Instruction: 01c07020 → add $14, $14, $0
Second Instruction: 6c000005 → baln 0x000005
The "baln" instruction functions similarly to the "jal" instruction but with a condition. If the status flag [N] is set to 1, indicating a negative result from a previous operation, the program branches to a pseudo-direct address, similar to how "jal" operates. Additionally, the address of the instruction following the branch is stored in register 31.
The first instruction is add $14, $14, $0
Register $14 contains a value of 0x80000000, which is a negative value. Since $0 is a zero register with a value of 0, the result will indeed be negative.
The program then branches to a pseudo-direct address calculated by concatenating the PC incremented by 4 and the extended label, resulting in a new PC value:
PC+4 : 0000 0000 0000 0000 0000 0000 1000 → first 4 bit ⇒ 0000
(0x00000008 stored in $31 register)
Label : 0000 0000 0000 0000 0101
Extended label: 0000 0000 0000 0000 0101 00
New PC : 0000 0000 0000 0000 0001 0100 → 000014
### BRV | ### JMXOR | ### NORI | ### BLEZAL | ### JALPC | ### BALN |
---|---|---|---|---|---|
@000000000001094020 0100001401ce7020 01000014 |
@0000000000``014b0022 | @0000000000``3dae894a | @000000000091C00004 91400004``91800004 |
@0000000000``7c0f0002 | @000000000001c07020 6c000005 |
**