feat(mir): 添加栈偏移操作数类型并重构内存访问表示
- 将 MIR 中的 SCC_MIR_OP_MEM 替换为更精确的 SCC_MIR_OP_STACK_SLOT 和 SCC_MIR_OP_STACK_OFFSET 类型 - 在 x86_64 指令选择中更新相应的内存操作数处理逻辑 - 修改寄存器分配器中的栈槽操作数类型检查 - 更新 IR 转机器码过程中的内存操作数转换 refactor(hir): 使用 tree_dump_node 输出函数节点 - 将 hir_dump 中的函数名输出从 append 改为 node 类型 refactor(frame-layout): 重构栈帧布局传递实现结构 - 引入函数指针实现方式替代直接函数实现 - 将栈帧分配功能集成到 MIR 传递流程中 - 移除独立的 frame_layout 实现文件 refactor(prolog-epilog): 添加函数序言/尾声传递框架 - 为 Windows x64 平台初始化序言/尾声生成器 - 在 MIR 传递阶段添加序言/尾声处理步骤 refactor(win64): 更新 Windows x64 目标平台接口 - 重命名寄存器分配填充函数为 scc_win_pc_x64_reg_alloc_fill - 添加栈帧分配和序言/尾声初始化函数 - 修正参数传递中的栈槽操作数类型 refactor(dump): 改进 MIR 输出格式 - 将基本块显示改为分支节点类型 - 更新操作数类型的显示处理 chore: 添加 x86 编码相关数据结构定义 - 新增 scc_x86_encode.h 头文件包含内存操作数和指令编码接口定义
This commit is contained in:
45
src/main.c
45
src/main.c
@@ -18,6 +18,8 @@
|
||||
#include <sccf2pe.h>
|
||||
|
||||
#include "config.h"
|
||||
void init_platform(void);
|
||||
#define GET_VALID_FP(fp) (fp == nullptr ? scc_stdout : fp)
|
||||
|
||||
static void print_ring(scc_lexer_tok_ring_t *ring, int verbose) {
|
||||
scc_lexer_tok_t tok = {0};
|
||||
@@ -66,10 +68,21 @@ static void print_file(scc_lexer_tok_ring_t *ring, scc_file_t fp) {
|
||||
static void tree_dump_output(const char *str, usize len, void *user) {
|
||||
scc_fprintf(user, "%.*s", (int)len, str);
|
||||
}
|
||||
static inline int mir_dump(scc_file_t fp, scc_mir_module_t *mir_module) {
|
||||
scc_tree_dump_t tree_dump;
|
||||
scc_mir_dump_ctx_t mir_dump_ctx;
|
||||
if (fp == nullptr) {
|
||||
scc_tree_dump_init(&tree_dump, true);
|
||||
} else {
|
||||
scc_tree_dump_init(&tree_dump, false);
|
||||
}
|
||||
scc_mir_dump_init(&mir_dump_ctx, &tree_dump, mir_module);
|
||||
scc_mir_dump_module(&mir_dump_ctx);
|
||||
|
||||
void init_platform(void);
|
||||
|
||||
#define GET_VALID_FP(fp) (fp == nullptr ? scc_stdout : fp)
|
||||
scc_tree_dump_flush(&tree_dump, tree_dump_output, GET_VALID_FP(fp));
|
||||
scc_tree_dump_drop(&tree_dump);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main(int argc, const char **argv, const char **envp) {
|
||||
init_platform();
|
||||
@@ -276,36 +289,20 @@ sstream_drop:
|
||||
|
||||
switch (config.emit_stage) {
|
||||
case SCC_EMIT_STAGE_MIR:
|
||||
goto mir_dump;
|
||||
return mir_dump(fp, &mir_module);
|
||||
case SCC_EMIT_STAGE_MIR_PASS_REG_ALLOC:
|
||||
scc_mir_pass(&mir_module, SCC_MIR_STAGE_REGALLOC);
|
||||
goto mir_dump;
|
||||
return mir_dump(fp, &mir_module);
|
||||
case SCC_EMIT_STAGE_MIR_PASS_FLAME_LAYOUT:
|
||||
scc_mir_pass(&mir_module, SCC_MIR_STAGE_FRAME_LAYOUT);
|
||||
goto mir_dump;
|
||||
return mir_dump(fp, &mir_module);
|
||||
case SCC_EMIT_STAGE_MIR_PASS_PROLOG_EPILOG:
|
||||
scc_mir_pass(&mir_module, SCC_MIR_STAGE_PROLOGUE_EPILOGUE);
|
||||
goto mir_dump;
|
||||
break;
|
||||
return mir_dump(fp, &mir_module);
|
||||
default:
|
||||
scc_mir_pass(&mir_module, SCC_MIR_STAGE_ANY);
|
||||
break;
|
||||
}
|
||||
do {
|
||||
mir_dump:
|
||||
scc_mir_dump_ctx_t mir_dump_ctx;
|
||||
scc_tree_dump_t tree_dump;
|
||||
if (fp == nullptr) {
|
||||
scc_tree_dump_init(&tree_dump, true);
|
||||
} else {
|
||||
scc_tree_dump_init(&tree_dump, false);
|
||||
}
|
||||
scc_mir_dump_init(&mir_dump_ctx, &tree_dump, &mir_module);
|
||||
scc_mir_dump_module(&mir_dump_ctx);
|
||||
|
||||
scc_tree_dump_flush(&tree_dump, tree_dump_output, GET_VALID_FP(fp));
|
||||
scc_tree_dump_drop(&tree_dump);
|
||||
return 0;
|
||||
} while (0);
|
||||
|
||||
if (config.emit_stage == SCC_EMIT_STAGE_FLATBIN) {
|
||||
scc_mcode_t mcode = {0};
|
||||
|
||||
Reference in New Issue
Block a user