### HOMEWORK OF THE SEMESTER IN HLS TITOPOULOS VASILEIOS AEM:57621 DALLAS NIKOLAOS AEM:57338

# **A TINY COMPUTER**

The layout of the computer:



The format of instructions is:



The encodings:

| OP<br>ENCODINGS | ACTIONS                                     | SKIP IF<br>AVAILABLE | CODE<br>ENCODINGS |
|-----------------|---------------------------------------------|----------------------|-------------------|
| 000             | RW<-Function(Ra,Rb)                         | Yes                  | Normal            |
| 001             | DM[Rb]<-Ra, Rw<-Function(Ra,Rb)             | Yes                  | StoreDM           |
| 010             | IM[Rb]<-Ra, Rw<-Function(Ra,Rb)             | Yes                  | StoreIM           |
| 011             | Output_channel<-Ra, Rw<-<br>Function(Ra,Rb) | Yes                  | Output            |
| 100             | Rw <- DM[Rb], ALU <- F(Ra, Rb)              | Yes                  | LoadDM            |
| 101             | Rw<-Input_channel, ALU <- F(Ra, Rb)         | Yes                  | Input             |
| 110             | Rw <- PC + 1, PC <- Function(Ra,<br>Rb)     | No                   | Jump              |
| 111             | Reserved                                    | Yes                  | RsrvdOp           |

As it is presented from the array above, we are unable to have skip if our opcode is Jump.

| SKIP ENCODINGS | ACTIONS                           | CODE ENCODINGS |
|----------------|-----------------------------------|----------------|
| 00             | PC<-PC+1                          | Never          |
| 01             | If ALU<0:PC<-PC+2, else: PC<-PC+1 | IfNegative     |
| 10             | If ALU=0:PC<-PC+2, else: PC<-PC+1 | lfZero         |
| 11             | If ALU>0:PC<-PC+2, else: PC<-PC+1 | IfPositive     |

| SHIFT ENCODINGS | ACTIONS                    |
|-----------------|----------------------------|
| 00              | No shift                   |
| 01              | Right Circular Shift by 1  |
| 10              | Right Circular Shift by 8  |
| 11              | Right Circular Shift by 16 |

| FUNCTION ENCODINGS | ACTIONS  | CODE ENCODINGS |
|--------------------|----------|----------------|
| 000                | A+B      | AplusB         |
| 001                | A-B      | AminusB        |
| 010                | B+1      | Bplusone       |
| 011                | B-1      | Bminusone      |
| 100                | A and B  | AND            |
| 101                | A or B   | OR             |
| 110                | A xor B  | XOR            |
| 111                | Reserved | RsrvdFun       |

| LOAD CONSTANT ENCODINGS | ACTIONS               |
|-------------------------|-----------------------|
| 0                       | Nothing               |
| 1                       | Rw<-Instruction[23:0] |

# **CATAPULT**

## **SETTINGS**

In the architecture, we chose the following specifications for our memories:

InstructionMemory:



#### DataMemory:



#### RegisterFile:



## Clock:1000 MHz

For the mapping we chose a clock of 1 GHz:



## **WITH WRITE TO INSTRUCTION MEMORY**

### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 3:



We were unable to achieve smaller initiation interval with this clock. The error with smaller initiation interval is:

Feedback path is too long to schedule design with current pipeline and clock constraints.

#### **Schedule**



## **QUESTASIM**

The waveforms have the form that is presented below:



```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
    captured 1 values of input
     captured 1 values of output
    captured 27 values of InstructionMemory_IN
   captured 27 values of InstructionMemory
    captured 27 values of DataMemory_IN
    captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
# 'output'
    capture count
    comparison count
                        = 1
   ignore count
                         = 0
   error count
                         = 0
    stuck in dut fifo = 0
    stuck in golden fifo = 0
# 'InstructionMemory'
    capture count
                      = 27
    comparison count
    ignore count
                         = 0
    error count
                         = 0
    stuck in dut fifo = 0
    stuck in golden fifo = 0
# 'DataMemory'
#
    capture count
                      = 27
#
    comparison count
    ignore count
#
                         = 0
#
    error count
                         = 0
    stuck in dut fifo = 0
     stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 85500 ps
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# Info: scverify_top/user_tb: Simulation completed
# ** Warning: (vsim-6614) sc_stop has already been called.
# 1
#
```

