Report

on

COEN 316 Laboratory Experiment #4

**CPU Datapath/Control Unit and Testing**

Submitted to

*SEYED AMIRREZA MOUSAVI*

*Instructor’s name*

Date Performed: November 24th, 2020

Date Submitted: December 8, 2020

By

Jasen Ratnam 40094237

Name student ID

Lab section: DI-X

“I certify that this submission is my original work and meets the Faculty's Expectations of Originality”

![](data:image/png;base64,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)

40094237 28/11/2020

\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_\_

# **Objective:**

In this lab, we will use digital logic simulation and synthesis using Modelsim, and Xilinx ISE (Vivado) to become acquainted with the VHDL simulation software tool and FPGA implementation software tools. During this lab, design and model a CPU datapath using VHDL and all the cpu components we have done in the previous labs. All components are put together along with some new components, a control unit and a pipeline, to create a fully functional CPU.

**Introduction:**

The lab consisted of designing a complete CPU using VHDL using different CPU units created in previous labs. We simulate the created processor and test possible operations that may happen on it, using the instructions i cache. The previous components include an ALU, next-address unit, register file unit, and a datapath unit. In this lab, we need to create a pipeline and control unit to join them.

In normal operation, the program counter of the CPU is updated to point to the next instruction after every clock cycle. To point at the next instruction, it’s address is needed that can be the following address of the current one or it can be pointed to a completely different part of the memory by using a jump or branch instruction. Our design needs to be able to calculate the address of the next instruction for every case.

**Part 1:**

In the first part of the lab, we are tasked to build a datapath to join all the CPU components we have created in the previous labs, along with some new components. We are given a partial datapath of the CPU and a detailed textual explanation of how the datapath should function. With this information we created the following complete datapath design. The different colours are used solely to differients the overlapping lines.

