





RISCV is an open source ISA

It is evident that RISCV is a revolution that is disrupting the whole hardware ecosystem.



It opens a can of OPPORTUNITY for us and the RISCV LLVM backend is the "gold standard" for writing LLVM backends.

# Supporting 64 bit pointers in RV32







Adding a new instruction in the RISCV LLVM backend is fairly simple

What to do when you have stepped on the tail of a sleeping dragon? (The legalizer)







Image credits:

Dragon illustration: Vintage vector created by stockgiu - www.freepik.com

Smiley image: The logo belong to the awesome band nirvana

## Selection DAG

#### PerformDAGCombine



This can be used before any DAG Combine giving complete control of the nodes.

**DAG Combine I** 

Type Legalizer

**DAG Combine II** 

Node Legalizer

## Selection DAG

## ReplaceNodeResults



Replaces illegal return type.

## **DAG Combine I**

Type Legalizer

**DAG Combine II** 

Node Legalizer

weakness

resistance

tage teast

## Selection DAG

## LowerOperationWrapper



When the result is legal and operands are illegal.

### DAG Combine I

Type Legalizer

**DAG Combine II** 

Node Legalizer

weakness

resistance:

Televist cost

### Selection DAG

## LowerOperations



When the types are legal

DAG Combine I

Type Legalizer

**DAG Combine II** 

Node Legalizer

