## 處理器設計與實作

#### 實習講義

編撰者 成大電通所計算機架構與系統研究室CASLAB

國立成功大學電機系與電腦與通信工程研究所

# LAB 5: RISC-V & LLVM RISC-V編譯器實作

#### 大綱

- 1. Compiler 基本概念
- 2. LLVM 基本概念
- 3. 實驗: RISC-V LLVM實作
  - 練習題一
  - 挑戰題

## 實驗目的

- 1. 認識編譯器與程式轉換流程
- 2. 嘗試在編譯器中新增客製化指令並與硬體結合
- 3. 認識編譯器的優化

# Compiler 基本概念

## What is compiler?

Translator between engineer & machine

Make programming easier

Optimize your code



## LLVM 基本概念

#### What is LLVM

- Begin as a research at the University of Illinois
- Modular and reusable compiler and toolchain technologies
- Provide common and simple LLVM IR
- Easier to target new SW and HW





The Institute of Computer and Communication Engineering, NCKU

## LAB 5: RISC-V & LLVM

#### Tool used

### 實驗環境:

#### 1.Linux

- LLVM with RISC-V backend
- RISC-V GNU toolchain

#### 2. Windows

Modelsim

#### Lab 5-1: Custom RISC-V instruction

## Complete instruction definition:

- > ~/Workspace/Tools/Ilvm-project/Ilvm/lib/Target/RISCV/
  - RISCVInstrFormats.td
  - RISCVInstrInfo.td

| Instruction | Funct7 | rs2 | rs1 | xd/xs1/xs2 | rd  | opcode  |
|-------------|--------|-----|-----|------------|-----|---------|
| mac.load    | 1      | 0   | GPR | 011        | 0   | 0001011 |
| mac.rfc0    | 2      | 0   | 0   | 111        | GPR | 0001011 |

```
//=======Custom Instruction=======\\
def OPC_CUSTOM : RISCVOpcode<0b>;
class RVInstR_CUSTOM<br/>dag ins, string opcodestr, string argstr>
    : RVInst<outs, ins, opcodestr, argstr, [], InstFormatR> {
    bits<5> rs2;
    bits<5> rs1;
    bits<5> rd;

let Ins:{-}
    let Ins:{-}
```

```
RISCVInstrFormats.td
```

RISCVInstrInfo.td

#### Lab 5-1: Custom RISC-V instruction

- Re-build LLVM compiler
  - >cd ~/Workspace/Tools/Ilvm-project/build
  - >sudo cmake -build . -target install
- Generate memory file
  - >cp test.c link.ld bin2mem.py ~/Workspace
  - >cd ~/Workspace && sh compile.sh

#### Modelsim驗證

- Copy test.mem to windows under Lab5/
- Open Modelsim and create new project under Lab5/
- Add testhench v & all files in src/\*



#### Modelsim驗證

Compile -> Compile order
Auto Generate



#### Modelsim驗證

- 毌Simulation 選擇 work -> tb\_core\_ut
- Disable optimization



#### 預期結果



## Challenge 挑戰題

- **+** Compile source with/without optimization
  - > cp origin.c ~/Workspace
  - > /opt/RISCV/LLVM/bin/clang -S -emit-llvm -Xclang -disable-O0-optnone origin.c
  - > /opt/RISCV/LLVM/bin/opt -mem2reg -S origin.ll -o opt.ll
- Compare difference between origin.ll & opt.ll

# 實驗結報

- →結報格式(每組一份)
  - ➤ 封面 (第幾組+組員)
  - ➤ 實驗內容(程式碼註解、結果截圖)
  - > 實驗心得
- ◆繳交位置
  - > ftp://140.116.164.225/ port: 21
  - ➤ 帳號/密碼:ca\_lab/Carch2020
  - Deadline: 11/09 18:00pm
- TA Contact Information:
  - ➤ 助教信箱:anita19961013@gmail.com
  - > Lab: 92617
  - Office hour: (Tuesday)8:00pm~10:00pm