feat(ir): 添加MIR中间表示层并重构LIR相关代码

- 新增mir库模块,包含scc_mir、scc_mir_module、scc_mir_dump等组件
- 添加LIR到MIR的转换接口scc_lir2mir
- 定义MIR操作数类型和指令结构,支持虚拟寄存器、物理寄存器、立即数等
- 实现x86_64指令选择器,将LIR指令转换为MIR指令
- 重构LIR模块中函数参数命名,统一使用lir_module参数名
- 移除LIR中物理寄存器相关的代码和注释
- 更新cbuild.toml依赖配置,添加mir模块依赖
This commit is contained in:
zzy
2026-04-26 17:38:30 +08:00
parent e850b5c981
commit f57ba9bd31
21 changed files with 830 additions and 54 deletions

View File

@@ -1,21 +1,22 @@
#include <scc_lir_module.h>
void scc_lir_module_init(scc_lir_module_t *module) {
void scc_lir_module_init(scc_lir_module_t *lir_module) {
// FIXME
// module->module
// lir_module->lir_module
scc_vec_init(module->func_metas);
scc_vec_init(module->symbol_metas);
scc_vec_init(lir_module->func_metas);
scc_vec_init(lir_module->symbol_metas);
}
void scc_lir_module_drop(scc_lir_module_t *module) {
scc_vec_free(module->func_metas);
scc_vec_free(module->symbol_metas);
void scc_lir_module_drop(scc_lir_module_t *lir_module) {
// FIXME memory leak
scc_vec_free(lir_module->func_metas);
scc_vec_free(lir_module->symbol_metas);
}
scc_lir_symbol_id_t scc_lir_module_add_func_decl(scc_lir_module_t *module,
scc_lir_symbol_id_t scc_lir_module_add_func_decl(scc_lir_module_t *lir_module,
const char *name) {
if (!module || !name)
if (!lir_module || !name)
return SCC_CFG_ID_nullptr;
scc_lir_symbol_meta_t *meta = scc_malloc(sizeof(scc_lir_symbol_meta_t));
@@ -26,21 +27,21 @@ scc_lir_symbol_id_t scc_lir_module_add_func_decl(scc_lir_module_t *module,
.meta = meta};
meta->func.func = nullptr;
scc_vec_push(module->symbol_metas, meta);
scc_vec_push(lir_module->symbol_metas, meta);
scc_cfg_symbol_id_t id =
scc_cfg_module_add_symbol(&module->cfg_module, &sym);
scc_cfg_module_add_symbol(&lir_module->cfg_module, &sym);
if (id == SCC_CFG_ID_nullptr) {
Panic("scc_lir: add func decl '%s' failed", name);
}
return id;
}
scc_lir_symbol_id_t scc_lir_module_add_data(scc_lir_module_t *module,
scc_lir_symbol_id_t scc_lir_module_add_data(scc_lir_module_t *lir_module,
const char *name,
scc_cfg_symbol_kind_t kind,
const u8 *init_data, usize size,
u32 align) {
if (!module || !name)
if (!lir_module || !name)
return SCC_CFG_ID_nullptr;
if (kind != SCC_CFG_SYMBOL_KIND_DATA && kind != SCC_CFG_SYMBOL_KIND_EXTERN)
return SCC_CFG_ID_nullptr;
@@ -67,9 +68,9 @@ scc_lir_symbol_id_t scc_lir_module_add_data(scc_lir_module_t *module,
}
}
scc_vec_push(module->symbol_metas, meta);
scc_vec_push(lir_module->symbol_metas, meta);
scc_cfg_symbol_id_t id =
scc_cfg_module_add_symbol(&module->cfg_module, &sym);
scc_cfg_module_add_symbol(&lir_module->cfg_module, &sym);
if (id = SCC_CFG_ID_nullptr) {
/* 冲突时释放已分配的数据 */
scc_free(meta->data.init_data);