## RISC-V Lab Ex1: Introduction



#### Content

- 1. Organisation
- 2. Project overview
- 3. Exercise 1: HDL Entry & Simulation
- 4. Group registration

#### Organisation

- 4 students per team
- project : self defined HW (FPGA) / SW (RISC-V) e.g.: real time video & audio, many-core X, networking...

#### **Formals**

- module = lecture + project
- 6 ECTS (<=> \*27.5h / 12 lecture weeks = 14h/week)
- project ET / CS
- see module description for exam details

#### (To) Do's

- 1. 6 assignments **completed in time** (=one week, deadline 2 weeks) walk you through the design flow & build base of your project
- 2. your project's self specified functionality demonstrated on FPGA
- 3. take part in mid- and final presentations (incl. video clip)
- 4. project specification & documentation ("on the go", effort minimized)

#### Support

- /home/rvlab/docs/index.html !!!
- IT (workstations, EDA tools, licenses .. )
  - o Adela Westedt: <u>adela.westedt@tu-berlin.de</u>, 24248, EN435a
  - o Rene Hartman: rene.hartmann@tu-berlin.de, 25351, EN435a
- Marco Liem: marco.liem@campus.tu-berlin.de (-> ZOOM)
- Tobias Kaiser: kaiser@tu-berlin.de, 25561, EN411

# Rvlab Overview Flow (simple) Simulation is king!

(not PCB tinkering)



#### **Rvlab Flow**





#### **Rvlab System**



#### Rvlab Core rvlab\_core rvlab\_cpu irq\_timer irq\_external debug\_req load/ instr. fetch store D xbar\_main tl\_ddr\_o tl\_ddr\_i tl\_host\_i userio\_i user\_o irg\_o bram\_main $\triangleright_{D}$ xbar\_peri rvlab\_debug student tl\_ddr\_ctrl\_o tl\_ddr\_ctrl\_i rv\_timer tl\_device\_peri\_i tl\_device\_peri\_o regdemo

 $H \longleftrightarrow D$ 

#### Exercise 1: Heal Entry & Simulation





#### Register bus read

```
localparam logic [3:0] ADDR_REGA = 4'h0;
localparam logic [3:0] ADDR_REGB = 4'h4;
logic [31:0] regA;
logic [ 7:0] regB;
always_comb begin
  rdata = '0; // !!!
 if (re) begin
    case (addr)
     ADDR_REGA: rdata[31:0] = regA;
                 rdata[ 7:0] = regB;
     ADDR_REGB:
     default: rdata = '0;
    endcase
 end
end
```



#### Register bus write

```
always_ff @(posedge clk_i, negedge rst_ni) begin
 if (~rst_ni) begin
    regA <= 32'h0000AFFE; // reset value</pre>
    regB <= '0; // reset value
  end else begin
   if (we) begin
     case (addr)
       ADDR_REGA: regA <= wdata[31:0];</pre>
        ADDR_REGB: regB <= wdata[ 7:0];
       default: ;
      endcase
    end // if(we)
  end // if (~rst_ni) else
end
```



#### Demo FSM

```
enum logic[1:0] {idle, swap, count} state;
logic [7:0] led;
logic [1:0] cnt;
always_ff @(posedge clk_i, negedge rst_ni)
bemifn(~rst_ni) begin
    state <= idle;</pre>
            <= 8'b10101010;
    led
    cnt
            <= '0;
 end else begin
      case (state)
        idle: begin
          if (regB[0] == 1'b1) begin
            led <= regA[15:8];</pre>
            state <= swap;</pre>
          end
        end
        swap: begin
          led[7:4] <= led[3:0];
          led[3:0] <= led[7:4];
          cnt
                   <= 2'd2;
          state
                   <= count;
        end
```

```
count: begin
    if (cnt != 0)

begin     cnt <= cnt - 1;
    end
    else begin
        state <= idle;
    end
    default: begin
        state <= idle;
    end
    end
    default: begin
        state <= idle;
    end
    end
    endcase;
    end // if (~rst_ni) else
end</pre>
```



#### **Demo FSM**

