## CprE 381: Computer Organization and Assembly-Level Programming

## **Project Part 1 Report**

Team Members: Jayson Acosta, Parnika Dasgupta, Nakota Clark

Project Teams Group #: Section **D\_01** 

Refer to the highlighted language in the project 1 instruction for the context of the following questions.

[Part 1 (d)] Include your final MIPS processor schematic in your lab report.



[Part 2 (a.i)] Create a spreadsheet detailing the list of *M* instructions to be supported in your project alongside their binary opcodes and funct fields, if applicable. Create a separate column for each binary bit. Inside this spreadsheet, create a new column for the *N* control signals needed by your datapath implementation. The end result should be an *N\*M* table where each row corresponds to the output of the control logic module for a given instruction.

| Instruction               | Opcode | Func | ţ      | RegDst | Jump | Branch | MemRead | MemtoReg | ALUOp | MemWrite | ALUSTO | RegWrite |
|---------------------------|--------|------|--------|--------|------|--------|---------|----------|-------|----------|--------|----------|
| add                       | 0      |      | 100000 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| addi                      | 1000   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| addiu                     | 1001   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| addu                      | 0      |      | 100001 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| and                       | 0      |      | 100100 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| andi                      | 1100   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| beg                       | 100    | N/A  |        | X      | 0    | 1      | 0       | X        | 1     | 0        | 0      | 0        |
| bne                       | 101    | N/A  |        | X      | 0    | 1      | 0       | X        | 1     | 0        | 0      | 0        |
| j                         | 10     | N/A  |        | X      | 1    | 0      | 0       | X        | XX    | 0        | X      | 0        |
| jal                       | 11     | N/A  |        | X      | 1    | 0      | 0       | X        | XX    | 0        | X      | 1        |
| jr                        | 0      |      | 1000   | X      | 1    | 0      | 0       | X        | XX    | 0        | X      | 0        |
| أييا                      | 1111   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| lw.                       | 100011 | N/A  |        | 0      | 0    | 0      | 1       | 1        | 0     | 0        | 1      | 1        |
| nor                       | 0      |      | 100111 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| or                        | 0      |      | 100101 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| ori                       | 1101   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| şlţ                       | 0      |      | 101010 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| oci<br>slti<br>sll<br>scl | 1010   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |
| şij                       | 0      |      | 0      | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| şrl                       | 0      |      | 10     | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| sra                       | 0      |      | 11     | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| <u>sw</u>                 | 101011 | N/A  |        | X      | 0    | 0      | 0       | X        | 0     | 1        | 1      | 0        |
| sub                       | 0      |      | 100010 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| subu                      | 0      |      | 100011 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| xor                       | 0      |      | 100110 | 1      | 0    | 0      | 0       | 0        | 10    | 0        | 0      | 1        |
| xori                      | 1110   | N/A  |        | 0      | 0    | 0      | 0       | 0        | 0     | 0        | 1      | 1        |

[Part 2 (a.ii)] Implement the control logic module using whatever method and coding style you prefer. Create a testbench to test this module individually, and show that your output matches the expected control signals from problem 1(a).

| <b>1 1 1 1 1 1 1 1 1 1</b>         | Msgs   |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
|------------------------------------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| → /tb_control_logic/s_opcode       | 000000 | 000000 |        | 000010 | 000011 | 000100 | 000101 | 001000 | 001001 | 001100 | 001101 | 001111 | 010100 | 100011 | 101011 |
| <u>→</u> /tb_control_logic/s_funct | 000001 | 000001 | 001000 | 000001 |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_Jump           | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_RegDst         | 1      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_branch         | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_memRead        | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_MemTo          | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_MemWrite       | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_ALUSrc         | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_RegWrite       | 1      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| /tb_control_logic/s_Halt           | 0      |        |        |        |        |        |        |        |        |        |        |        |        |        |        |
| ■-  /tb control logic/s_ALUOp      | 10     | 10     |        | 100    |        | 01     |        | 00     |        | 11     |        |        | 00     |        |        |
|                                    |        |        |        |        |        |        |        |        |        |        |        |        |        |        |        |

This testbench output shows that the control logic module is operating exactly as it should be based on our expected control signals. The test bench iterates through each of the opcodes anb functions. The output for all of these test cases match what they should be.