### WITHOUT WRITE TO INSTRUCTION MEMORY

#### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 3:



We were unable to achieve smaller initiation interval with this clock. The error with smaller initiation interval is:

Feedback path is too long to schedule design with current pipeline and clock constraints.

#### **Schedule**



#### **QUESTASIM**



```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
    captured 1 values of input
   captured 1 values of output
    captured 27 values of InstructionMemory
    captured 27 values of DataMemory_IN
    captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
# 'output
    capture count
                       = 1
   comparison count
   ignore count
                       = 0
   error count
   stuck in dut fifo = 0
    stuck in golden fifo = 0
# 'DataMemory'
##
   capture count
                       = 27
                        = 27
   comparison count
#
    ignore count
    error count
    stuck in dut fifo = 0
    stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 85500 ps
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# Info: scverify_top/user_tb: Simulation completed
# ** Warning: (vsim-6614) sc_stop has already been called.
# 1
#
```

## Clock:500 MHz

For the mapping we chose a clock of 0.5 GHz:



#### WITH WRITE TO INSTRUCTION MEMORY

#### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 2:



We were unable to achieve smaller initiation interval with this clock. The error with smaller initiation interval is:

```
Feedback path is too long to schedule design with current pipeline and clock constraints.

Schedule failed, sequential delay violated. List of sequential operations and dependencies:

MEMORYWRITE "RISC::memory_write_back:else:switch-lp:write_mem(InstructionMemory:rsc.@)" finalv3.h(162,20,31)

CHANOPERREAD "InstructionMemory:io_sync(InstructionMemory:rsc.triosy)" finalv3.h(202,25,17)

MEMORYREAD "RISC::fetch_decode:instruction:read_mem(InstructionMemory:rsc.@)" finalv3.h(40,39,21)

Feedback path is too long to schedule design with current pipeline and clock constraints.

Design 'RISC' could not schedule partition '/RISC/run' - could not schedule even with unlimited resources
```

#### **Schedule**



#### **QUESTASIM**



```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
   captured 1 values of input
    captured 1 values of output
    captured 27 values of InstructionMemory_IN
    captured 27 values of InstructionMemory
    captured 27 values of DataMemory_IN
    captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
# 'output
    capture count
    comparison count
                         = 1
   ignore count
                         = 0
    error count
                         = 0
    stuck in dut fifo
                       = 0
    stuck in golden fifo = 0
  'InstructionMemory'
    capture count
     comparison count
                         = 0
     ignore count
                         = 0
     error count
     stuck in dut fifo
                        = 0
     stuck in golden fifo = 0
# 'DataMemory'
    capture count
                        = 27
     comparison count
                         = 27
    ignore count
     error count
                         = 0
     stuck in dut fifo
                         = 0
     stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 116 ns
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# 1
```

#### WITHOUT WRITE TO INSTRUCTION MEMORY

#### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 2:



We were unable to achieve smaller initiation interval with this clock. The error with smaller initiation interval is:

- Feedback path is too long to schedule design with current pipeline and clock constraints.
- Schedule failed, sequential delay violated. List of sequential operations and dependencies:
- 8 MEMORYREAD "RISC::fetch decode:instruction:read mem(InstructionMemory:rsc.@)" finalv3.h(40,39,21)
- Feedback path is too long to schedule design with current pipeline and clock constraints.
- Design 'RISC' could not schedule partition '/RISC/run' could not schedule even with unlimited resources

#### Schedule



#### **QUESTASIM**

