feat(compiler): 启用 ir2mcode 和 sccf2target 库并实现 x86_64 代码生成
- 在 cbuild.toml 中启用 ir2mcode 和 sccf2target 依赖库 - 修改 justfile 中的构建命令,使用 release 模式并更新 tokei 统计排除 mcode 目录 - 重构 LIR 中的地址操作数类型,将 SCC_LIR_INSTR_KIND_ADDR 重命名为 SCC_LIR_INSTR_KIND_MEM - 实现完整的 MIR 到 x86_64 机器码转换,包括: - 添加 move、compare、binary operation 等指令发射函数 - 实现条件分支和跳转指令生成 - 支持算术、逻辑、移位等基本操作 - 添加调用和返回指令处理 - 实现栈分配和寄存器分配功能 - 完善 ir2mcode 模块,将 MIR 指令转换为机器码 - 更新 ir2sccf 模块,集成机器码生成功能 - 添加 mcode 库的架构支持和内存管理功能 - 修复 PE 文件生成中的空指针检查问题
This commit is contained in:
@@ -7,14 +7,37 @@
|
||||
#include <x86/scc_x86_reg.h>
|
||||
|
||||
void mir_x86_to_mcode(scc_mcode_t *mcode, const scc_mir_instr_t *ins) {
|
||||
// scc_x86_operand_value_t ops[8] = {0};
|
||||
// for (int i = 0; i < ins->num_operands; i += 1) {
|
||||
// }
|
||||
scc_x86_encode_inst(mcode, ins->opcode, (void *)&ins->operands);
|
||||
scc_x86_operand_value_t ops[8] = {0};
|
||||
for (int i = 0; i < ins->num_operands; i += 1) {
|
||||
switch (ins->operands[i].kind) {
|
||||
case SCC_MIR_OP_VREG:
|
||||
Panic("can't convert vreg to mcode");
|
||||
break;
|
||||
case SCC_MIR_OP_PREG:
|
||||
ops[i].kind = SCC_X86_OPR_REG;
|
||||
ops[i].reg = ins->operands[i].preg;
|
||||
break;
|
||||
case SCC_MIR_OP_MEM:
|
||||
Panic("can't convert mem to mcode");
|
||||
break;
|
||||
case SCC_MIR_OP_IMM:
|
||||
ops[i].kind = SCC_X86_OPR_IMM;
|
||||
ops[i].imm = ins->operands[i].imm;
|
||||
break;
|
||||
case SCC_MIR_OP_SYMBOL:
|
||||
case SCC_MIR_OP_BLOCK:
|
||||
ops[i].kind = SCC_X86_OPR_RELBR;
|
||||
ops[i].imm = 0;
|
||||
break;
|
||||
default:
|
||||
Panic("unsupported operand kind");
|
||||
};
|
||||
}
|
||||
scc_x86_encode_inst(mcode, ins->opcode, ops);
|
||||
}
|
||||
|
||||
static void scc_emit_mcode(scc_mcode_t *mcode,
|
||||
const scc_mir_instr_t *mir_instr) {
|
||||
void scc_ir2mcode_emit_instr(scc_mcode_t *mcode,
|
||||
const scc_mir_instr_t *mir_instr) {
|
||||
// TODO
|
||||
mir_x86_to_mcode(mcode, mir_instr);
|
||||
}
|
||||
@@ -31,7 +54,7 @@ void scc_ir2mcode(scc_mcode_t *mcode, const scc_mir_module_t *mir_module) {
|
||||
scc_mir_instr_vec_t *instrs = SCC_MIR_BBLOCK_VALUES(bb);
|
||||
scc_vec_foreach(*instrs, i) {
|
||||
const scc_mir_instr_t *ins = &scc_vec_at(*instrs, i);
|
||||
scc_emit_mcode(mcode, ins);
|
||||
scc_ir2mcode_emit_instr(mcode, ins);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user