[Part 2 (b.i)] What are the control flow possibilities that your instruction fetch logic must support? Describe these possibilities as a function of the different control flow-related instructions you are required to implement.

Our fetch logic supports the following control flow possibilities:

- Sequential execution: PC = PC + 4
- Branch instructions (beq, bne): PC = PC + 4 + (sign-extended immediate <<</li>
   2)
- Jump instructions (j, jal): PC = (PC + 4)[31:28] concatenated with (address << 2)
- Jump Register (jr): PC = register value
- These correspond to the MIPS branch (beq, bne), jump (j, jal), and jump register (jr) instructions.

[Part 2 (b.ii)] Draw a schematic for the instruction fetch logic and any other datapath modifications needed for control flow instructions. What additional control signals are needed?

We needed to add a reset signal to set the PC register to the proper initial value. We also needed to add signals to handle Jump Return logic. We added a Jump Return enable and a Jump Return Address.



[Part 2 (b.iii)] Implement your new instruction fetch logic using VHDL. Use Modelsim to test your design thoroughly to make sure it is working as expected. Describe how the execution of the control flow possibilities corresponds to the Modelsim waveforms in your writeup.

| /tb_fetch_logic/s_clk /tb_fetch_logic/s_rst | 1        |          |          |          |          |          |          |          |          |          |  |
|---------------------------------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|--|
| /tb_fetch_logic/s_branch_en                 | 0        |          |          |          |          |          |          |          |          |          |  |
| /tb_fetch_logic/s_jump_en                   | 0        |          |          |          |          |          |          |          |          |          |  |
| /tb_fetch_logic/s_jr_en                     | 1        |          |          |          |          |          |          |          |          |          |  |
|                                             | 00001000 | 00000000 |          |          | 00001000 |          |          |          |          |          |  |
|                                             | 00400008 | 00400000 | 00400004 | 00400008 |          | 0040100C |          | 0F800000 |          | 00400008 |  |
|                                             | 00400008 | 00000000 |          |          | 00400008 |          |          |          |          |          |  |
| ■ /tb_fetch_logic/s_next_inst_addr          | 00400008 | 00400004 | 00400008 | 0040000C | 0040100C | 00402010 | 0F800000 |          | 00400008 |          |  |
| _ tb_fetch_logic/s_jump_addr                | 3E00000  | 0000000  |          |          | 3E00000  |          |          |          |          |          |  |

[Part 2 (c.i.1)] Describe the difference between logical (srl) and arithmetic (sra) shifts. Why does MIPS not have a sla instruction?

The difference between srl and sra is how it decides whether to shift in 1's or 0's. Logical shifts don't care about the numerical value, and so it shifts all the bits and place 0's in the new bits. Arithmetic shifts treat the values as numbers, and look at the sign bit to decide whether to shift in 0's or 1's. Sla does not exist because shifting to the left shifts in values to the least significant bits. Looking at the sign bit to decide which value to shift into these bits will not preserve the numerical value, and instead will make the number entirely different than expected. This means you should always shift in 0's, so sla would be the same as sll, and would be redundant to add separately.

Example of sla being incorrect:

```
-1 -4
sll 0b1111, 2 => 0b1100
-1 -1
sla 0b1111,2 => 0b1111
```

[Part 2 (c.i.2)] In your writeup, briefly describe how your VHDL code implements both the arithmetic and logical shifting operations.

My code implements both arithmetic and logical operations by using a control signal and if/elsif statements. The control bit is Logic\_Arith; 0 means logical and 1 means arithmetic. This value decides which branch of the if/elsif to take. For logical shifts, I shift the data and treat it as an unsigned number, so that it shifts in 0's. Arithmetic treats the data as a signed number, so it will shift in 0's or 1's depending on the sign bit.

[Part 2 (c.i.3)] In your writeup, explain how the right barrel shifter above can be enhanced to also support left shifting operations.

In order to support left shift operations, I will just add a new control signal Right\_Left, and this will decide whether to do a left or right shift. I will concatenate this bit with the Logic\_Arith bit and use that combined signal as the control for the if/elsif. If the Right\_Left bit is 1, it doesn't matter what the Logic\_Arith bit is. I'll only need to add 1 more branch to shift the data to the left.