The waveforms have the form that is presented below:



After our simulation, the transcript of Questasim prints the following messages:

```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
     captured 1 values of input
     captured 1 values of output
    captured 27 values of InstructionMemory
     captured 27 values of DataMemory_IN
     captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
  'output
     capture count
     comparison count
    ignore count
     error count
     stuck in dut fifo
     stuck in golden fifo = 0
  'DataMemory'
                          = 27
     capture count
     comparison count
                          = 27
     ignore count
     error count
                          = 0
     stuck in dut fifo
                         = 0
     stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 116 ns
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# 1
#
```

## Clock:470 MHz

For the mapping we chose a clock of 0.47 GHz:



## **WITH WRITE TO INSTRUCTION MEMORY**

#### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 2:



We were unable to achieve smaller initiation interval with this clock. The error with smaller initiation interval is:

```
Feedback path is too long to schedule design with current pipeline and clock constraints.

Schedule failed, sequential delay violated. List of sequential operations and dependencies:

MEMORYWRITE "RISC::memory_write_back:else:switch-lp:write_mem(InstructionMemory:rsc.@)" finalv3.h(162,20,31)

CHANOPERREAD "InstructionMemory:io_sync(InstructionMemory:rsc.triosy)" finalv3.h(202,25,17)

MEMORYREAD "RISC::fetch_decode:instruction:read_mem(InstructionMemory:rsc.@)" finalv3.h(40,39,21)

Feedback path is too long to schedule design with current pipeline and clock constraints.

Design 'RISC' could not schedule partition '/RISC/run' - could not schedule even with unlimited resources
```

#### Schedule



#### **QUESTASIM**

```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
    captured 1 values of input
    captured 1 values of output
    captured 27 values of InstructionMemory_IN
    captured 27 values of InstructionMemory
    captured 27 values of DataMemory_IN
    captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
# 'output
                       = 1
   capture count
                       = 1
   comparison count
#
                        = 0
    ignore count
#
   error count
                        = 0
#
    stuck in dut fifo
                      = 0
    stuck in golden fifo = 0
# 'InstructionMemory'
                        = 27
    capture count
    comparison count
                       = 27
    ignore count
    error count
                        = 0
    stuck in dut fifo
                      = 0
    stuck in golden fifo = 0
# 'DataMemory'
    capture count
                       = 27
    comparison count
                        = 27
    ignore count
    error count
    stuck in dut fifo
    stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 123065 ps
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# 1
#
```



## WITHOUT WRITE TO INSTRUCTION MEMORY

#### **Initiation Interval**

In the architecture, we chose, for our function, pipeline with initiation interval 1:



#### **Schedule**



#### **QUESTASIM**



```
# Info: Execution of user-supplied C++ testbench 'main()' has completed with exit code = 0
# Info: Collecting data completed
    captured 1 values of input
    captured 1 values of output
    captured 27 values of InstructionMemory
    captured 27 values of DataMemory_IN
    captured 27 values of DataMemory
# Info: scverify_top/user_tb: Simulation completed
# Checking results
# 'output'
                         = 1
    capture count
    comparison count
                         = 0
    ignore count
    error count
                         = 0
    stuck in dut fifo
                         = 0
    stuck in golden fifo = 0
# 'DataMemory
    capture count
    comparison count
    ignore count
                         = 0
    error count
    stuck in dut fifo
    stuck in golden fifo = 0
# Info: scverify_top/user_tb: Simulation PASSED @ 68065 ps
# ** Note: (vsim-6574) SystemC simulation stopped by user.
# 1
#
```

# **REFERENCES**

1. <a href="https://www.cl.cam.ac.uk/teaching/1112/ECAD+Arch/files/Thacker-A Tiny Computer-3.pdf">https://www.cl.cam.ac.uk/teaching/1112/ECAD+Arch/files/Thacker-A Tiny Computer-3.pdf</a>, A Tiny Computer.