- 在 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 文件生成中的空指针检查问题
89 lines
2.8 KiB
C
89 lines
2.8 KiB
C
#ifndef __SCC_MCODE_H__
|
|
#define __SCC_MCODE_H__
|
|
|
|
#include <scc_core.h>
|
|
|
|
typedef enum {
|
|
SCC_MCODE_ARCH_NONE,
|
|
SCC_MCODE_ARCH_X86_64,
|
|
} scc_mcode_arch_t;
|
|
|
|
typedef SCC_VEC(u8) scc_mcode_buff_t;
|
|
typedef struct {
|
|
cbool is_littel_endian;
|
|
scc_mcode_arch_t arch;
|
|
scc_mcode_buff_t mcode;
|
|
} scc_mcode_t;
|
|
|
|
static inline void scc_mcode_init(scc_mcode_t *mcode, scc_mcode_arch_t arch) {
|
|
scc_vec_init(mcode->mcode);
|
|
mcode->arch = arch;
|
|
mcode->is_littel_endian = true;
|
|
}
|
|
|
|
static inline char *scc_mcode_unsafe_data(scc_mcode_t *mcode) {
|
|
return (char *)scc_vec_unsafe_get_data(mcode->mcode);
|
|
}
|
|
|
|
static inline usize scc_mcode_size(scc_mcode_t *mcode) {
|
|
return scc_vec_size(mcode->mcode);
|
|
}
|
|
|
|
static inline void scc_mcode_drop(scc_mcode_t *mcode) {
|
|
scc_vec_free(mcode->mcode);
|
|
mcode->arch = SCC_MCODE_ARCH_NONE;
|
|
mcode->is_littel_endian = true;
|
|
}
|
|
|
|
static inline void scc_mcode_add_u8(scc_mcode_t *mcode, u8 data) {
|
|
scc_vec_push(mcode->mcode, data);
|
|
}
|
|
|
|
static inline void scc_mcode_add_u16(scc_mcode_t *mcode, u16 data) {
|
|
if (mcode->is_littel_endian) {
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
} else {
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
}
|
|
}
|
|
|
|
static inline void scc_mcode_add_u32(scc_mcode_t *mcode, u32 data) {
|
|
if (mcode->is_littel_endian) {
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 16));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 24));
|
|
} else {
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 24));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 16));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
}
|
|
}
|
|
|
|
static inline void scc_mcode_add_u64(scc_mcode_t *mcode, uint64_t data) {
|
|
if (mcode->is_littel_endian) {
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 16));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 24));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 32));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 40));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 48));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 56));
|
|
} else {
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 56));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 48));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 40));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 32));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 24));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 16));
|
|
scc_vec_push(mcode->mcode, (u8)(data >> 8));
|
|
scc_vec_push(mcode->mcode, (u8)(data & 0xFF));
|
|
}
|
|
}
|
|
|
|
#endif /* __SCC_MCODE_H__ */
|