Files
Fig-TreeWalker/src/IR/IR.hpp
2026-02-05 22:20:21 +08:00

62 lines
1.0 KiB
C++

#pragma once
#include <Core/String.hpp>
#include <vector>
#include <cstdint>
namespace Fig::IR
{
using Reg = uint16_t;
using Label = uint32_t;
constexpr Reg INVALID_REG = 0xFFFF;
enum class Op : uint8_t
{
// ---- control ----
Nop,
Jmp,
Br, // conditional branch
Ret,
Call,
// ---- arithmetic ----
Add,
Sub,
Mul,
Div,
// ---- compare ----
Lt,
Le,
Gt,
Ge,
Eq,
// ---- data ----
LoadImm, // immediate -> reg
Mov,
};
struct Inst
{
Op op;
Reg dst; // 结果寄存器
Reg a; // operand a
Reg b; // operand b
int64_t imm; // immediate / jump offset
};
struct Function
{
String name;
uint16_t paramCount;
uint16_t localCount; // 不含参数
uint16_t regCount; // param + locals + temps
std::vector<Inst> code;
};
}; // namespace Fig::IR