From: kub Date: Sun, 19 May 2024 20:45:44 +0000 (+0000) Subject: sh2 drc, fix conditional immediate for armv7 X-Git-Tag: v2.00~51 X-Git-Url: https://notaz.gp2x.de/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=65b37c5a3b057b3c78c0d9d48f5c4bf93f151039;p=picodrive.git sh2 drc, fix conditional immediate for armv7 --- diff --git a/cpu/drc/emit_arm.c b/cpu/drc/emit_arm.c index d32954e0..ed4732f6 100644 --- a/cpu/drc/emit_arm.c +++ b/cpu/drc/emit_arm.c @@ -425,11 +425,11 @@ static void emith_flush(void) #define EOP_MSR_IMM(ror2,imm) EOP_C_MSR_IMM(A_COND_AL,ror2,imm) #define EOP_MSR_REG(rm) EOP_C_MSR_REG(A_COND_AL,rm) -#define EOP_MOVW(rd,imm) \ - EMIT(0xe3000000 | ((rd)<<12) | ((imm)&0xfff) | (((imm)<<4)&0xf0000), M1(rd), NO) +#define EOP_MOVW(cond,rd,imm) \ + EMIT(((cond)<<28) | 0x03000000 | ((rd)<<12) | ((imm)&0xfff) | (((imm)<<4)&0xf0000), M1(rd), NO) -#define EOP_MOVT(rd,imm) \ - EMIT(0xe3400000 | ((rd)<<12) | (((imm)>>16)&0xfff) | (((imm)>>12)&0xf0000), M1(rd), NO) +#define EOP_MOVT(cond,rd,imm) \ + EMIT(((cond)<<28) | 0x03400000 | ((rd)<<12) | (((imm)>>16)&0xfff) | (((imm)>>12)&0xf0000), M1(rd), NO) // host literal pool; must be significantly smaller than 1024 (max LDR offset = 4096) #define MAX_HOST_LITERALS 128 @@ -486,9 +486,9 @@ static void emith_op_imm2(int cond, int s, int op, int rd, int rn, unsigned int if (op == A_OP_MVN) imm = ~imm; // ...prefer movw/movt - EOP_MOVW(rd, imm); + EOP_MOVW(cond,rd, imm); if (imm & 0xffff0000) - EOP_MOVT(rd, imm); + EOP_MOVT(cond,rd, imm); return; } #else @@ -512,7 +512,7 @@ static void emith_op_imm2(int cond, int s, int op, int rd, int rn, unsigned int EOP_C_DOP_IMM(cond, A_OP_ADD, 0,rd,rd,0,o); else if (o < 0) EOP_C_DOP_IMM(cond, A_OP_SUB, 0,rd,rd,0,-o); - return; + return; } #endif break;