## 2. TASKS FROM SweRVref

## TASK: Open file

[RVfpgaPath]/RVfpga/src/SweRVolfSoC/SweRVEh1CoreComplex/include/swerv\_types.sv and analyse it during the next descriptions of the structure types that group together the control bits.

Solution not provided.

<u>TASK</u>: Take a quick look at modules <u>dec\_decode\_ctl</u> and <u>dec\_dec\_ctl</u> to see how the fields of the control signals are assigned based on the 32 bits of the instruction. These two modules are very extensive and quite complex, so the idea is not to analyse them in detail. Moreover, see that module <u>dec\_dec\_ctl</u> is created automatically as explained in lines 2482-2495 of <u>dec\_decode\_ctl.sv</u>.

Solution not provided.

<u>TASK</u>: Analyse the remaining instructions from the loop body in terms of compressed/uncompressed instructions.

The first instruction is in its compressed format: c.lw



 $0x4398 = 010\ 000\ 111\ 00\ 110\ 00$ 

- funct3 =  $010 \rightarrow c.lw$
- $\circ$  imm = 00000
- o rs1 $= 111 \rightarrow x15 = a5$
- o rd = 110  $\rightarrow$  x14 = a4
- $\circ$  op = 00  $\rightarrow$  c.lw

The second instruction is in its compressed format, as we analysed in the SweRVref document.

The third instruction is in its compressed format: c.addi



 $0x0729 = 000 \ 0 \ 01110 \ 01010 \ 01$ 

○ funct3 =  $000 \rightarrow c.addi$ 



2

- o  $rd/rs1 = 01110 \rightarrow x14 = a4$
- $\circ$  imm = 001010  $\rightarrow$  10
- op =  $01 \rightarrow c$ .addi

The fourth and fifth instructions are in their uncompressed formats.

<u>TASK</u>: Take a look inside module **ifu\_compress\_ctl** and try to get an idea about how it works

Solution not provided.