[Part 2 (c.i.4)] Describe how the execution of the different shifting operations corresponds to the Modelsim waveforms in your writeup.

| ♦ /tb_shifter/s_Right_Left 0 |                                         |                                         |                                         |
|------------------------------|-----------------------------------------|-----------------------------------------|-----------------------------------------|
| /tb_shifter/s_Logic_Arith 0  |                                         |                                         |                                         |
| •                            | 00011                                   | 00010                                   | (11111                                  |
| ★- /tb_shifter/s_i_D         |                                         |                                         |                                         |
|                              | 000000000000000000000000000000000000000 | 000000000000000000000000000000000000000 | 0 (100000000000000000000000000000000000 |

This image shows the shifter working properly for basic cases. I kept the input the same for all of them to make it easier for me to compare the results. The data in was always 0b0000000000000000000000001111. The first operation was a srl operation with a shamt of 1. The result matches the expected result of

0b00000000000000000000000000111. The second was a sra operation with a shamt of 3. It gave the expected result of 0b00000000000000000000000000000001. Then came a sll with a shamt of 2. It gave the expected result of

0b000000000000000000000000111100. Finally there is a sll with a shamt of 31. It gave the expected result of 0b1000000000000000000000000000000. This shows that the operations are working as expected.

[Part 2 (c.ii.1)] In your writeup, briefly describe your design approach, including any resources you used to choose or implement the design. Include at least one design decision you had to make.

We didn't really have to design any other components to complete the ALU. We primarily used Behavioral instead of Structural. One component we did create was a separate ALU Controller to handle the logic that controls the ALU's output. This component was made to offload some of the control logic from the Control Logic module. This was done to simplify the code to prevent potential issues.

## [Part 2 (c.ii.2)] Describe how the execution of the different operations corresponds to the Modelsim waveforms in your writeup.

| /to_auu_ci | ontrovs_ALUOP         | 10        | ( 00   |         | ŢUL      |        | Į 10   |        |        |        |        |        |        |        |        |        |
|------------|-----------------------|-----------|--------|---------|----------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
|            | ontrol/s_InstOp       | 000101    | 00001  | 0       | 000100   | 000101 |        |        |        |        |        |        |        |        |        |        |
|            |                       | 000010    | (00000 | 1       | 1 000100 |        | 100000 | 100001 | 100100 | 100101 | 1001   | .0     |        | 100111 | 101010 | 000000 |
|            |                       | 1001      | 0010   |         | 0110     | 1110   | 0010   |        | 1 0000 | 1 0001 | 1 0011 |        |        | 0100   | 0111   | 1000   |
|            |                       |           |        |         |          |        |        |        |        |        |        |        |        |        |        |        |
|            |                       |           |        |         |          |        |        |        |        |        |        |        |        |        |        |        |
| <u> </u>   |                       |           | Msgs   |         |          |        |        |        |        |        |        |        |        |        |        |        |
|            | /tb_alu_control/s_AL  | UOp 10    | )      | 10      |          |        |        |        | 111    |        |        |        |        |        |        |        |
|            | /tb_alu_control/s_Ins |           | 00101  | 000101  |          |        |        |        | 001000 | 001001 | 001010 | 001100 | 001101 | 001110 | 001111 |        |
|            | /tb_alu_control/s_fun |           | 00010  | 0000000 | 000010   | 000011 | 100010 | 100011 | 000010 |        |        |        |        |        |        |        |
|            | /tb_alu_control/s_AL  | U_Oper 10 |        | 1000    | 1001     | 1010   | 0110   |        | 0010   |        | 0111   | 10000  | 0001   | 0011   | 1100   |        |
|            |                       |           |        |         |          |        |        |        |        |        |        |        |        |        |        |        |
|            |                       |           |        |         |          |        |        |        |        |        |        | _      |        |        |        |        |

When executing instructions, we needed a way to tell what instruction type we were going to use. For this problem, we created alu\_control.vhd. This file took in 3 parameters, i\_ALUOp (from the main control), i\_Funct (from instruction function field) and i\_InstOp. ALUOp would be 00 for memory references or immediate instructions, 01 when it is a branch instruction, 10 when it is a R-type instruction and 11 when it is an immediate instruction. From this it would assign o\_ALU\_Operation with the appropriate instruction based on the instruction type and function code / op code for the instructions based on i\_Funct (R-type) or i\_InstOp (I-type and Branch)

[Part 2 (c.iii)] Draw a simplified, high-level schematic for the 32-bit ALU. Consider the following questions: how is Overflow calculated? How is Zero calculated? How is Slt implemented?



Overflow is handled with a case statement that takes the most significant bit of the 2 inputs and the output. These 3 bits are concatenated together in a signal called s\_overflow\_detect. If the operation is addition if the signal is 001 or 110 then overflow occurred. If the operation is subtraction and the signal is 011 or 100 then overflow happened. Zero is calculated using a case statement as well. If the ALUOP is for beq and the result is 0, then Zero becomes 1. Otherwise it is zero. If the ALUOP for bne then if the result != 0, then Zero becomes 1. Slt is implemented using dataflow and simply uses < to compare the inputs and if it is true it outputs 1, otherwise it outputs 0.

[Part 2 (c.v)] Describe how the execution of the different operations corresponds to the Modelsim waveforms in your writeup.

| +·· /tb_alu/s_i_A   | 11111111 | 11111111 |          |          |          |          |          |          |          |          |          |          |
|---------------------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| + /tb_alu/s_i_B     | 11112222 | 11112222 |          |          |          |          |          |          | 11111110 | 11112222 |          |          |
| + /tb_alu/s_o_F     | 11113333 | 11110000 | 11113333 | 22223333 | 00003333 | EEEECCCC | FFFFEEEF | 00000001 | 00000000 | 11122220 | 01111222 | 22220000 |
| + /tb_alu/s_ALUOp   | 0001     | 0000     | 0001     | 0010     | 0011     | 0100     | 0110     | 0111     |          | 1000     | 1010     | 1100     |
| + /tb_alu/s_i_shamt | 00100    | 00100    |          |          |          |          |          |          |          |          |          |          |
| /tb_alu/s_o_Zero    | 0        |          |          |          |          |          |          |          |          |          |          |          |
| /tb alu/o Overflow  | 0        |          |          |          |          |          |          |          |          |          |          |          |
| <u> </u>            |          |          |          |          |          |          |          |          |          |          |          |          |

This was the output from a basic testbench that was made to simply ensure that the basic functionality worked properly. The testbench iterates through each of the basic ALU functions so we can verify the right operation happens. First the ALUOP is 0000 which is AND. inputs were 0x11111111 and 0x11112222. The output was 0x11110000. This is correct. Another example is Subtraction. The ALUOP is 0110. The inputs were 0x11111111 and 0x11112222. The output was 0xFFFFEEEF wich is also correct. This testbench was just to test basic functionality. We planned to do the real testing once it was integrated into the processor.

[Part 2 (c.viii)] justify why your test plan is comprehensive. Include waveforms that demonstrate your test programs functioning.

Our test plan is comprehensive due to the amount of different operations and combinations in it. We received a lot of tests from the professor. There are a ton of unit tests for each of the components in the processor. There are also some mixed tests, such as one that does the Fibonacci sequence. We will also create our own extensive tests to verify each of our functions.

[Part 3] In your writeup, show the Modelsim output for each of the following tests, and provide a discussion of result correctness. It may be helpful to also annotate the waveforms directly.

[Part 3 (a)] Create a test application that makes use of every required arithmetic/logical instruction at least once. The application need not perform any particularly useful task, but it should demonstrate the full functionality of the processor (e.g., sequences of many instructions executed sequentially, 1 per cycle while data written into registers can be effectively retrieved and used by later instructions). Name this file Proj1\_base\_test.s.



This waveform demonstrates our processor successfully completing our test program for all of the requiired arithmetic/logical operations. This is a waveform of the ALU in poarticular, because it handles all of these instructions, so it can tell you if it is working properly without having all of the other signals to sift through. All of the tests completed successfully, but i'll give some examples.



This image shows that addition is working, as 2+2=4 as the output demonstrates.



This image shows and ANDI operations completing successfully. it got 0xFFFFFE0 from a register and 0x0000100 is the immediate from the instructions. The result of 0x00000100 is the correct output.

[Part 3 (b)] Create and test an application which uses each of the required control-flow instructions and has a call depth of at least 5 (i.e., the number of activation records on the stack is at least 4). Name this file Proj1\_cf\_test.s.



This waveform demonstrates the branch and jump instructions operate properly and the PC is properly updated. The value for PC after each of the instructions match the expected results for each of the cases.

[Part 3 (c)] Create and test an application that sorts an array with *N* elements using the BubbleSort algorithm (link). Name this file Proj1\_bubblesort.s.

| <b>■</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 32'h00000000 | 0             | 00000  | 000000 | 000 | 000000 | 01  | 000000 | 00   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---------------|--------|--------|-----|--------|-----|--------|------|
| /tb/MyMips/s_DMemWr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0            |               |        |        |     |        |     |        |      |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 32'h00000000 |               | 00000  |        | 000 | 000000 | 01  | 000000 |      |
| ★ ◆ /tb/MyMips/s_DMemData                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 32'h00000000 | 0             | 000000 |        |     | 000000 | 09  | 000000 | 01   |
| → /tb/MyMips/s_DMemOut                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 32'h00000000 | 0             | 000000 |        |     | 000000 | 00  |        |      |
| /tb/MyMips/s_RegWr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0            |               |        |        |     |        |     |        |      |
| <b></b> ✓ /tb/MyMips/s_RegWrAddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 5'h00        | 0             | q      | 09     |     | 0A     |     | 0A     |      |
| <b></b> → /tb/MyMips/s_RegWrData                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 32'h00000000 | 0             | 00000  | 000000 | 00  | 000000 | 01  | 000000 | 00   |
| <u>★</u> √ /tb/MyMips/s_IMemAddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 32'h00400054 | 0             | 04000  | 004000 | 10  | 004000 | 14  | 004000 | 18   |
| ■ / /tb/MyMips/s_NextInstAddr                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 32'h00400054 | 0             | 04000  | 004000 | 10  | 004000 | )14 | 004000 | 18   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 32'h50000000 | $\frac{1}{1}$ | 5C0F   | 000048 | 20  | 022850 | )22 | 214AFF | FF ) |
| /tb/MyMips/s_ALU_Ovfl                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0            | $\rightarrow$ |        |        |     |        |     |        |      |
| /tb/MyMips/s_RegDest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0            | <u> </u>      |        |        |     |        |     |        |      |
| /tb/MyMips/s_Jump                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0            | $\rightarrow$ |        |        |     |        |     |        |      |
| /tb/MyMips/s_Jump_Return                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0            | $\perp$       |        |        |     |        |     |        |      |
| Name of the line | 0            |               |        |        |     |        |     |        |      |
| /tb/MyMips/s_zero_extend                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0            | $\perp$       |        |        |     |        |     |        |      |
| /tb/MyMips/s_Branch                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0            |               |        |        |     |        |     |        |      |
| /tb/MyMips/s_MemRead                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 1            |               |        |        |     |        |     |        |      |
| /tb/MyMips/s_RegAddr_JalA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | U            |               |        |        |     |        |     |        |      |
| /tb/MyMips/s_MemtoReg                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1            | ya .          |        |        |     |        |     |        |      |
| → /tb/MyMips/s_ALUOp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 2'h0         | 1             | 2      |        |     |        | 0   |        | 2    |
| ♦ /tb/MvMips/s ALUSrc  • **  **  **  **  **  **  **  **  **                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1            |               |        |        |     |        |     |        |      |

This waveform demonstrates the bubble sort algorithm, showing the comparisons, swaps, ALU results and the loops in the MIPS processor. s\_DMemData shows the unsorted array, and when s\_DMemWr goes high, a swap is occuring while s\_DMemAddr shows which element is being accessed. The loops can be seen occuring with the branch instruction going from low to high.

[Part 4] report the maximum frequency your processor can run at and determine what your critical path is. Draw this critical path on top of your top-level schematics. What components would you focus on to improve the frequency?

The reported FMax in the timing output is 26.76mhz. The critical path is the path taken by lw. The critical path involves reading a value from a register, operating on it in the ALU, and using this value as an input to the DMEM. Then the output of DMEM goes into the registers write\_data port. This would be a lw instruction.



In order to improve the frequency of our processor we should focus on the register file and ALU. Those were the components that we made that had the highest latency. They took about 4ns and 5ns respectively. If we had a way to improve the memory that would likely help the most. There are 2 memory modules and they have the longest latency at about 8ns.