

# RISC-V Instruction Set Architecture

why clear output buffer?

what is gcc?

what is compiler?

what is assembly?

What is the design flow

RISC Arch



RTL



Implementation.



Pseudo Instruction.

Base Integer Instr.<sup>w</sup>. RV-64I  
RISC-V 64 bit (Integers) ?

any CPU must contain this.

mulw }  
divw } Multiply extension RV64IM

Together called RV64IM CPU Core.



based on the type of hardware  
of (ARM, x86, RISC etc)

# Single and Double precision floating point extension

flow                      fast.d.s  
fall.d.s          found.s          fm.v. x.d  
                            f.s.d

Together called RVCAIMFO

(sp), a0, ra, s0 etc are Application Binary Interface (ABI) used a lot a.k.a., registers we used in ARM.  
In examples.

## Memory allocation and stack pointer.

64 bit rep. of signed and unsigned integer.

number of inputs to be given.

unknown

"riscv64-unknown-elf-gcc" command not found

Lab 2 of the course ('GCC Compile and disassemble')

This error arises when the RISC-V GCC compiler is not installed or not in your system's PATH

↑

SPELLING MISTAKE IT WAS!!!

# Number Representations

(D01T04)



- Entire 64 bit binary number is called the Doubleword.
  - 32 bit halves are called Word



- Group of 8 bits is byte. In a 64 bit archi., each instruction consists of 8 bytes /doubleword.

8 bits → 1 byte

4 bytes  $\rightarrow$  1 word

2 words → 1 doubleword

↑ There are very important for the implementation of efficient codes in our RISC-V Archi.

In the 64 bit representation, total number of patterns which we can represent are :  $2^{64}$

i.e.,  $0$  to  $(2^{64}-1)$

Range of 64 bit in [0, 18, 446, 744, 073, 709, 551, 615]  
decimal is →

Numbers exceeding this range will cause overflow flag to be set

∴ The no. of unsigned patterns or numbers we can represent in RV64 are (0 to  $2^{64}-1$ )

positive numbers  
↓

[D01T05]

For negative numbers or signed integers, we need to use 2's complement for that.

i.e., Take the positive bit rep.

Invert the 1s and 0s and add 1 to it  
↑ 2's complement.

+2 → 0000 - - - - 010 ←  
-2 → 1111 - - - - 101  
 $(-2)_{dec} = (1111 - - - - 110)_{bin}$  Invert and add 1 for reverse.  
MSB

Note:-

Signed Numbers,

$\oplus^{\text{ue}}$  nos → MSB = '0'

$\ominus^{\text{ue}}$  nos → MSB = '1'

Range of signed range is  $[-2^{63}, 2^{63}-1]$

e.g. for 3 bit it is  $-2^{3-1}, 2^{3-1}-1$   
 $= [-4, 3]$

|   |   | 0, 1, 2, 3 |
|---|---|------------|
| 0 | 0 | 0          |
|   | 1 | 1          |
| 1 | 0 | 0          |
|   | 1 | 1          |
|   | 1 | 2          |
|   | 0 | 3          |
|   | 1 | 4          |
|   | 0 | 5          |
|   | 1 | 6          |
|   | 0 | 7          |
|   | 1 | 8          |

$[-4, -3, -2, -1, 0, 1, 2, 3]$

vim → used to open a c program file in the terminal

↪ → :wq → exit out of the c program file and back to the terminal.

wq  
writes or saves the changes  
q → quits

→ switch from normal to insert mode where you can edit the c program file

↪ → esc → to go back to normal mode.

:q! → quit w/o saving.

Even after changing the power of  $2^n$ , the max value remains same as ours as a 64 bit arch. and/or our data type doesn't go beyond that

[unsigned long long int]

|                        | bytes | specifier |
|------------------------|-------|-----------|
| unsigned int           | 4     | %u        |
| int                    | 4     | %d        |
| unsigned long long int | 8     | %llu      |
| long long int          | 8     | %lld      |