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:
@@ -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);
|
||||
|
||||
Reference in New Issue
Block a user