From de29084e8db07d4718408acd0241b1a758df8135 Mon Sep 17 00:00:00 2001 From: tyfkda Date: Wed, 17 Apr 2024 10:49:03 +0900 Subject: [PATCH] Fix assembly --- src/as/arch/aarch64/asm_code.c | 12 ++++++------ src/as/arch/riscv64/asm_code.c | 16 +++++++--------- src/as/arch/x64/asm_code.c | 6 +++--- src/as/arch/x64/ir_asm.c | 1 + 4 files changed, 17 insertions(+), 18 deletions(-) diff --git a/src/as/arch/aarch64/asm_code.c b/src/as/arch/aarch64/asm_code.c index 0752675ea..5b3bf9f28 100644 --- a/src/as/arch/aarch64/asm_code.c +++ b/src/as/arch/aarch64/asm_code.c @@ -17,17 +17,17 @@ #endif void make_code16(Inst *inst, Code *code, unsigned short *buf, int len) { - assert(len <= (int)sizeof(code->buf)); + assert(code->len + len <= (int)sizeof(code->buf)); code->inst = inst; - code->len = len; - memcpy(code->buf, buf, len); + memcpy(code->buf + code->len, buf, len); + code->len += len; } void make_code32(Inst *inst, Code *code, unsigned int *buf, int len) { - assert(len <= (int)sizeof(code->buf)); + assert(code->len + len <= (int)sizeof(code->buf)); code->inst = inst; - code->len = len; - memcpy(code->buf, buf, len); + memcpy(code->buf + code->len, buf, len); + code->len += len; } inline bool assemble_error(const ParseInfo *info, const char *message) { diff --git a/src/as/arch/riscv64/asm_code.c b/src/as/arch/riscv64/asm_code.c index 4cce52bf6..0d8fbe513 100644 --- a/src/as/arch/riscv64/asm_code.c +++ b/src/as/arch/riscv64/asm_code.c @@ -17,17 +17,17 @@ #endif void make_code16(Inst *inst, Code *code, unsigned short *buf, int len) { - assert(len <= (int)sizeof(code->buf)); + assert(code->len + len <= (int)sizeof(code->buf)); code->inst = inst; - code->len = len; - memcpy(code->buf, buf, len); + memcpy(code->buf + code->len, buf, len); + code->len += len; } void make_code32(Inst *inst, Code *code, unsigned int *buf, int len) { - assert(len <= (int)sizeof(code->buf)); + assert(code->len + len <= (int)sizeof(code->buf)); code->inst = inst; - code->len = len; - memcpy(code->buf, buf, len); + memcpy(code->buf + code->len, buf, len); + code->len += len; } inline bool is_im6(int64_t x) { @@ -65,7 +65,7 @@ inline bool assemble_error(const ParseInfo *info, const char *message) { #define C_LUI(rd, imm) MAKE_CODE16(inst, code, 0x6001 | (IMM(imm, 5, 5) << 12) | (rd << 7) | (IMM(imm, 4, 0) << 2)) #define C_ADDI(rd, imm) MAKE_CODE16(inst, code, 0x0001 | (IMM(imm, 5, 5) << 12) | (rd << 7) | (IMM(imm, 4, 0) << 2)) #define C_ADDIW(rd, imm) MAKE_CODE16(inst, code, 0x2001 | (IMM(imm, 5, 5) << 12) | (rd << 7) | (IMM(imm, 4, 0) << 2)) -#define C_LDSP(rd, imm) MAKE_CODE16(inst, code, 0xe002 | (IMM(imm, 5, 5) << 12) | (rd << 7) | (IMM(imm, 4, 3) << 5) | (IMM(imm, 8, 6) << 2)) +#define C_LDSP(rd, imm) MAKE_CODE16(inst, code, 0x6002 | (IMM(imm, 5, 5) << 12) | (rd << 7) | (IMM(imm, 4, 3) << 5) | (IMM(imm, 8, 6) << 2)) #define C_SDSP(rs, imm) MAKE_CODE16(inst, code, 0xe002 | (IMM(imm, 5, 3) << 10) | (IMM(imm, 8, 6) << 7) | (rs << 2)) #define C_JR(rs) MAKE_CODE16(inst, code, 0x8002 | (rs << 7)) @@ -125,7 +125,6 @@ static unsigned char *asm_ld(Inst *inst, Code *code) { int64_t imm = offset != NULL ? offset->fixnum : 0; int base_reg = inst->opr2.indirect.reg.no; if (imm >= 0 && imm < (1 << 9) && (imm & 7) == 0 && base_reg == SP) { - imm >>= 3; C_LDSP(rd, imm); return code->buf; } @@ -140,7 +139,6 @@ static unsigned char *asm_sd(Inst *inst, Code *code) { int64_t imm = offset != NULL ? offset->fixnum : 0; int base_reg = inst->opr2.indirect.reg.no; if (imm >= 0 && imm < (1 << 9) && (imm & 7) == 0 && base_reg == SP) { - imm >>= 3; C_SDSP(rd, imm); return code->buf; } diff --git a/src/as/arch/x64/asm_code.c b/src/as/arch/x64/asm_code.c index 36709ac6a..b6ec0c4a6 100644 --- a/src/as/arch/x64/asm_code.c +++ b/src/as/arch/x64/asm_code.c @@ -25,10 +25,10 @@ static unsigned char *put_code_filtered(unsigned char *p, const short *buf, size } void make_code(Inst *inst, Code *code, unsigned char *buf, int len) { - assert(len <= (int)sizeof(code->buf)); + assert(code->len + len <= (int)sizeof(code->buf)); code->inst = inst; - code->len = len; - memcpy(code->buf, buf, len); + memcpy(code->buf + code->len, buf, len); + code->len += len; } inline char opr_regno(const Reg *reg) { diff --git a/src/as/arch/x64/ir_asm.c b/src/as/arch/x64/ir_asm.c index 456674d55..17fc8f44f 100644 --- a/src/as/arch/x64/ir_asm.c +++ b/src/as/arch/x64/ir_asm.c @@ -167,6 +167,7 @@ static bool make_jmp_long(IR *ir) { Inst *inst = ir->code.inst; // Change to long offset, and recalculate. ir->code.flag |= INST_LONG_OFFSET; + ir->code.len = 0; if (inst->op == JMP) MAKE_CODE(inst, &ir->code, 0xe9, IM32(-1)); else