**![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAADUlEQVR4XmP4//8/AwAI/AL+GwXmLwAAAABJRU5ErkJggg==)**

**Figure 1: CPU datapath.**

With this design, we begin creating the additional components needed in vhdl and then create a datapath code to put all the components together following the design above.

**Part 2:**

In this part of the lab, we are tasked with creating a control unit to control the datapath of the CPU created above based on the instruction in the I\_Chache. We are given 20 instructions to implement in the CPU. The instructions have a 6 bit opcode, a 6 bit func, and 10 control signals to control the flow of data in the datapath of the CPU. We are given a partially completed table with the 20 instructions and their control signals, we completed the table by deriving the values of the 10 control signals using the tables given that give the conditions of each signal to be enabled, The completed table is given below.

**Table 1: 20 instructions with opcode and function fields and control signals.**

| Inst. | op | func | reg\_write | reg\_dst | reg\_in\_src | alu\_src | add\_sub | data\_write | logic\_func | func | branch\_type | pc\_sel |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| lui | 001111 | 001111 | 1 | 0 | 1 | 1 | 0 | 0 | 00 | 00 | 00 | 00 |
| add | 000000 | 100000 | 1 | 1 | 1 | 0 | 0 | 0 | 00 | 10 | 00 | 00 |
| sub | 000000 | 100010 | 1 | 1 | 0 | 0 | 1 | 0 | 00 | 10 | 00 | 00 |
| slt | 000000 | 101010 | 1 | 1 | 0 | 0 | 0 | 0 | 00 | 01 | 00 | 00 |
| addi | 001000 | 001000 | 1 | 0 | 1 | 1 | 0 | 0 | 00 | 10 | 00 | 00 |
| slti | 001010 | 001010 | 1 | 0 | 0 | 1 | 0 | 0 | 00 | 01 | 00 | 00 |
| and | 000000 | 100100 | 1 | 1 | 1 | 0 | 1 | 0 | 00 | 11 | 00 | 00 |
| or | 000000 | 100101 | 1 | 1 | 0 | 0 | 0 | 0 | 01 | 11 | 00 | 00 |
| xor | 000000 | 100110 | 1 | 1 | 0 | 0 | 0 | 0 | 10 | 11 | 00 | 00 |
| nor | 000000 | 100111 | 1 | 1 | 0 | 0 | 0 | 0 | 11 | 11 | 00 | 00 |
| andi | 001100 | 001100 | 1 | 0 | 0 | 1 | 0 | 0 | 00 | 11 | 00 | 00 |
| ori | 001101 | 001101 | 1 | 0 | 0 | 1 | 0 | 0 | 01 | 11 | 00 | 00 |
| xori | 001110 | 001101 | 1 | 0 | 0 | 1 | 0 | 0 | 10 | 11 | 00 | 00 |
| lw | 100011 | 100011 | 1 | 0 | 0 | 1 | 0 | 0 | 10 | 10 | 00 | 00 |
| sw | 101011 | 101011 | 0 | 0 | 1 | 1 | 0 | 1 | 00 | 10 | 00 | 00 |
| j | 000010 | 000010 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 00 | 00 | 01 |
| jr | 000000 | 001000 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 00 | 00 | 10 |
| bltz | 000001 | 000001 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 00 | 11 | 00 |
| beq | 000100 | 000100 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 00 | 01 | 00 |
| bne | 000101 | 000101 | 0 | 0 | 0 | 0 | 0 | 0 | 00 | 00 | 10 | 00 |

With the table completed, we begin designing the control unit using vhdl as a process in the datapath code done in part 1 of the lab. The unit is designed as a combinational logic circuit whose inputs are the opcode and function fields of the instruction and the outputs are the 10 control signals from the table above. This control unit and the entire CPU is tested using the following instructions stored in I\_Cache.

| "00000" "00100000000000110000000000000000"; *-- addi r3, r0, 0* "00001" "00100000000000010000000000000000"; *-- addi r1, r0, 0* "00010" "00100000000000100000000000000101"; *-- addi r2,r0,5* **LOOP**: "00011" "00000000001000100000100000100000"; *-- add r1,r1,r2* "00100" "00100000010000101111111111111111"; *-- addi r2, r2, -1* "00101" "00010000010000110000000000000001"; *-- beq r2,r3 (+1)* THERE "00110" "00001000000000000000000000000011"; *-- jump 3 (LOOP)* THERE:"00111" "10101100000000010000000000000000"; *-- sw r1, 0(r0)* "01000" "10001100000001000000000000000000"; *-- lw r4, 0(r0)* "01001" "00110000100001000000000000001010"; *-- andi r4,r4, 0x000A* "01010" "00110100100001000000000000000001"; *-- ori r4,r4, 0x0001* "01011" "00111000100001000000000000001011"; *-- xori r4,r4, 0xB* "01100" "00111000100001000000000000000000"; *-- xori r4,r4,* 0x0000 **others** "00000000000000000000000000000000"; *-- dont care* |
| --- |

**Results:**

**The complete VHDL code source for the register file:**

| **library** IEEE; **use** IEEE.std\_logic\_1164.**all**; **use** IEEE.std\_logic\_signed.**all**;  **entity** cpu **is**  **port**(   *--asynchronous reset and a clock input.*  clk, rst: **in** std\_logic;  rs\_out : **out** std\_logic\_vector(31 **downto** 0);  rt\_out : **out** std\_logic\_vector(31 **downto** 0);  *--output ports from register file*  pc\_out : **out** std\_logic\_vector(31 **downto** 0);   zero, overflow : **out** std\_logic); **end** cpu;     **architecture** cpu\_arch **of** cpu **is**  *--components:*  *--component of instruction cache*  **component** icache\_comp **is**  **port**  (  address : **in** std\_logic\_vector(4 **downto** 0);  instruction : **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;   *--component of a 5 bit mux*   **component** mux5\_comp **is**  **port**  (  control : **in** std\_logic;  regD : **in** std\_logic\_vector(4 **downto** 0);  regT : **in** std\_logic\_vector(4 **downto** 0);  reg : **out** std\_logic\_vector(4 **downto** 0));  **end** **component**;    *--component of the REGFILE*  *-- 32x32 register file*  **component** regFile\_comp **is**   **port**  ( din : **in** std\_logic\_vector(31 **downto** 0);   reset : **in** std\_logic;  clk : **in** std\_logic;  write : **in** std\_logic;  read\_a : **in** std\_logic\_vector(4 **downto** 0);  read\_b : **in** std\_logic\_vector(4 **downto** 0);  write\_address : **in** std\_logic\_vector(4 **downto** 0);  out\_a : **out** std\_logic\_vector(31 **downto** 0);  out\_b : **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;    *--component of sign extending*  **component** signex\_comp **is**  **port**  ( func : **in** std\_logic\_vector(1 **downto** 0);  immediate : **in** std\_logic\_vector(15 **downto** 0);  signExtended : **out** std\_logic\_vector(31 **downto** 0));   **end** **component**;    *--component of a 32 bit mux*   **component** mux32\_comp **is**  **port**  ( control : **in** std\_logic;  reg : **in** std\_logic\_vector(31 **downto** 0);  immediate : **in** std\_logic\_vector(31 **downto** 0);  value : **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;   *--component of the ALU*   **component** alu\_comp **is**   **port**  ( x : **in** std\_logic\_vector(31 **downto** 0);  y : **in** std\_logic\_vector(31 **downto** 0); *-- two input operands*  add\_sub : **in** std\_logic; *-- 0 = add , 1 = sub*  logic\_func : **in** std\_logic\_vector(1 **downto** 0 ); *-- 00 = AND, 01 = OR , 10 = XOR , 11 = NOR*  func : **in** std\_logic\_vector(1 **downto** 0 ) ; *-- 00 = lui, 01 = setless , 10 = arith , 11 = logic*  output : **out** std\_logic\_vector(31 **downto** 0) ;  overflow : **out** std\_logic ;  zero : **out** std\_logic);  **end** **component**;   *--component of the data cache*   **component** dcache\_comp **is**  **port**  (  clock : **in** std\_logic;  reset : **in** std\_logic;  registerData : **in** std\_logic\_vector(31 **downto** 0);  write : **in** std\_logic;  muxsel : **in** std\_logic;  ld\_st : **in** std\_logic\_vector(31 **downto** 0);  Dout: **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;   *--component of the nextAddress block*   **component** nextAddr\_comp **is**   **port**  (  rt : **in** std\_logic\_vector(31 **downto** 0);  rs : **in** std\_logic\_vector(31 **downto** 0);   pc : **in** std\_logic\_vector(31 **downto** 0);  target\_address : **in** std\_logic\_vector(25 **downto** 0);  branch\_type : **in** std\_logic\_vector(1 **downto** 0);  pc\_sel : **in** std\_logic\_vector(1 **downto** 0);  next\_pc : **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;   *--component of pc regsiter*  **component** pc\_comp **is**   **port**(   clock : **in** std\_logic;  reset : **in** std\_logic;  value : **in** std\_logic\_vector(31 **downto** 0);  lower : **out** std\_logic\_vector(4 **downto** 0);  pc\_value : **out** std\_logic\_vector(31 **downto** 0));  **end** **component**;   *--Entities to connect the components to the vhd code*  **for** instructioni : icache\_comp **use** **entity** work.icache(icache\_arch);  **for** write : mux5\_comp **use** **entity** work.Mux5(mux5\_arch);  **for** registr : regFile\_comp **use** **entity** work.regfile(regfile\_arch);  **for** se : signex\_comp **use** **entity** work.signextend(se\_arch);  **for** check : mux32\_comp **use** **entity** work.mux32(mux32\_arch);  **for** a\_l\_u : alu\_comp **use** **entity** work.alu(alu\_arch);  **for** data : dcache\_comp **use** **entity** work.dcache(dcache\_arch);  **for** nextpc : nextAddr\_comp **use** **entity** work.next\_address(arch\_next);  **for** pcpass : pc\_comp **use** **entity** work.pc(pc\_arch);    *--define the signals*  **signal** pc\_in : std\_logic\_vector(31 **downto** 0);  **signal** pc\_nxt : std\_logic\_vector(31 **downto** 0);  **signal** lower\_pc : std\_logic\_vector(4 **downto** 0);   **signal** instruction : std\_logic\_vector(31 **downto** 0);  **signal** reg\_one, reg\_two : std\_logic\_vector(31 **downto** 0);  **signal** write\_reg : std\_logic\_vector(4 **downto** 0);  **signal** immediate\_se : std\_logic\_vector(31 **downto** 0);  **signal** reg\_value : std\_logic\_vector(31 **downto** 0);  **signal** alu\_out : std\_logic\_vector(31 **downto** 0);  **signal** alu\_overflow, alu\_zero : std\_logic;  **signal** data\_out : std\_logic\_vector(31 **downto** 0);   *--control unit signals*  **signal** branch\_type, pc\_sel, logic, the\_func : std\_logic\_vector(1 **downto** 0);  **signal** reg\_write,alu\_src, addsub, data\_write, reg\_in\_src, reg\_dst : std\_logic;     **begin**   pcpass : pc\_comp **port** **map**(clk, rst, pc\_nxt, lower\_pc, pc\_in);   *--------next pc------------*  nextpc : nextAddr\_comp **port** **map**(reg\_one, reg\_two, pc\_in, instruction(25 **downto** 0), branch\_type, pc\_sel, pc\_nxt);    *-----------send pc address to icache and get the instruction components*  instructioni : icache\_comp **port** **map**(lower\_pc, instruction);    *--------get the address to write into*  write : mux5\_comp **port** **map**(reg\_dst, instruction(15 **downto** 11), instruction(20 **downto** 16), write\_reg);   *----------control unit-------*  **process**(instruction)   **begin**  *--set tje signals depending on the opcode of the instructions*  *--lui*  **if**(instruction(31 **downto** 26) = "001111") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '1';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "00";   pc\_sel <= "00";   *--addi*  **elsif**(instruction(31 **downto** 26) = "001000") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '1';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "10";  branch\_type <= "00";   pc\_sel <= "00";   *--slti*  **elsif**(instruction(31 **downto** 26) = "001010") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "01";  branch\_type <= "00";   pc\_sel <= "00";   *--andi*  **elsif**(instruction(31 **downto** 26) = "001100") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "11";  branch\_type <= "00";   pc\_sel <= "00";   *--ori*  **elsif**(instruction(31 **downto** 26) = "001101") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "01";  the\_func <= "11";  branch\_type <= "00";   pc\_sel <= "00";   *--xori*  **elsif**(instruction(31 **downto** 26) = "001101") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "10";  the\_func <= "11";  branch\_type <= "00";   pc\_sel <= "00";   *--lw*  **elsif**(instruction(31 **downto** 26) = "100011") **then**  reg\_write <= '1';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '1';   addsub <= '0';   data\_write <= '0';   logic <= "10";  the\_func <= "10";  branch\_type <= "00";   pc\_sel <= "00";   *--sw*  **elsif**(instruction(31 **downto** 26) = "101011") **then**  reg\_write <= '0';   reg\_dst <= '0';   reg\_in\_src <= '1';   alu\_src <= '1';   addsub <= '0';   data\_write <= '1';   logic <= "00";  the\_func <= "10";  branch\_type <= "00";   pc\_sel <= "00";   *--nor*  **elsif**(instruction(31 **downto** 26) = "100111") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "11";  the\_func <= "11";  branch\_type <= "00";   pc\_sel <= "00";   *--jump*  **elsif**(instruction(31 **downto** 26) = "000010") **then**  reg\_write <= '0';  reg\_dst <= '0';  reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "00";   pc\_sel <= "01";   *--bltz*  **elsif**(instruction(31 **downto** 26) = "000001") **then**  reg\_write <= '0';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "11";   pc\_sel <= "00";   *--beq*  **elsif**(instruction(31 **downto** 26) = "000100") **then**  reg\_write <= '0';  reg\_dst <= '0';  reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "01";   pc\_sel <= "00";   *--bne*  **elsif**(instruction(31 **downto** 26) = "000101") **then**  reg\_write <= '0';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "10";   pc\_sel <= "00";    *--if opcode is 0*  **elsif**(instruction(31 **downto** 26) = "000000") **then**   *--add*  **if**(instruction(5 **downto** 0) = "100000") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '1';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "10";  branch\_type <= "00";  pc\_sel <= "00";  *--sub*  **elsif**(instruction(5 **downto** 0) = "100010") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '1';   data\_write <= '0';   logic <= "00";  the\_func <= "10";  branch\_type <= "00";  pc\_sel <= "00";   *--slt*  **elsif**(instruction(5 **downto** 0) = "101010") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "01";  branch\_type <= "00";  pc\_sel <= "00";   *--and*  **elsif**(instruction(5 **downto** 0) = "100100") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '1';   alu\_src <= '0';   addsub <= '1';   data\_write <= '0';   logic <= "00";  the\_func <= "11";  branch\_type <= "00";  pc\_sel <= "00";   *--or*  **elsif**(instruction(5 **downto** 0) = "100101") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "01";  the\_func <= "11";  branch\_type <= "00";  pc\_sel <= "00";   *--xor*  **elsif**(instruction(5 **downto** 0) = "100110") **then**  reg\_write <= '1';   reg\_dst <= '1';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "10";  the\_func <= "11";  branch\_type <= "00";  pc\_sel <= "00";   *--jump register*  **else**  reg\_write <= '0';   reg\_dst <= '0';   reg\_in\_src <= '0';   alu\_src <= '0';   addsub <= '0';   data\_write <= '0';   logic <= "00";  the\_func <= "00";  branch\_type <= "00";  pc\_sel <= "10";   **end** **if**;  **end** **if**;  **end** **process**;   *--Do operation depending on the control values*  registr : regFile\_comp **port** **map**(data\_out,rst,clk,reg\_write,instruction(20 **downto** 16), instruction(25 **downto** 21), write\_reg,reg\_one, reg\_two);   *------------Sign Extend*  se : signex\_comp **port** **map**(the\_func, instruction(15 **downto** 0), immediate\_se);   *-----------determine if we use immediate or register*  check : mux32\_comp **port** **map**(alu\_src, reg\_two, immediate\_se, reg\_value);   *-----------alu*  a\_l\_u : alu\_comp **port** **map**(reg\_one, reg\_value, addsub, logic, the\_func, alu\_out, alu\_overflow, alu\_zero);    *------------dcache*  data : dcache\_comp **port** **map**(clk, rst, alu\_out, data\_write, reg\_in\_src, reg\_one, data\_out);   rs\_out <= reg\_two(31 **downto** 0);  rt\_out <= reg\_one(31 **downto** 0);  pc\_out <= pc\_nxt(31 **downto** 0);  zero <= alu\_zero;  overflow <= alu\_overflow; **end** cpu\_arch; |
| --- |

**The TCL script file:**

| # TCL script **for** running vivado **in** batch mode **to** synthesize  # **To** run the script first source the Vivado env **file**: # source /CMC/tools/xilinx/Vivado\_2018.2/Vivado/2018.2/settings64\_CMC\_central\_license.csh # #**Then** issue the following command from the Linux prompt: # vivado -log tedcircuit.log -mode batch -source tedcircuit\_script.tcl  # read **in** the VHDL source code files **and** the xdc constraints **file**  set\_property **SEVERITY** {Warning} [get\_drc\_checks UCIO-1]  read\_vhdl { ../Code/cpu.vhd ../Code/cpuCircuit.vhd } read\_xdc CPUcircuit.xdc  # the -top refers **to** the top level VHDL **entity** name # the -part specfies the target Xilinx FPGA  synth\_design -top CPUCircuit -part xc7a100tcsg324-1  opt\_design place\_design route\_design  # **generate** the bitsteam **file** write\_bitstream -**force** CPUCircuit.bit |
| --- |

**The log file is available in the appendix.**

Unfortunately, while performing the synthesis with Xilinx Vivado with the command line script I faced an error that I could find a fix for. The synthesis of the program throws an error that the complaining and simulation of the code did not show.

The error is :

ERROR: [Synth 8-2948] no **architecture** 'pc\_arch' **for** **entity** 'pc\_comp' [/nfs/home/j/j\_ratn/COEN316/Code/cpu.vhd:150]

This is a synthesis error that happens on line 150 of the cpu.vhd code:

| pcpass : pc\_comp **port** **map**(clk, rst, pc\_nxt, lower\_pc, pc\_in); |
| --- |

This line port maps the inputs and outputs of the CPU to the PC component of the system. The error says that the component has no access to architecture of pc “pc\_arch” but it is declared on line 127:

| **for** pcpass : pc\_comp **use** **entity** work.pc(pc\_arch); |
| --- |

And we know that the PC code is situated in the work folder since it was compiled using vcom on the command panel.

I understand the error and the cause of the error but i could not find a way to fix the error, since the architecture is available but the program somehow does not have access to it.

| #*-----------------------------------------------------------* # Vivado v2018.2 (64-bit) # SW Build 2258646 **on** Thu Jun 14 20:02:38 MDT 2018 # IP Build 2256618 **on** Thu Jun 14 22:10:49 MDT 2018 # Start **of** session at: Mon Nov 30 10:02:04 2020 # **Process** ID: 61661 # Current directory: /nfs/home/j/j\_ratn/COEN316/CPUCIRCUIT\_SCRIPT # Command line: vivado -log cpucircuit.log -mode batch -source CPU\_script.tcl # Log **file**: /nfs/home/j/j\_ratn/COEN316/CPUCIRCUIT\_SCRIPT/cpucircuit.log # Journal **file**: /nfs/home/j/j\_ratn/COEN316/CPUCIRCUIT\_SCRIPT/vivado.jou #*-----------------------------------------------------------* source CPU\_script.tcl # set\_property **SEVERITY** {Warning} [get\_drc\_checks UCIO-1] # read\_vhdl { ../Code/cpu.vhd ../Code/cpuCircuit.vhd } # read\_xdc CPUcircuit.xdc # synth\_design -top CPUCircuit -part xc7a100tcsg324-1 Command: synth\_design -top CPUCircuit -part xc7a100tcsg324-1 Starting synth\_design Attempting **to** get a license **for** feature 'Synthesis' **and**/**or** device 'xc7a100t' INFO: [Common 17-349] Got license **for** feature 'Synthesis' **and**/**or** device 'xc7a100t' INFO: Launching helper **process** **for** spawning children vivado processes INFO: Helper **process** launched **with** PID 61688  *---------------------------------------------------------------------------------* Starting RTL Elaboration : Time (s): cpu = 00:00:03 ; elapsed = 00:00:06 . Memory (MB): peak = 1468.590 ; gain = 86.727 ; free physical = 79561 ; free virtual = 128919 *---------------------------------------------------------------------------------* INFO: [Synth 8-638] synthesizing module 'CPUCircuit' [/nfs/home/j/j\_ratn/COEN316/Code/cpuCircuit.vhd:10] INFO: [Synth 8-3491] module 'cpu' declared at '/nfs/home/j/j\_ratn/COEN316/Code/cpu.vhd:5' bound **to** instance 'U1' **of** **component** 'cpu' [/nfs/home/j/j\_ratn/COEN316/Code/cpuCircuit.vhd:31] INFO: [Synth 8-638] synthesizing module 'cpu' [/nfs/home/j/j\_ratn/COEN316/Code/cpu.vhd:17] ERROR: [Synth 8-2948] no **architecture** 'pc\_arch' **for** **entity** 'pc\_comp' [/nfs/home/j/j\_ratn/COEN316/Code/cpu.vhd:150] ERROR: [Synth 8-285] failed synthesizing module 'cpu' [/nfs/home/j/j\_ratn/COEN316/Code/cpu.vhd:17] ERROR: [Synth 8-285] failed synthesizing module 'CPUCircuit' [/nfs/home/j/j\_ratn/COEN316/Code/cpuCircuit.vhd:10] *---------------------------------------------------------------------------------* Finished RTL Elaboration : Time (s): cpu = 00:00:05 ; elapsed = 00:00:08 . Memory (MB): peak = 1513.215 ; gain = 131.352 ; free physical = 79573 ; free virtual = 128931 *---------------------------------------------------------------------------------* RTL Elaboration failed INFO: [Common 17-83] Releasing license: Synthesis 5 Infos, 0 Warnings, 0 Critical Warnings **and** 4 Errors encountered. synth\_design failed ERROR: [Common 17-69] Command failed: Synthesis failed - please see the console **or** run log **file** **for** details INFO: [Common 17-206] Exiting Vivado at Mon Nov 30 10:02:30 2020... |
| --- |

**Simulation and implementation results using port maps:**

* The Modelsim simulation: rs\_out, rt\_out and pc\_out are examined
  + ![](data:image/png;base64,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) ![](data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAARsAAADFCAYAAABkblbKAAASmUlEQVR4Ae2da7aqOhCEHQ9TcSQOhIEwDgfHWRE6O49OGhOMevx+3MXdNkmwqK5OkNS5XC6Xlf/AAA7AgQEcAOQBICPoFDU4QKIhtnAADgziAEAPAprKxuzm1zmA2CA2cAAODOGAPshtmdfrdFuX+frrasz3Z0YCB87hgCY213Vebut0ndflNj0N9HSb12W5r/f7orYnDj7w4zX5MU3X9brnXyl3a/nX296YISpis89optuyzlclXlO5VKCuc9wH8ViAwQd+hDnWmx+Sm2k/pc9T/pXOK31eai/nx8dYTK6zU9zkvyeWUtd5WW9T0GeyFCMOPvDjdfnhZxYFsbHy77T2scjI6ij44nLCfqHZhUm8cszaOLFZbjLYSlwRG/CBH3tO9eZHk1gE/Dutva4RiA1iSDGQJOtN9ne3l+9xeWZm8y6x6V9G3eM1eLaMIh49BwOf6BdPxz/wCSYAT/LDFps6vqe1PzqzcQ+G3ZPs25JM+fUO/BT4caHTbZ2DX7Cc0qfkIf73Cx/4wI9T80NytDCzuVj5eVZ76Sc+Biq6B7bqcl3n+7xO8cmxsBRi7qc1ecis/fxGHHzgx/YjzNn5oa5MkmVSLf962/uZka4NudjwQl+OiQHiIRGmD3D9cQ5AgB8nAEKpV2FwOR8XxAaxgQNwYAgHhgxClTi/SoApmH4bBxAbqhocgANDODBkkG9TYK6XWQMcOJ8DiA1VDQ7AgSEc0Afh528dF0gJLnCgmQNaQ/xs8Ft5jd+KS9SanwrxPnx6/Wh62xtCrIjNvh8DP5vL6ja0Ra+Tp6+BEwefM/1oevklz1nSfkqfp/wtnVf6vNRezo+PsdioryvjZ+MfFqq7egN8iCf76bKNhMRf6efjZxYFsbH4eVr7WGQkf2KxeQy2X2h2YXoH0tHjmLVxZAv2ZhBXkg18PIfgRx8/msQi4N9p7XWtQGwQQ/xsJMm+Xezke+Bnc7ms247yQOCyaXbdb4P24BM9Q4M/kR+QLTZ1/pzW/ujMBj8b/GaEdK7Sp8mNH9EH80OSvPDMBj8bAWg/1vw2XBIQxw8HPxzdD0f9gSd5JlPLn972UqQKx2BJsyc7L/TlmBTA8w82iYMZHDA5YJ5AQiUzL0gFZ+BAEweaGiFACBAcgAPPcgCxoUrBATgwhANDBnlWATmfqgkH/j8OIDZUNTgAB4ZwYMggVKn/r0pxT7mnz3JAFxt+/tZxoQKCCxxo5oDWED8b/Gzws7nft38ZNhWXT/bjsfxorLj7rr3fL8Ur+FsRm32/CX42+Nng5/NlfkaytCttV7DiabvUr8aKS//6MRYb9XXlwK8lUCl1vabumg3aE1csBMDHcwl+9PHD52cqCmnyF+K9+Pvx0/G2v2OxeZy8X0g2sN6BJ4prm7XBzwY/n2BvDvxQxOREfHyyF8TEivfeH9+/rhWIDX42+NlIkvQm27vby/co+dlY8d7r9/0fEZv+ZVTdL8P1n1oWLNEygjj4BAUQv5rIr8bKH5/szTObvvzz4x8RG3cyfjYf7Fcy3Vb8ZLg/ktRuJhIVJ0nyRrEx/W4s/sn4+jGoIvsJm3pe1/k+r5PeKHpOI19cjjW/jE3M8GPBj0X3Y4EffX5N6sokeia04S78exyD+Bn4iw4ox1xseKEvx0QBriq4nA+GcCDjQPYBSdQwm4NY8AgOmBwwT0B8EB84AAfO4ABiQ0WCA3BgCAeGDHKGKtIH1RUOfDcHEBuqGhyAA0M4MGQQKtJ3VyTuH/fvDA7oYsPP3zouVEBwgQPNHNAa4meDnw1+Nv+jn40TyppfzRl+NxUxVsQGP5u/KeOzfh7pa+K0j1+nB591uf1ttzjdL0iWeynOpc9TfpbOK31eai/nx8dYbNTXnYONkhXVeiSoums0aE9csRgAHy/u8KOPHz4/C2Jj4Xta+1hk5P7GYvMYbL/Q7ML0DqSjstgEey+yPvG7we8Gfvgc6s2PJrEI8D+tva4ViA1+NvjZSJL1Jvu728v3KPnZWNd3WvsjYtO/jOrzw9h2nAcCiJ/JU34m4Pfb/LPFoo7Pae2PiI0bDD+bvwd4rhJEfiGWnwdx/HaCB8DD+SNJXnhmY/rVnNVe+omPwSxiD2zVET8b5/UR/XKw44NfD35E4gfzafxQVybJM5kaf3vb+5lRLDLyTCoXG17oyzExQBQwOeokAxdwcRwgscAADsCBIRwYMgiVDVGHA3AAsaGqwQE4MIQDQwahqlHV4AAcQGyoanAADgzhwJBBqGpUNTgAB3Sx4edvHRcqILjAgWYOaA3xs8HPBj8b/Gz+3qQPBbbmhxOep/y/Ijb42fxN+VO/jvQ1cOLxdg7wid86H80PWaql96H0eXp9pfNKn5fay/nxMRYb9XXlwG9FUau/xLxcVnVXadCeeJ9fCfiB320KcjbZqOzzsyA2Fn9Oax+LjGhEcOFywn6h2YVJvHLM2uBXg19NsDcHfihieSI+TWIRjH9ae10jEBv8bPCzkST7djGU74GfzWOZVffT2HacBwKYTBOJg19q+bFEy/TfxscWmzo+p7U/OrPBz+bvKbyrdCm553f6leCXg19OjX+S5IVnNvjZCED7sea34ZSXOH4yn+on825+qj/wJM9kavnT297PjJKc3j8Pliz7CbzQl2NigChP2znqJAMXcHEcILHAAA7AgSEcGDIIlQ1RhwNwALGhqsEBODCEA0MGoapR1eAAHEBsqGpwAA4M4cCQQahqVDU4AAd0seHnbx0XKiC4wIFmDmgN8bPBzwY/m//Rz2aaruv1Nq+O39o/sOeE1PKrseIVMVbEBj+bvyl/6teRvgZOPN7OAT5xEo/mhyzV0vsgn8uxFE8/f/b6pX/9GIuN+rpysNGtolqPBFV3zQbtiSsWA+DjxR1+9PHD52cqGmnyF+K9+Pvx0/G2v2OxeZy8X0g2sN6BJ4prm7XBzwY/m2BvDvxQxOREfHyyF8TEivfeH9+/rhWIDX42+NlIkvQm27vby/co+dlY8d7r9/0fEZv+ZVTdL8P1n1o24Edy9bND8IEfPfnhk715ZtOHvx//iNi4k/Gzwc9GSOMqXUp+/Hw+mB+S5I1iY/rdWH5KMr5+zJdRW3W9rvN9Xie9ka/EQsrwWPPL2MQMPxb8WNxP6/rPr/CnPT/UlUn0TGjDXfj3OAbxM/Iz1ILk/3Ox4YW+HJMEtKrYci74wQGVA+qHJFPDjA6CwSU4UOVANYjoIDpwAA6cxQHEhmoEB+DAEA4MGeQsZaQfqiwc+F4OIDZUNTgAB4ZwYMggVKPvrUbcO+7dWRzQxYafv3VcqIDgAgeaOaA1bPezsfwyiNf9RMAHfGp+MxY/nBDW/GZ621v9G0KsiE2Pn41MOVtfl6b9NmUFv9gXRnghR/DR8UlxSf1oLPys9lZc+tePsdiorzsHfiuGcv2t7dKLSgcnrpNFcAIf8An+Te8s7wr8UHdta/nb2P5w/8Lj+BiLzeNL7ReSdRw3/BMW7fPCl/GgESeZGpIJ/uz5WsifLGcTPykLP6u9Fff9a5qgBhGbtdUPxONZIAPxerKATx8+h8WgwE+rvRX39++I2LCM6rvZHuzCzSQOvg8OvIgfm2PDjrFL+P35q+ediEBhfKu9Fc/GkfG2Y3Bhe6DLz0Y6L3wZfzHEWUaxjCo/imjNj6N+M6X+rfZWXPJfP+Zis6lXm5+Naxt5Zdzv6z3wyyAOPvAj4cCJ+eGKec0PyMo/q/2RuJ9Q5IKTiw0v9OWYVAAsV6ccbM4Fk1/mAImFkMABODCEA0MG+WU157szm4EDGwcQG6oaHIADQzgwZBCUneoOB+AAYkNVgwNwYAgHhgxCVaOqwQE4oIsNP3/ruFABwQUONHNAa4ifzbIU/gG1Cb+VHr8Vy0+FeB+/nBDiZ5NOIUuvS8t5xNnOwHaG8tKzlB/p5/jZXNhVnZJCRFaOxBHbBrFVd2XjZzNDpgYy+ecFiBH8Ufijik2w98rij9Xeivv+pWjGR+WZzU7krOO4YXmK584jGUgGJRk8GeHHS/iR5ewnm2epu0K1aZglPJDpJWQiWffiCL9Ufrn8na/BBAI/G2Y+zPxYRi+vmPkd9ZspibXV3orXJyGBCu4nbuqIn433XQnWvOrMj7hfUoNP4lUz2M/JzXzxs6krnierXyZwPpjAgf+NA/nMhoQHEzgAB17AAUB9Aaj/W0Xi+zDLOoMDiA1iAwfgwBAODBnkDFWkD6orHPhuDiA2VDU4AAeGcGDIIFSk765I3D/u3xkc0MUGPxsdFyoguMCBZg5oDdv9bNyNqPlpEAcf+DGvzi/pfl/ULQc9+PT6AVn5afVvCLEiNvt+CvfP8Eb7LI5MJdPXoFM/DeIxwcAn5hj86OOH5GiKo3wux1I8/Tzlp9Ve4voxFhv1dfMnNmKqu06D9sSX9TYFmCcb5cAHfHr44WcWqWikyV+IW/w73H863vZ3QHw5Yb+QbGCJV45Zm2SLO3ElmaK9VcSzZAMf/3DWyp/DYvCM2AT4H+5f1wjEZgnAtG4mccTwk8XwsBh8gtj0L6Pqfhqu/+g5ULaMIA4+QQGEH+sSPYao50e/2JzU/9GZjXsw7Lw2bktSxfQO/BTv8UUtvwvi6xz4mLiZUiouxCfPKfB5kh+So4WZiylGVn4e7V/Oi49BFdkD2+yjzc/GfZmanwZx8IEf8ypeSZqBVg8+6sokekxQ99ux8tPq34tZLDJSPHKx4YW+HBMDRAGTo04ycAEXxwESCwzgABwYwoEhg1DZEHU4AAcQG6oaHIADQzgwZBCqGlUNDsABxIaqBgfgwBAODBmEqkZVgwNwQBcbfv7WcaECggscaOaA1rDdz8byuyB+Xa+3zc9EfaFrIg4+7fxwQljzw7Hyz2p/JF4RY0Vs9v0oTX42MlVsfV2a9ttyA/xiXxfhhRzBR8cnxeVZPxqrvRWX+6MfY7FRX0cONoJVVCtek6cXlQ5OXCeL4AQ+4BPsocvyrsAP1ZVAy9/G9of7Fx7Hx1hsHl9qv5Cs47hhLC5prPBlPGjESaaGZII/e74W8ifL2cRPysLPam/Fff+pHmx/IzYqQIWb6c8ljlh+oFgeFoMCf632VtznxxGxYRlVrxwezMLNIg5+Dw68iR8uf1PLktAPx+Kn1d6K+/6PiI07ucvPRgZ5E9j+yzI+M48PnHm8nJ+9fjRWeysu+a8f82XUpl5tfjaurXh1+OMTfhq0Bz/Pm/uOBfzxz0et/NgmC2W/nN72Vv9eTI+KDS/05QJsgOjJwHlgBweKHCgGSCBdncEFXOBAGwcQGyoRHIADQzgwZBAqQVslADdw+584gNhQ1eAAHBjCgSGD/E/qzHdhtgEH2jiA2FDV4AAcGMIBfRB+/tZxgZTgAgeaOaA1xM9mWe7qG7iWHwhx/Hje6cfjhBA/m3SNx3YCVcx81QQf8GnZbpHyBj+by3pJQUGM4oeO4IPYNIiNuisbP5sZMjWQiZnPvuxHjNX8UcUm2Ftm8cdqb8V9/+nkYftbeWaz38isY72DuCLLOZBBJYO/GeADPi8oNlnOfrJ5lrorVJuGiaiUjiQTyfSCZEKs6zM7l7/42aSihBghRoiRvipwudKaH0f9Zkr9W+2teJrn8d/5MmpTR/xsvK9KsOZVZ37EfdKAz3v9iNzMz/30LdxN/7kg6/5Y7Y/E/ewzFhrHkVxseKEvx0TDic/ACQ48xYGnTvYVDJDBDQ7AgSc5AGBPAobgKrNhMCSPDnAAkA6AhMAgMHCgnwOIDWIDB+DAEA4MGYSq0F8VwBAMv50DiA1VDQ7AgSEc0Afh528dF0gJLnCgmQNaw3Y/G3cjan4axMEHfsyr80u63xf1LfIefHr9lKz8tPo3hFgRG7d5a74+/hneaJ/FkTVz+hp06qdBPCYY+MR7eeBHHz8kR1Mc5XM5luLp5yk/rfYS14+x2KivMz+xEVPddRq0J76stynAfBd2qQjgAz49/BAete6tsvh3uP8jYvPobFe3bGC9g+gJedYm2eJOXEmmaG8V8SzZwMfnmJU/h8UgncHsuX1a/7pWBFVWTkBs/M29IJbrQrJ7PljJ+O74V4lN/zKq7qfh+o+eA2XLCOLgExRA+PF4fioiYuWPnNe+jKrn3+H+ZeISH4Mbuwem2/aU/LYkU/q4oVd7fwEubvldEF/nwMfFVcJUXIhPnlvg8yQ/JEcLyySfq6W4lZ9H+5fz4mMuNpt6tvnZuC9T89MgDj7wo+w305sf6sokWgbX/Xas8a3+XfvKf3mQF/pyTCoA1sAlVicf+PwWPiQWQgIH4MAQDgwZhAr2WxWM+8391jiA2FDV4AAcGMKBIYNoKsdnVD848FscQGyoanAADgzhwJBBqGC/VcG439zvjAP/AMrZmCd7gQTGAAAAAElFTkSuQmCC)

**Conclusion:**

In conclusion, the experiment was done somewhat successfully since the results obtained in the modelsim step is accurate compared to the theoretical results. We learned and understood all the steps to do a simulation of a register file.This is shown by the Modelsim simulations testing with the DO file for all possible operations and it produced the correct outputs. The lab was successful in designing a complete CPU for simulation. All of the combinations of inputs were tested and the correct outputs were obtained from the Ichache to the D-cache. But the experiment failed while performing synthesis with the Xilinx Vivado from the command line script, it threw an error in the synthesis step saying the architecture of the PC component is not available. I was not able to solve this error in time unfortunately.