## **OBJECTS**

## Generic Header



## Ordinary



#### Long



## Executable



## Immediate (Primitive)



# Immediate (Pointer)



## **POINTERS & DATA**

(in memory)



| j               | 2 31 | 25   | 24  | 17 1  | 6 9  | 8 1  | 0 |
|-----------------|------|------|-----|-------|------|------|---|
| Small Data (w): | 31   |      | in  | nt(30 | (0:  |      | 0 |
| Small Data (h): | 5    | า1(1 | 4:0 | )     | h0(1 | 5:0) | 0 |
| Small Data (b): | 7    | b3   | b   | 2     | b1   | b0   | 0 |

Allocate immediate primitive if:

- sw and rs(30) ≠ rs(31)
- sh at h1 and rs(14) ≠ rs(15)
- sb at b3 and (rs(7) = 1 or rs < 0)

# **REGISTER FILE & PIPELINE**

## Architectural Registers (x0-x31, alc-params):



Tags:

 $\boldsymbol{r}$  read access,  $\boldsymbol{w}$  write access,  $\boldsymbol{u}$  0 when  $\beta$  =  $\lambda$  else 1,  $\boldsymbol{d}$  data only

## Microarchitectural Registers:



# **User Mode Instructions (Single Cycle)**

| Instruction | rd  | rs1 | rs2 | cr | imm | Decision                      |
|-------------|-----|-----|-----|----|-----|-------------------------------|
| lui         | rd  |     |     | -  | imm |                               |
| auipc       | rd  |     |     | -  | imm |                               |
| jal         | rd  |     | sp  | •  | imm |                               |
|             |     |     |     |    |     |                               |
| bcc         |     | rs1 | rs2 | -  | imm |                               |
|             |     |     |     |    |     |                               |
| arithi      | rd  | rs1 |     | -  | imm |                               |
| arith       | rd  | rs1 | rs2 | -  |     |                               |
|             |     |     |     |    |     |                               |
| alc         | rd  | rs1 | ар  | -  | -   |                               |
| alci        | rd  |     | ар  | -  | imm |                               |
| alc.d       | rd  | rs1 | ар  | -  |     |                               |
| alci.d      | rd  |     | ар  | -  | imm |                               |
| qsz         | rd  | rs1 |     | -  | -   |                               |
| clr         | rs1 | rs1 |     | -  | imm | if imm fits in one cache line |
|             |     |     |     |    |     |                               |

# User Mode Instructions (Multi Cycle)

| Inst | ruction      | rd  | rs1 | rs2 | cr | imm | Decision                                |
|------|--------------|-----|-----|-----|----|-----|-----------------------------------------|
| jalr |              | rd  | rs1 |     | -  | imm |                                         |
| Α    | jalr         | rd  | rs1 | sp  | •  | imm | always                                  |
| Α    | lgt          | got | rs1 |     | -  |     | always (instead of nop)                 |
|      |              |     |     |     |    |     |                                         |
| 1b/b | ı/h/hu/w     | rd  | rs1 |     | -  | imm |                                         |
| Α    | lb/bu/h/hu/w | rd  | rs1 | got | •  | imm |                                         |
| a    | lb/bu/h/hu/w | rd  | rd  | got | •  | imm | if A Loaded an immediate pointer        |
|      |              |     |     |     |    |     |                                         |
| sb/h | /w           |     | rs1 | rs2 | -  | imm |                                         |
| Α    | alci.d       | rs1 | rs2 | ар  | •  | 4   | if rs2 is data and does not fit in word |
| В    | alci         | rs1 | rs2 | ар  | •  | 8   | if rs2 is pointer with index ≠ 0        |
| A/B  | sb/h/w       | rs1 | rs1 | rs2 | •  | imm | always                                  |
|      | ·            |     |     |     |    |     |                                         |
| clr  |              | rs1 | rs1 |     | •  | imm | if imm spans multiple cache lines       |
|      |              |     |     |     |    |     |                                         |

## **Supervisor Mode Instructions:**

| Instruction    | rd | rs1 | rs2 | cr | imm | Notes                                                                   |
|----------------|----|-----|-----|----|-----|-------------------------------------------------------------------------|
| sb/h/w.r       |    | rs1 | rs2 | -  | imm | "store raw", allows stores at any point in memory. Uses rs1 as base-ptr |
| lb/bu/h/hu/w.r | rd | rs1 |     | -  |     | "Load raw", same as store raw                                           |
| dtp            | rd | rs1 |     | -  |     | "data to pointer", creates a pointer from data                          |
| ptd            | rd | rs1 |     | -  |     | "pointer to data", extracts base address of pointer as data             |
| itd            | rd | rs1 |     | -  |     | "index to data", extracts index of pointer as data                      |
|                |    |     |     |    |     |                                                                         |
|                |    |     |     |    |     |                                                                         |