```
enum logic[1:0] {idle, swap, count} state;
logic [7:0] led;
always_ff @(posedge clk_i, negedge rst_ni) begin
 if (~rst_ni) begin
  state <= idle;
   led <= 8'b10101010;
     case (state)
       idle: begin
        if (regB[0] == 1'b1) begin
          led <= regA[15:8];</pre>
           state <= swap;</pre>
       swap: begin
         led[7:4] <= led[3:0];</pre>
         led[3:0] <= led[7:4];</pre>
          state <= count;
          state <= idle;
         state <= idle;
```

| 1          | ◆ clk          | 1'h1         |          |    |    |       |      |       |   |      |      |      |      |      |      | 1 |
|------------|----------------|--------------|----------|----|----|-------|------|-------|---|------|------|------|------|------|------|---|
|            | rst_n          | 1'h1         |          |    |    |       |      |       |   |      |      |      |      |      |      | Ī |
| #-         | <b>♦</b> addr  | 4'h4         | 4        |    |    | 0     |      | 4     |   |      |      |      |      | 0    |      |   |
| -          | → we           | 1'h1         |          |    |    |       |      |       |   |      |      |      |      |      |      |   |
|            | <b>≁</b> re    | 1'h0         |          |    |    |       |      |       |   |      |      |      |      |      |      |   |
| <b>H</b> - | <b>∜</b> wdata | 32'hffffff01 | ffffff01 |    |    | 0000  | 0000 |       |   |      |      |      |      |      |      |   |
| <b>H</b> - | 👉 rdata        | 32'h00000    | 000000   | 00 |    |       |      |       |   | 0000 | 0001 | 0000 | 0000 |      |      |   |
| <b>H</b> - | ♦ regA         | 32'h12345    | 123456   | 78 |    |       |      |       |   |      |      |      |      |      |      |   |
|            |                | 8'h00        | 00       |    | 01 |       |      |       |   |      |      |      |      |      |      | Ī |
|            | ♦ state        | idle         | idle     |    |    | swap  |      | count | t |      |      |      |      | idle | swap | C |
| <b>.</b>   | <b>→</b> led   | 8'haa        | aa       |    |    | 56    |      | 65    |   |      |      |      |      |      | 56   | 6 |
| ₩.         |                | 2'h0         | 0        |    |    |       |      | 2     |   | 1    |      | 0    |      |      |      | 2 |
|            | <b>梦</b> led   | 8'haa        | aa       |    |    | 56    |      | 65    |   |      |      |      |      |      | 56   | 6 |
|            |                |              |          |    |    | <br>_ |      |       |   |      |      |      |      | _    |      | - |

#### **RTL Simulation with Questa Sim**

- Inputs
  - RTL design in synthesisable HDL
  - test bench in HDL
  - o tcl scripts: wave view formatting (.do), ...
- Outputs
  - value trace of all signals
  - messages from display\$()

flow student\_rlight\_tb.sim\_rtl\_questa

### Hints for Ex.1

- address space ("registers") != physical registers
- handle conflicting writes (HW vs. SW)!
   Suggestions!





#### **Group registration & 1st login**

- 1. Self organize groups of 4 students each
- 2. Each group comes forward & registers
- 3. Each group receives one account for the msc network user: rvlab[01-20] / password:
- 4. Walk to EN4141 / Door code:

or

- i) connect to TUBIT VPN
- ii) log in using wiki.x2go.org
- iii) X2GO server: msclab.msc.tu-berlin.de, desktop: XFCE
- 5. Change password immediately: passwd Detailed instructions for X2GO on ISIS page.

#### **Getting rvlab**

- 1. Log into the msc network using your rvlab?? account.
- 2. Clone the git using your TUBIT account:

```
git clone https://git.tu-berlin.de/msc/rvlab
```

3. Start with the 1st exercise sheet:

firefox /home/rvlab/docs/index.html

(**No** support: If you want to run rvlab on your own machine see rvlab/README.rst.)

#### **Appendix**

#### Kill a dead session on the server

- 1. ssh on the server
- 2. x2golistsessions to list your running sessions and get their ID It will return a string, e.g. 494|slehmann-62-1536514901\_stDXFCE\_dp24|62|mscx2go|...
  The second field is the session ID e.g. "slehmann-62-1536514901\_stDXFCE\_dp24"
- 3. x2goterminate-session slehmann-62-1536514901\_stDXFCE\_dp24