# Eli Granade's Journal

## Final Presentation:

11/12/23

I worked on the design document and our presentation. I decided to base what went into the presentation on both the suggested inputs on the course web page and my teammates input. While doing this, I realized that the table about how to write instructions was incorrect in regards to I-type, since it never used the immediate. This was rectified. I decided to make a handout so that it is easer to tell the viewers about the different commands we used, and how to construct commands. This will just be a modified handout found at the bottom of the design document. This took about an hour and a half.

Later in the day I put some work in to finish the Design Document. This took about 2 hours. I discovered that our testing plan was horribly out of date, since we originally were going to build the CPU from the decode stage forward, bit by bit. Instead we built each stage individually. Updated to reflect this.

# MILESTONE6:

11/3/23

I worked with Yash on the tests for the decode stage. No major tests were constructed, but we decided to try small things first, and implemented the tests as such. We discovered an error in the implementation of the Decode stage, the decode stage never had a register location input for writing data. This took approx 1 hour.

### 11/6/23

I once again worked with Yash on the decode stage tests in class. No major decisions made. Spent about 1 hour.

#### 11/7/23

I worked on our design document, and realized that our version of the branch commands were syntactically distinct from the other commands. Changed this to be more inline with all other commands.

### 11/8/23

I worked for about an hour on the design document, rearranging it so that it can flow better.

## MILESTONE5:

## 10/27/23

I worked on redoing the reset bit of all of the register blocks. For the tests, I looked up and found out that \$random gives a random signed number for verilog which was used for the Noop testing codes for the ALU. The Noop code was swapped to be zero, so that we can implement this command later down the line, should we wish to. In addition, I ran into some trouble where I was uncertain how to do a loop in verilog. Looking back at our in class mux test bench gave me the loop I was looking for. I realised that we may not need the Zero output for the ALU, and if we

don't, it will be removed. Remembered something I had wondered about the shift left and shift write commands, and how since we only have immediate input versions of the commands, we only need one shift left. In researching, I discovered a possible shorter way to code the shift left and right. On compilation tests, I ran into a problem when compiling that we can't have numbers in the first character of name of inputs/outputs of components. Names Changed accordingly. Several minor syntax issues were identified and fixed during this time as well. Time taken, aprox. 1 hour.

#### 10/30/23

I worked to finish up the ALU testbench. To that end I did decide to find the testing we made in class so I could remember how to display the failure variable. I could not find it there, but I did find it in the Lab 4 work we did. Upon attempting to run the test bench, I got the error "Error (10119): loop with non-constant loop condition must terminate within 250 iterations" for my clock code. I'll need to talk to robert to figure this one out. I tried "set\_global\_assignment -name VERILOG\_NON\_CONSTANT\_LOOP\_LIMIT 300" using the quartus console, but that did not help. I'll see if robert can help me later today. Spent around 40 minutes on this.

In class, Robert helped me by saying swap to model sim. The new error was found to be it didn't deal with negatives correctly. After discussing with my team, I signed the appropriate parts of both ALU and it's test bench. This is needed later down the line. After discussing with the group, I'm gonna remove the is\_zero output since we don't need it anymore. Time taken, approx. 30-45 minutes

### 10/31/23

The ALU still has an error for the or command. After a bit of work, I fixed the errors through help figuring out how to check errors in model sim, and testing. When testing I wondered whether right shift should sign extend or not. We decided to not sign extend it since that's what's in the design doc. I also looked and saw that some errors were caused by the and and or operations needing only 1 and or or symbol respectively. I also debugged the first completed register block.

#### 11/1/23

We reviewed with another team, and I then worked on the main suggestion, debugging code we had as examples, since it is incorrect in some ways. After staring at it for a bit, I worked with the team to debug some problems, since I think some of the loop examples would not work. We kept it as is beyond fixing the actual errors they showed us in our class review.

# MILESTONE4:

## 10/21/23

Started implementation of ALU. Ran into immediate problem of how to start the files. I dove back into our lab 4 files to figure out how to make it react to the clock. Realized that we may have forgotten a = zero output, take a look and see if we need it. Upon beginning to write the test benches, I realized that I had no clue once more. I pulled our tb\_counter tests from the same lab. In my creation of the ALU code, I designated any inputs on the opcode input that aren't defined output a zero on the mux. This may allow for a noop command. I would put this in

the zero slot, so an all zero command could be inputted for this noop command. Another possible upgrade/fix would be to take the shift left and shift right immediate and combine them into a shift right, and let negative numbers shift it left. I spent about an hour working on the test bench and the ALU. transferred to another section of the work, the intermediate registers between the stages. I was again unsure how to proceed, but this time I looked into what my teammates did for the single use register. This process was a lot of copy paste replace combos. This took about another hour. I double checked the program, and realized that several of the outputs were just wires, not registers. Make a point of double checking the code as we go forward.

#### 10/24/2023

One of my teammates told me that the register blocks and ALU were having trouble compiling. I realised that the issue was the end of the input/output block cannot have a , character. In addition, I had ended many of my lines with a , instead of an ; which causes problems. Fixed in the register blocks, but not the ALU.

# MILESTONE3:

## 10/13/23

Discussed what our language should denote as comments during the in-class work time. Decided that the # symbol would be good, since it is a simple, one character symbol that does not show up in any of our commands. In addition, I worked on the compiler/translator, laying the foundation for a possible runtime environment, or just a way to translate our register programming to base binary. I worked on this since I was unable to assist in the making of the data path, since editing it can only be done by one person at a time.

# 10/17/23

Worked for about 30 minutes further developing the translator. Only major decision is that future R types need to follow the pattern of one character commands, since that is easier to hardcode in than track variable sizes. Programming for the I types will be a challenge because of this. Will look into making the program more flexible on what it can accept in terms of actual commands.

## 10/18/23

Worked for approx an hour on finishing touches for milestone 3. I made two major decisions, the naming conventions for components, and the Naming convention for inputs/outputs. I chose camel case since most of us have coded in java, so this will make verilog easier. I chose I and O at the beginning so that we can easily tell whether something is an input or an output in the verilog code.

For Milestone 3 I am going to be working on the ALU implementation and register file, and continuing work on the translator.

## **MILESTONE2:**

10/4/23

I helped plan the next milestone, and finish up one. We decided to change our command conventions, opting for the final register to be the destination in all cases. In addition, to make typing faster, we decided to change the names to be mathematical symbols or sets of relevant symbols, such as Y for the branch command since it delineates a fork.

#### 10/10/2023

Spent about twenty minutes contributing to the RTL, and considering what else needed to be done for milestone two, and future plans. Discussed with the team why the destination register was named 3rd arg. While we left it for the speed of jump commands, it may become an issue if we develop the processor to be a pipeline. We left it as is for now. I wonder if pipelining could be even faster, should we decide to disregard the actual final cost of the machine. One possible way to do this is by swapping all non-essential registers (i.e. the input/ return argument registers) to be saved or all to temporary registers. This may make the procedure calls better overall. Will bring up at tomorrow's meeting.

## 10/11

Proposed again the mark command. Was again refused due to the simplicity of the current commands. Decided to swap our work from multi-cycle to a pipeline system. It will be harder, but fastest possible system. Decided to double check the RTL by

Went over the work we did for milestone 2, and confirmed that it met the requirements.

For the next milestone, I will be assisting Drew on the datapath construction, probably taking less than an hour, and possibly taking some time to contribute to the tests and basic quartus work, depending on how long I have.

# **MILESTONE 1:**

### 9/27/2023

We only spent the remaining class time that we had at the time.

We decided to do a load store implementation because it is the fastest and most simplest for our purposes.

We decided to have the following registers:

A zero/ground register, a return address register, a stack pointer, two argument/return registers, and three temporary registers. We chose 8 registers so our main add command can be 12 bits for registers and a four bit opcode. We chose a four bit opcode since we're restricted to 16 bit commands.

### 10/3/23

I helped complete the design document that is due for milestone one, spending an hour after class.

Gave us the ability to add more R types by extending the opcode of the R type instruction, while simultaneously removing dead bits in the instruction type.