Commit 05ba7d5f3476de8b573aed43229bbcf0ffda4b69
1 parent
786c02f1
A first small step to convert the CRIS translator to TCG.
git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@4057 c046a42c-6fe2-441c-8c8c-71466251a162
Showing
1 changed file
with
312 additions
and
344 deletions
target-cris/translate.c
| 1 | /* | 1 | /* |
| 2 | * CRIS emulation for qemu: main translation routines. | 2 | * CRIS emulation for qemu: main translation routines. |
| 3 | * | 3 | * |
| 4 | - * Copyright (c) 2007 AXIS Communications AB | 4 | + * Copyright (c) 2008 AXIS Communications AB |
| 5 | * Written by Edgar E. Iglesias. | 5 | * Written by Edgar E. Iglesias. |
| 6 | * | 6 | * |
| 7 | * This library is free software; you can redistribute it and/or | 7 | * This library is free software; you can redistribute it and/or |
| @@ -19,28 +19,6 @@ | @@ -19,28 +19,6 @@ | ||
| 19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA | 19 | * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
| 20 | */ | 20 | */ |
| 21 | 21 | ||
| 22 | -/* | ||
| 23 | - * This file implements a CRIS decoder-stage in SW. The decoder translates the | ||
| 24 | - * guest (CRIS) machine-code into host machine code via dyngen using the | ||
| 25 | - * micro-operations described in op.c | ||
| 26 | - * | ||
| 27 | - * The micro-operations for CRIS translation implement a RISC style ISA. | ||
| 28 | - * Note that the micro-operations typically order their operands | ||
| 29 | - * starting with the dst. CRIS asm, does the opposite. | ||
| 30 | - * | ||
| 31 | - * For example the following CRIS code: | ||
| 32 | - * add.d [$r0], $r1 | ||
| 33 | - * | ||
| 34 | - * translates into: | ||
| 35 | - * | ||
| 36 | - * gen_movl_T0_reg(0); // Fetch $r0 into T0 | ||
| 37 | - * gen_load_T0_T0(); // Load T0, @T0 | ||
| 38 | - * gen_movl_reg_T0(1); // Writeback T0 into $r1 | ||
| 39 | - * | ||
| 40 | - * The actual names for the micro-code generators vary but the example | ||
| 41 | - * illustrates the point. | ||
| 42 | - */ | ||
| 43 | - | ||
| 44 | #include <stdarg.h> | 22 | #include <stdarg.h> |
| 45 | #include <stdlib.h> | 23 | #include <stdlib.h> |
| 46 | #include <stdio.h> | 24 | #include <stdio.h> |
| @@ -52,6 +30,7 @@ | @@ -52,6 +30,7 @@ | ||
| 52 | #include "exec-all.h" | 30 | #include "exec-all.h" |
| 53 | #include "disas.h" | 31 | #include "disas.h" |
| 54 | #include "tcg-op.h" | 32 | #include "tcg-op.h" |
| 33 | +#include "helper.h" | ||
| 55 | #include "crisv32-decode.h" | 34 | #include "crisv32-decode.h" |
| 56 | 35 | ||
| 57 | #define CRIS_STATS 0 | 36 | #define CRIS_STATS 0 |
| @@ -82,6 +61,8 @@ | @@ -82,6 +61,8 @@ | ||
| 82 | #define CC_MASK_NZVC 0xf | 61 | #define CC_MASK_NZVC 0xf |
| 83 | #define CC_MASK_RNZV 0x10e | 62 | #define CC_MASK_RNZV 0x10e |
| 84 | 63 | ||
| 64 | +TCGv cpu_env, cpu_T[2]; | ||
| 65 | + | ||
| 85 | /* This is the state at translation time. */ | 66 | /* This is the state at translation time. */ |
| 86 | typedef struct DisasContext { | 67 | typedef struct DisasContext { |
| 87 | CPUState *env; | 68 | CPUState *env; |
| @@ -128,92 +109,6 @@ static void gen_BUG(DisasContext *dc, char *file, int line) | @@ -128,92 +109,6 @@ static void gen_BUG(DisasContext *dc, char *file, int line) | ||
| 128 | cris_prepare_jmp (dc, 0x70000000 + line); | 109 | cris_prepare_jmp (dc, 0x70000000 + line); |
| 129 | } | 110 | } |
| 130 | 111 | ||
| 131 | -/* Table to generate quick moves from T0 onto any register. */ | ||
| 132 | -static GenOpFunc *gen_movl_reg_T0[16] = | ||
| 133 | -{ | ||
| 134 | - gen_op_movl_r0_T0, gen_op_movl_r1_T0, | ||
| 135 | - gen_op_movl_r2_T0, gen_op_movl_r3_T0, | ||
| 136 | - gen_op_movl_r4_T0, gen_op_movl_r5_T0, | ||
| 137 | - gen_op_movl_r6_T0, gen_op_movl_r7_T0, | ||
| 138 | - gen_op_movl_r8_T0, gen_op_movl_r9_T0, | ||
| 139 | - gen_op_movl_r10_T0, gen_op_movl_r11_T0, | ||
| 140 | - gen_op_movl_r12_T0, gen_op_movl_r13_T0, | ||
| 141 | - gen_op_movl_r14_T0, gen_op_movl_r15_T0, | ||
| 142 | -}; | ||
| 143 | -static GenOpFunc *gen_movl_T0_reg[16] = | ||
| 144 | -{ | ||
| 145 | - gen_op_movl_T0_r0, gen_op_movl_T0_r1, | ||
| 146 | - gen_op_movl_T0_r2, gen_op_movl_T0_r3, | ||
| 147 | - gen_op_movl_T0_r4, gen_op_movl_T0_r5, | ||
| 148 | - gen_op_movl_T0_r6, gen_op_movl_T0_r7, | ||
| 149 | - gen_op_movl_T0_r8, gen_op_movl_T0_r9, | ||
| 150 | - gen_op_movl_T0_r10, gen_op_movl_T0_r11, | ||
| 151 | - gen_op_movl_T0_r12, gen_op_movl_T0_r13, | ||
| 152 | - gen_op_movl_T0_r14, gen_op_movl_T0_r15, | ||
| 153 | -}; | ||
| 154 | - | ||
| 155 | -static void noop_write(void) { | ||
| 156 | - /* nop. */ | ||
| 157 | -} | ||
| 158 | - | ||
| 159 | -static void gen_vr_read(void) { | ||
| 160 | - gen_op_movl_T0_im(32); | ||
| 161 | -} | ||
| 162 | - | ||
| 163 | -static void gen_movl_T0_p0(void) { | ||
| 164 | - gen_op_movl_T0_im(0); | ||
| 165 | -} | ||
| 166 | - | ||
| 167 | -static void gen_ccs_read(void) { | ||
| 168 | - gen_op_movl_T0_p13(); | ||
| 169 | -} | ||
| 170 | - | ||
| 171 | -static void gen_ccs_write(void) { | ||
| 172 | - gen_op_movl_p13_T0(); | ||
| 173 | -} | ||
| 174 | - | ||
| 175 | -/* Table to generate quick moves from T0 onto any register. */ | ||
| 176 | -static GenOpFunc *gen_movl_preg_T0[16] = | ||
| 177 | -{ | ||
| 178 | - noop_write, /* bz, not writeable. */ | ||
| 179 | - noop_write, /* vr, not writeable. */ | ||
| 180 | - gen_op_movl_p2_T0, gen_op_movl_p3_T0, | ||
| 181 | - noop_write, /* wz, not writeable. */ | ||
| 182 | - gen_op_movl_p5_T0, | ||
| 183 | - gen_op_movl_p6_T0, gen_op_movl_p7_T0, | ||
| 184 | - noop_write, /* dz, not writeable. */ | ||
| 185 | - gen_op_movl_p9_T0, | ||
| 186 | - gen_op_movl_p10_T0, gen_op_movl_p11_T0, | ||
| 187 | - gen_op_movl_p12_T0, | ||
| 188 | - gen_ccs_write, /* ccs needs special treatment. */ | ||
| 189 | - gen_op_movl_p14_T0, gen_op_movl_p15_T0, | ||
| 190 | -}; | ||
| 191 | -static GenOpFunc *gen_movl_T0_preg[16] = | ||
| 192 | -{ | ||
| 193 | - gen_movl_T0_p0, | ||
| 194 | - gen_vr_read, | ||
| 195 | - gen_op_movl_T0_p2, gen_op_movl_T0_p3, | ||
| 196 | - gen_op_movl_T0_p4, gen_op_movl_T0_p5, | ||
| 197 | - gen_op_movl_T0_p6, gen_op_movl_T0_p7, | ||
| 198 | - gen_op_movl_T0_p8, gen_op_movl_T0_p9, | ||
| 199 | - gen_op_movl_T0_p10, gen_op_movl_T0_p11, | ||
| 200 | - gen_op_movl_T0_p12, | ||
| 201 | - gen_ccs_read, /* ccs needs special treatment. */ | ||
| 202 | - gen_op_movl_T0_p14, gen_op_movl_T0_p15, | ||
| 203 | -}; | ||
| 204 | - | ||
| 205 | -/* We need this table to handle moves with implicit width. */ | ||
| 206 | -int preg_sizes[] = { | ||
| 207 | - 1, /* bz. */ | ||
| 208 | - 1, /* vr. */ | ||
| 209 | - 4, /* pid. */ | ||
| 210 | - 1, /* srs. */ | ||
| 211 | - 2, /* wz. */ | ||
| 212 | - 4, 4, 4, | ||
| 213 | - 4, 4, 4, 4, | ||
| 214 | - 4, 4, 4, 4, | ||
| 215 | -}; | ||
| 216 | - | ||
| 217 | #ifdef CONFIG_USER_ONLY | 112 | #ifdef CONFIG_USER_ONLY |
| 218 | #define GEN_OP_LD(width, reg) \ | 113 | #define GEN_OP_LD(width, reg) \ |
| 219 | void gen_op_ld##width##_T0_##reg (DisasContext *dc) { \ | 114 | void gen_op_ld##width##_T0_##reg (DisasContext *dc) { \ |
| @@ -245,18 +140,112 @@ GEN_OP_ST(w, T0) | @@ -245,18 +140,112 @@ GEN_OP_ST(w, T0) | ||
| 245 | GEN_OP_LD(l, T0) | 140 | GEN_OP_LD(l, T0) |
| 246 | GEN_OP_ST(l, T0) | 141 | GEN_OP_ST(l, T0) |
| 247 | 142 | ||
| 143 | +/* We need this table to handle preg-moves with implicit width. */ | ||
| 144 | +int preg_sizes[] = { | ||
| 145 | + 1, /* bz. */ | ||
| 146 | + 1, /* vr. */ | ||
| 147 | + 4, /* pid. */ | ||
| 148 | + 1, /* srs. */ | ||
| 149 | + 2, /* wz. */ | ||
| 150 | + 4, 4, 4, | ||
| 151 | + 4, 4, 4, 4, | ||
| 152 | + 4, 4, 4, 4, | ||
| 153 | +}; | ||
| 154 | + | ||
| 155 | +#define t_gen_mov_TN_env(tn, member) \ | ||
| 156 | + _t_gen_mov_TN_env((tn), offsetof(CPUState, (member))) | ||
| 157 | +#define t_gen_mov_env_TN(member, tn) \ | ||
| 158 | + _t_gen_mov_env_TN(offsetof(CPUState, (member)), (tn)) | ||
| 159 | + | ||
| 160 | +#define t_gen_mov_TN_reg(tn, regno) \ | ||
| 161 | + _t_gen_mov_TN_env((tn), offsetof(CPUState, regs[regno])) | ||
| 162 | +#define t_gen_mov_reg_TN(regno, tn) \ | ||
| 163 | + _t_gen_mov_env_TN(offsetof(CPUState, regs[regno]), (tn)) | ||
| 164 | + | ||
| 165 | +static inline void _t_gen_mov_TN_env(TCGv tn, int offset) | ||
| 166 | +{ | ||
| 167 | + tcg_gen_ld_tl(tn, cpu_env, offset); | ||
| 168 | +} | ||
| 169 | +static inline void _t_gen_mov_env_TN(int offset, TCGv tn) | ||
| 170 | +{ | ||
| 171 | + tcg_gen_st_tl(tn, cpu_env, offset); | ||
| 172 | +} | ||
| 173 | + | ||
| 174 | +static inline void t_gen_mov_TN_preg(TCGv tn, int r) | ||
| 175 | +{ | ||
| 176 | + if (r == PR_BZ || r == PR_WZ || r == PR_DZ) | ||
| 177 | + tcg_gen_mov_tl(tn, tcg_const_i32(0)); | ||
| 178 | + else if (r == PR_VR) | ||
| 179 | + tcg_gen_mov_tl(tn, tcg_const_i32(32)); | ||
| 180 | + else | ||
| 181 | + tcg_gen_ld_tl(tn, cpu_env, offsetof(CPUState, pregs[r])); | ||
| 182 | +} | ||
| 183 | +static inline void t_gen_mov_preg_TN(int r, TCGv tn) | ||
| 184 | +{ | ||
| 185 | + if (r == PR_BZ || r == PR_WZ || r == PR_DZ) | ||
| 186 | + return; | ||
| 187 | + else | ||
| 188 | + tcg_gen_st_tl(tn, cpu_env, offsetof(CPUState, pregs[r])); | ||
| 189 | +} | ||
| 190 | + | ||
| 191 | +static inline void t_gen_mov_TN_im(TCGv tn, int32_t val) | ||
| 192 | +{ | ||
| 193 | + tcg_gen_movi_tl(tn, val); | ||
| 194 | +} | ||
| 195 | + | ||
| 196 | +static void t_gen_lsl(TCGv d, TCGv a, TCGv b) | ||
| 197 | +{ | ||
| 198 | + int l1; | ||
| 199 | + | ||
| 200 | + l1 = gen_new_label(); | ||
| 201 | + /* Speculative shift. */ | ||
| 202 | + tcg_gen_shl_tl(d, a, b); | ||
| 203 | + tcg_gen_brcond_tl(TCG_COND_LE, b, tcg_const_i32(31), l1); | ||
| 204 | + /* Clear dst if shift operands were to large. */ | ||
| 205 | + tcg_gen_movi_tl(d, 0); | ||
| 206 | + gen_set_label(l1); | ||
| 207 | +} | ||
| 208 | + | ||
| 209 | +static void t_gen_lsr(TCGv d, TCGv a, TCGv b) | ||
| 210 | +{ | ||
| 211 | + int l1; | ||
| 212 | + | ||
| 213 | + l1 = gen_new_label(); | ||
| 214 | + /* Speculative shift. */ | ||
| 215 | + tcg_gen_shr_tl(d, a, b); | ||
| 216 | + tcg_gen_brcond_tl(TCG_COND_LE, b, tcg_const_i32(31), l1); | ||
| 217 | + /* Clear dst if shift operands were to large. */ | ||
| 218 | + tcg_gen_movi_tl(d, 0); | ||
| 219 | + gen_set_label(l1); | ||
| 220 | +} | ||
| 221 | + | ||
| 222 | +static void t_gen_asr(TCGv d, TCGv a, TCGv b) | ||
| 223 | +{ | ||
| 224 | + int l1; | ||
| 225 | + | ||
| 226 | + l1 = gen_new_label(); | ||
| 227 | + /* Speculative shift. */ | ||
| 228 | + tcg_gen_sar_tl(d, a, b); | ||
| 229 | + tcg_gen_brcond_tl(TCG_COND_LE, b, tcg_const_i32(31), l1); | ||
| 230 | + /* Clear dst if shift operands were to large. */ | ||
| 231 | + tcg_gen_movi_tl(d, 0); | ||
| 232 | + tcg_gen_brcond_tl(TCG_COND_LT, b, tcg_const_i32(0x80000000), l1); | ||
| 233 | + tcg_gen_movi_tl(d, 0xffffffff); | ||
| 234 | + gen_set_label(l1); | ||
| 235 | +} | ||
| 236 | + | ||
| 248 | static void gen_goto_tb(DisasContext *dc, int n, target_ulong dest) | 237 | static void gen_goto_tb(DisasContext *dc, int n, target_ulong dest) |
| 249 | { | 238 | { |
| 250 | TranslationBlock *tb; | 239 | TranslationBlock *tb; |
| 251 | tb = dc->tb; | 240 | tb = dc->tb; |
| 252 | if ((tb->pc & TARGET_PAGE_MASK) == (dest & TARGET_PAGE_MASK)) { | 241 | if ((tb->pc & TARGET_PAGE_MASK) == (dest & TARGET_PAGE_MASK)) { |
| 253 | -#if 0 | ||
| 254 | - /* XXX: this code is not finished */ | ||
| 255 | - tcg_gen_goto_tb(n); | ||
| 256 | -#endif | ||
| 257 | - tcg_gen_exit_tb(0); | 242 | + tcg_gen_goto_tb(n); |
| 243 | + tcg_gen_movi_tl(cpu_T[0], dest); | ||
| 244 | + gen_op_movl_pc_T0(); | ||
| 245 | + tcg_gen_exit_tb((long)tb + n); | ||
| 258 | } else { | 246 | } else { |
| 259 | - tcg_gen_exit_tb(0); | 247 | + gen_op_movl_pc_T0(); |
| 248 | + tcg_gen_exit_tb(0); | ||
| 260 | } | 249 | } |
| 261 | } | 250 | } |
| 262 | 251 | ||
| @@ -273,10 +262,22 @@ static int sign_extend(unsigned int val, unsigned int width) | @@ -273,10 +262,22 @@ static int sign_extend(unsigned int val, unsigned int width) | ||
| 273 | return sval; | 262 | return sval; |
| 274 | } | 263 | } |
| 275 | 264 | ||
| 265 | +static inline void cris_clear_x_flag(DisasContext *dc) | ||
| 266 | +{ | ||
| 267 | + TCGv ccs; | ||
| 268 | + | ||
| 269 | + ccs = tcg_temp_new(TCG_TYPE_TL); | ||
| 270 | + | ||
| 271 | + t_gen_mov_TN_preg(ccs, PR_CCS); | ||
| 272 | + tcg_gen_andi_i32(ccs, ccs, ~X_FLAG); | ||
| 273 | + t_gen_mov_preg_TN(PR_CCS, ccs); | ||
| 274 | + dc->flagx_live = 1; | ||
| 275 | + dc->flags_x = 0; | ||
| 276 | +} | ||
| 277 | + | ||
| 276 | static void cris_evaluate_flags(DisasContext *dc) | 278 | static void cris_evaluate_flags(DisasContext *dc) |
| 277 | { | 279 | { |
| 278 | if (!dc->flags_live) { | 280 | if (!dc->flags_live) { |
| 279 | - | ||
| 280 | switch (dc->cc_op) | 281 | switch (dc->cc_op) |
| 281 | { | 282 | { |
| 282 | case CC_OP_MCP: | 283 | case CC_OP_MCP: |
| @@ -373,7 +374,7 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | @@ -373,7 +374,7 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | ||
| 373 | switch (op) | 374 | switch (op) |
| 374 | { | 375 | { |
| 375 | case CC_OP_ADD: | 376 | case CC_OP_ADD: |
| 376 | - gen_op_addl_T0_T1(); | 377 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 377 | /* Extended arithmetics. */ | 378 | /* Extended arithmetics. */ |
| 378 | if (!dc->flagx_live) | 379 | if (!dc->flagx_live) |
| 379 | gen_op_addxl_T0_C(); | 380 | gen_op_addxl_T0_C(); |
| @@ -381,18 +382,18 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | @@ -381,18 +382,18 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | ||
| 381 | gen_op_addxl_T0_C(); | 382 | gen_op_addxl_T0_C(); |
| 382 | break; | 383 | break; |
| 383 | case CC_OP_ADDC: | 384 | case CC_OP_ADDC: |
| 384 | - gen_op_addl_T0_T1(); | 385 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 385 | gen_op_addl_T0_C(); | 386 | gen_op_addl_T0_C(); |
| 386 | break; | 387 | break; |
| 387 | case CC_OP_MCP: | 388 | case CC_OP_MCP: |
| 388 | - gen_op_addl_T0_T1(); | 389 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 389 | gen_op_addl_T0_R(); | 390 | gen_op_addl_T0_R(); |
| 390 | break; | 391 | break; |
| 391 | case CC_OP_SUB: | 392 | case CC_OP_SUB: |
| 392 | - gen_op_negl_T1_T1(); | ||
| 393 | - gen_op_addl_T0_T1(); | 393 | + tcg_gen_sub_tl(cpu_T[1], tcg_const_i32(0), cpu_T[1]); |
| 394 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); | ||
| 394 | /* CRIS flag evaluation needs ~src. */ | 395 | /* CRIS flag evaluation needs ~src. */ |
| 395 | - gen_op_negl_T1_T1(); | 396 | + tcg_gen_sub_tl(cpu_T[1], tcg_const_i32(0), cpu_T[1]); |
| 396 | gen_op_not_T1_T1(); | 397 | gen_op_not_T1_T1(); |
| 397 | 398 | ||
| 398 | /* Extended arithmetics. */ | 399 | /* Extended arithmetics. */ |
| @@ -402,28 +403,30 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | @@ -402,28 +403,30 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | ||
| 402 | gen_op_subxl_T0_C(); | 403 | gen_op_subxl_T0_C(); |
| 403 | break; | 404 | break; |
| 404 | case CC_OP_MOVE: | 405 | case CC_OP_MOVE: |
| 405 | - gen_op_movl_T0_T1(); | 406 | + tcg_gen_mov_tl(cpu_T[0], cpu_T[1]); |
| 406 | break; | 407 | break; |
| 407 | case CC_OP_OR: | 408 | case CC_OP_OR: |
| 408 | - gen_op_orl_T0_T1(); | 409 | + tcg_gen_or_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 409 | break; | 410 | break; |
| 410 | case CC_OP_AND: | 411 | case CC_OP_AND: |
| 411 | - gen_op_andl_T0_T1(); | 412 | + tcg_gen_and_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 412 | break; | 413 | break; |
| 413 | case CC_OP_XOR: | 414 | case CC_OP_XOR: |
| 414 | - gen_op_xorl_T0_T1(); | 415 | + tcg_gen_xor_tl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 415 | break; | 416 | break; |
| 416 | case CC_OP_LSL: | 417 | case CC_OP_LSL: |
| 417 | - gen_op_lsll_T0_T1(); | 418 | + t_gen_lsl(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 418 | break; | 419 | break; |
| 419 | case CC_OP_LSR: | 420 | case CC_OP_LSR: |
| 420 | - gen_op_lsrl_T0_T1(); | 421 | + t_gen_lsr(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 421 | break; | 422 | break; |
| 422 | case CC_OP_ASR: | 423 | case CC_OP_ASR: |
| 423 | - gen_op_asrl_T0_T1(); | 424 | + t_gen_asr(cpu_T[0], cpu_T[0], cpu_T[1]); |
| 424 | break; | 425 | break; |
| 425 | case CC_OP_NEG: | 426 | case CC_OP_NEG: |
| 426 | - gen_op_negl_T0_T1(); | 427 | + /* TCG-FIXME: this is not optimal. Many archs have |
| 428 | + fast neg insns. */ | ||
| 429 | + tcg_gen_sub_tl(cpu_T[0], tcg_const_i32(0), cpu_T[1]); | ||
| 427 | /* Extended arithmetics. */ | 430 | /* Extended arithmetics. */ |
| 428 | gen_op_subxl_T0_C(); | 431 | gen_op_subxl_T0_C(); |
| 429 | break; | 432 | break; |
| @@ -447,10 +450,11 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | @@ -447,10 +450,11 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | ||
| 447 | gen_op_bound_T0_T1(); | 450 | gen_op_bound_T0_T1(); |
| 448 | break; | 451 | break; |
| 449 | case CC_OP_CMP: | 452 | case CC_OP_CMP: |
| 450 | - gen_op_negl_T1_T1(); | ||
| 451 | - gen_op_addl_T0_T1(); | 453 | + tcg_gen_sub_tl(cpu_T[1], tcg_const_i32(0), cpu_T[1]); |
| 454 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); | ||
| 455 | + /* CRIS flag evaluation needs ~src. */ | ||
| 456 | + tcg_gen_sub_tl(cpu_T[1], tcg_const_i32(0), cpu_T[1]); | ||
| 452 | /* CRIS flag evaluation needs ~src. */ | 457 | /* CRIS flag evaluation needs ~src. */ |
| 453 | - gen_op_negl_T1_T1(); | ||
| 454 | gen_op_not_T1_T1(); | 458 | gen_op_not_T1_T1(); |
| 455 | 459 | ||
| 456 | /* Extended arithmetics. */ | 460 | /* Extended arithmetics. */ |
| @@ -467,23 +471,24 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | @@ -467,23 +471,24 @@ static void crisv32_alu_op(DisasContext *dc, int op, int rd, int size) | ||
| 467 | gen_op_update_cc_src_T1(); | 471 | gen_op_update_cc_src_T1(); |
| 468 | 472 | ||
| 469 | if (size == 1) | 473 | if (size == 1) |
| 470 | - gen_op_andl_T0_im(0xff); | 474 | + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], 0xff); |
| 471 | else if (size == 2) | 475 | else if (size == 2) |
| 472 | - gen_op_andl_T0_im(0xffff); | 476 | + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], 0xffff); |
| 477 | + | ||
| 473 | /* Writeback. */ | 478 | /* Writeback. */ |
| 474 | if (writeback) { | 479 | if (writeback) { |
| 475 | if (size == 4) | 480 | if (size == 4) |
| 476 | - gen_movl_reg_T0[rd](); | 481 | + t_gen_mov_reg_TN(rd, cpu_T[0]); |
| 477 | else { | 482 | else { |
| 478 | - gen_op_movl_T1_T0(); | ||
| 479 | - gen_movl_T0_reg[rd](); | 483 | + tcg_gen_mov_tl(cpu_T[1], cpu_T[0]); |
| 484 | + t_gen_mov_TN_reg(cpu_T[0], rd); | ||
| 480 | if (size == 1) | 485 | if (size == 1) |
| 481 | - gen_op_andl_T0_im(~0xff); | 486 | + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], ~0xff); |
| 482 | else | 487 | else |
| 483 | - gen_op_andl_T0_im(~0xffff); | ||
| 484 | - gen_op_orl_T0_T1(); | ||
| 485 | - gen_movl_reg_T0[rd](); | ||
| 486 | - gen_op_movl_T0_T1(); | 488 | + tcg_gen_andi_tl(cpu_T[0], cpu_T[0], ~0xffff); |
| 489 | + tcg_gen_or_tl(cpu_T[0], cpu_T[0], cpu_T[1]); | ||
| 490 | + t_gen_mov_reg_TN(rd, cpu_T[0]); | ||
| 491 | + tcg_gen_mov_tl(cpu_T[0], cpu_T[1]); | ||
| 487 | } | 492 | } |
| 488 | } | 493 | } |
| 489 | if (dc->update_cc) | 494 | if (dc->update_cc) |
| @@ -674,53 +679,21 @@ void gen_store_T0_T1 (DisasContext *dc, unsigned int size) | @@ -674,53 +679,21 @@ void gen_store_T0_T1 (DisasContext *dc, unsigned int size) | ||
| 674 | gen_op_stl_T0_T1(dc); | 679 | gen_op_stl_T0_T1(dc); |
| 675 | } | 680 | } |
| 676 | 681 | ||
| 677 | -/* sign extend T1 according to size. */ | ||
| 678 | -static void gen_sext_T1_T0(int size) | ||
| 679 | -{ | ||
| 680 | - if (size == 1) | ||
| 681 | - gen_op_extb_T1_T0(); | ||
| 682 | - else if (size == 2) | ||
| 683 | - gen_op_extw_T1_T0(); | ||
| 684 | -} | ||
| 685 | - | ||
| 686 | -static void gen_sext_T1_T1(int size) | ||
| 687 | -{ | ||
| 688 | - if (size == 1) | ||
| 689 | - gen_op_extb_T1_T1(); | ||
| 690 | - else if (size == 2) | ||
| 691 | - gen_op_extw_T1_T1(); | ||
| 692 | -} | ||
| 693 | - | ||
| 694 | -static void gen_sext_T0_T0(int size) | ||
| 695 | -{ | ||
| 696 | - if (size == 1) | ||
| 697 | - gen_op_extb_T0_T0(); | ||
| 698 | - else if (size == 2) | ||
| 699 | - gen_op_extw_T0_T0(); | ||
| 700 | -} | ||
| 701 | - | ||
| 702 | -static void gen_zext_T0_T0(int size) | ||
| 703 | -{ | ||
| 704 | - if (size == 1) | ||
| 705 | - gen_op_zextb_T0_T0(); | ||
| 706 | - else if (size == 2) | ||
| 707 | - gen_op_zextw_T0_T0(); | ||
| 708 | -} | ||
| 709 | - | ||
| 710 | -static void gen_zext_T1_T0(int size) | 682 | +static inline void t_gen_sext(TCGv d, TCGv s, int size) |
| 711 | { | 683 | { |
| 712 | if (size == 1) | 684 | if (size == 1) |
| 713 | - gen_op_zextb_T1_T0(); | 685 | + tcg_gen_ext8s_i32(d, s); |
| 714 | else if (size == 2) | 686 | else if (size == 2) |
| 715 | - gen_op_zextw_T1_T0(); | 687 | + tcg_gen_ext16s_i32(d, s); |
| 716 | } | 688 | } |
| 717 | 689 | ||
| 718 | -static void gen_zext_T1_T1(int size) | 690 | +static inline void t_gen_zext(TCGv d, TCGv s, int size) |
| 719 | { | 691 | { |
| 692 | + /* TCG-FIXME: this is not optimal. Many archs have fast zext insns. */ | ||
| 720 | if (size == 1) | 693 | if (size == 1) |
| 721 | - gen_op_zextb_T1_T1(); | 694 | + tcg_gen_andi_i32(d, s, 0xff); |
| 722 | else if (size == 2) | 695 | else if (size == 2) |
| 723 | - gen_op_zextw_T1_T1(); | 696 | + tcg_gen_andi_i32(d, s, 0xffff); |
| 724 | } | 697 | } |
| 725 | 698 | ||
| 726 | #if DISAS_CRIS | 699 | #if DISAS_CRIS |
| @@ -758,21 +731,20 @@ static void do_postinc (DisasContext *dc, int size) | @@ -758,21 +731,20 @@ static void do_postinc (DisasContext *dc, int size) | ||
| 758 | { | 731 | { |
| 759 | if (!dc->postinc) | 732 | if (!dc->postinc) |
| 760 | return; | 733 | return; |
| 761 | - gen_movl_T0_reg[dc->op1](); | 734 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 762 | gen_op_addl_T0_im(size); | 735 | gen_op_addl_T0_im(size); |
| 763 | - gen_movl_reg_T0[dc->op1](); | 736 | + t_gen_mov_reg_TN(dc->op1, cpu_T[0]); |
| 764 | } | 737 | } |
| 765 | 738 | ||
| 766 | 739 | ||
| 767 | static void dec_prep_move_r(DisasContext *dc, int rs, int rd, | 740 | static void dec_prep_move_r(DisasContext *dc, int rs, int rd, |
| 768 | int size, int s_ext) | 741 | int size, int s_ext) |
| 769 | { | 742 | { |
| 770 | - gen_movl_T0_reg[rs](); | ||
| 771 | - gen_op_movl_T1_T0(); | 743 | + t_gen_mov_TN_reg(cpu_T[1], rs); |
| 772 | if (s_ext) | 744 | if (s_ext) |
| 773 | - gen_sext_T1_T1(size); | 745 | + t_gen_sext(cpu_T[1], cpu_T[1], size); |
| 774 | else | 746 | else |
| 775 | - gen_zext_T1_T1(size); | 747 | + t_gen_zext(cpu_T[1], cpu_T[1], size); |
| 776 | } | 748 | } |
| 777 | 749 | ||
| 778 | /* Prepare T0 and T1 for a register alu operation. | 750 | /* Prepare T0 and T1 for a register alu operation. |
| @@ -783,11 +755,11 @@ static void dec_prep_alu_r(DisasContext *dc, int rs, int rd, | @@ -783,11 +755,11 @@ static void dec_prep_alu_r(DisasContext *dc, int rs, int rd, | ||
| 783 | { | 755 | { |
| 784 | dec_prep_move_r(dc, rs, rd, size, s_ext); | 756 | dec_prep_move_r(dc, rs, rd, size, s_ext); |
| 785 | 757 | ||
| 786 | - gen_movl_T0_reg[rd](); | 758 | + t_gen_mov_TN_reg(cpu_T[0], rd); |
| 787 | if (s_ext) | 759 | if (s_ext) |
| 788 | - gen_sext_T0_T0(size); | 760 | + t_gen_sext(cpu_T[0], cpu_T[0], size); |
| 789 | else | 761 | else |
| 790 | - gen_zext_T0_T0(size); | 762 | + t_gen_zext(cpu_T[0], cpu_T[0], size); |
| 791 | } | 763 | } |
| 792 | 764 | ||
| 793 | /* Prepare T0 and T1 for a memory + alu operation. | 765 | /* Prepare T0 and T1 for a memory + alu operation. |
| @@ -823,20 +795,20 @@ static int dec_prep_alu_m(DisasContext *dc, int s_ext, int memsize) | @@ -823,20 +795,20 @@ static int dec_prep_alu_m(DisasContext *dc, int s_ext, int memsize) | ||
| 823 | } | 795 | } |
| 824 | DIS(fprintf (logfile, "imm=%x rd=%d sext=%d ms=%d\n", | 796 | DIS(fprintf (logfile, "imm=%x rd=%d sext=%d ms=%d\n", |
| 825 | imm, rd, s_ext, memsize)); | 797 | imm, rd, s_ext, memsize)); |
| 826 | - gen_op_movl_T1_im (imm); | 798 | + tcg_gen_movi_tl(cpu_T[1], imm); |
| 827 | dc->postinc = 0; | 799 | dc->postinc = 0; |
| 828 | } else { | 800 | } else { |
| 829 | - gen_movl_T0_reg[rs](); | 801 | + t_gen_mov_TN_reg(cpu_T[0], rs); |
| 830 | gen_load_T0_T0(dc, memsize, 0); | 802 | gen_load_T0_T0(dc, memsize, 0); |
| 831 | - gen_op_movl_T1_T0(); | 803 | + tcg_gen_mov_tl(cpu_T[1], cpu_T[0]); |
| 832 | if (s_ext) | 804 | if (s_ext) |
| 833 | - gen_sext_T1_T1(memsize); | 805 | + t_gen_sext(cpu_T[1], cpu_T[1], memsize); |
| 834 | else | 806 | else |
| 835 | - gen_zext_T1_T1(memsize); | 807 | + t_gen_zext(cpu_T[1], cpu_T[1], memsize); |
| 836 | } | 808 | } |
| 837 | 809 | ||
| 838 | /* put dest in T0. */ | 810 | /* put dest in T0. */ |
| 839 | - gen_movl_T0_reg[rd](); | 811 | + t_gen_mov_TN_reg(cpu_T[0], rd); |
| 840 | return insn_len; | 812 | return insn_len; |
| 841 | } | 813 | } |
| 842 | 814 | ||
| @@ -882,8 +854,8 @@ static unsigned int dec_addoq(DisasContext *dc) | @@ -882,8 +854,8 @@ static unsigned int dec_addoq(DisasContext *dc) | ||
| 882 | DIS(fprintf (logfile, "addoq %d, $r%u\n", imm, dc->op2)); | 854 | DIS(fprintf (logfile, "addoq %d, $r%u\n", imm, dc->op2)); |
| 883 | cris_cc_mask(dc, 0); | 855 | cris_cc_mask(dc, 0); |
| 884 | /* Fetch register operand, */ | 856 | /* Fetch register operand, */ |
| 885 | - gen_movl_T0_reg[dc->op2](); | ||
| 886 | - gen_op_movl_T1_im(imm); | 857 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 858 | + tcg_gen_movi_tl(cpu_T[1], imm); | ||
| 887 | crisv32_alu_op(dc, CC_OP_ADD, R_ACR, 4); | 859 | crisv32_alu_op(dc, CC_OP_ADD, R_ACR, 4); |
| 888 | return 2; | 860 | return 2; |
| 889 | } | 861 | } |
| @@ -895,8 +867,8 @@ static unsigned int dec_addq(DisasContext *dc) | @@ -895,8 +867,8 @@ static unsigned int dec_addq(DisasContext *dc) | ||
| 895 | 867 | ||
| 896 | cris_cc_mask(dc, CC_MASK_NZVC); | 868 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 897 | /* Fetch register operand, */ | 869 | /* Fetch register operand, */ |
| 898 | - gen_movl_T0_reg[dc->op2](); | ||
| 899 | - gen_op_movl_T1_im(dc->op1); | 870 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 871 | + tcg_gen_movi_tl(cpu_T[1], dc->op1); | ||
| 900 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); | 872 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); |
| 901 | return 2; | 873 | return 2; |
| 902 | } | 874 | } |
| @@ -908,10 +880,9 @@ static unsigned int dec_moveq(DisasContext *dc) | @@ -908,10 +880,9 @@ static unsigned int dec_moveq(DisasContext *dc) | ||
| 908 | imm = sign_extend(dc->op1, 5); | 880 | imm = sign_extend(dc->op1, 5); |
| 909 | DIS(fprintf (logfile, "moveq %d, $r%u\n", imm, dc->op2)); | 881 | DIS(fprintf (logfile, "moveq %d, $r%u\n", imm, dc->op2)); |
| 910 | 882 | ||
| 911 | - cris_cc_mask(dc, 0); | ||
| 912 | - gen_op_movl_T1_im(imm); | ||
| 913 | - crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); | ||
| 914 | - | 883 | + t_gen_mov_reg_TN(dc->op2, tcg_const_i32(imm)); |
| 884 | + if (!dc->flagx_live || dc->flags_x) | ||
| 885 | + cris_clear_x_flag(dc); | ||
| 915 | return 2; | 886 | return 2; |
| 916 | } | 887 | } |
| 917 | static unsigned int dec_subq(DisasContext *dc) | 888 | static unsigned int dec_subq(DisasContext *dc) |
| @@ -922,8 +893,8 @@ static unsigned int dec_subq(DisasContext *dc) | @@ -922,8 +893,8 @@ static unsigned int dec_subq(DisasContext *dc) | ||
| 922 | 893 | ||
| 923 | cris_cc_mask(dc, CC_MASK_NZVC); | 894 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 924 | /* Fetch register operand, */ | 895 | /* Fetch register operand, */ |
| 925 | - gen_movl_T0_reg[dc->op2](); | ||
| 926 | - gen_op_movl_T1_im(dc->op1); | 896 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 897 | + t_gen_mov_TN_im(cpu_T[1], dc->op1); | ||
| 927 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); | 898 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); |
| 928 | return 2; | 899 | return 2; |
| 929 | } | 900 | } |
| @@ -935,8 +906,8 @@ static unsigned int dec_cmpq(DisasContext *dc) | @@ -935,8 +906,8 @@ static unsigned int dec_cmpq(DisasContext *dc) | ||
| 935 | 906 | ||
| 936 | DIS(fprintf (logfile, "cmpq %d, $r%d\n", imm, dc->op2)); | 907 | DIS(fprintf (logfile, "cmpq %d, $r%d\n", imm, dc->op2)); |
| 937 | cris_cc_mask(dc, CC_MASK_NZVC); | 908 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 938 | - gen_movl_T0_reg[dc->op2](); | ||
| 939 | - gen_op_movl_T1_im(imm); | 909 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 910 | + t_gen_mov_TN_im(cpu_T[1], imm); | ||
| 940 | crisv32_alu_op(dc, CC_OP_CMP, dc->op2, 4); | 911 | crisv32_alu_op(dc, CC_OP_CMP, dc->op2, 4); |
| 941 | return 2; | 912 | return 2; |
| 942 | } | 913 | } |
| @@ -948,8 +919,8 @@ static unsigned int dec_andq(DisasContext *dc) | @@ -948,8 +919,8 @@ static unsigned int dec_andq(DisasContext *dc) | ||
| 948 | 919 | ||
| 949 | DIS(fprintf (logfile, "andq %d, $r%d\n", imm, dc->op2)); | 920 | DIS(fprintf (logfile, "andq %d, $r%d\n", imm, dc->op2)); |
| 950 | cris_cc_mask(dc, CC_MASK_NZ); | 921 | cris_cc_mask(dc, CC_MASK_NZ); |
| 951 | - gen_movl_T0_reg[dc->op2](); | ||
| 952 | - gen_op_movl_T1_im(imm); | 922 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 923 | + t_gen_mov_TN_im(cpu_T[1], imm); | ||
| 953 | crisv32_alu_op(dc, CC_OP_AND, dc->op2, 4); | 924 | crisv32_alu_op(dc, CC_OP_AND, dc->op2, 4); |
| 954 | return 2; | 925 | return 2; |
| 955 | } | 926 | } |
| @@ -960,8 +931,8 @@ static unsigned int dec_orq(DisasContext *dc) | @@ -960,8 +931,8 @@ static unsigned int dec_orq(DisasContext *dc) | ||
| 960 | imm = sign_extend(dc->op1, 5); | 931 | imm = sign_extend(dc->op1, 5); |
| 961 | DIS(fprintf (logfile, "orq %d, $r%d\n", imm, dc->op2)); | 932 | DIS(fprintf (logfile, "orq %d, $r%d\n", imm, dc->op2)); |
| 962 | cris_cc_mask(dc, CC_MASK_NZ); | 933 | cris_cc_mask(dc, CC_MASK_NZ); |
| 963 | - gen_movl_T0_reg[dc->op2](); | ||
| 964 | - gen_op_movl_T1_im(imm); | 934 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 935 | + t_gen_mov_TN_im(cpu_T[1], imm); | ||
| 965 | crisv32_alu_op(dc, CC_OP_OR, dc->op2, 4); | 936 | crisv32_alu_op(dc, CC_OP_OR, dc->op2, 4); |
| 966 | return 2; | 937 | return 2; |
| 967 | } | 938 | } |
| @@ -970,8 +941,8 @@ static unsigned int dec_btstq(DisasContext *dc) | @@ -970,8 +941,8 @@ static unsigned int dec_btstq(DisasContext *dc) | ||
| 970 | dc->op1 = EXTRACT_FIELD(dc->ir, 0, 4); | 941 | dc->op1 = EXTRACT_FIELD(dc->ir, 0, 4); |
| 971 | DIS(fprintf (logfile, "btstq %u, $r%d\n", dc->op1, dc->op2)); | 942 | DIS(fprintf (logfile, "btstq %u, $r%d\n", dc->op1, dc->op2)); |
| 972 | cris_cc_mask(dc, CC_MASK_NZ); | 943 | cris_cc_mask(dc, CC_MASK_NZ); |
| 973 | - gen_movl_T0_reg[dc->op2](); | ||
| 974 | - gen_op_movl_T1_im(dc->op1); | 944 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 945 | + t_gen_mov_TN_im(cpu_T[1], dc->op1); | ||
| 975 | crisv32_alu_op(dc, CC_OP_BTST, dc->op2, 4); | 946 | crisv32_alu_op(dc, CC_OP_BTST, dc->op2, 4); |
| 976 | 947 | ||
| 977 | cris_update_cc_op(dc, CC_OP_FLAGS); | 948 | cris_update_cc_op(dc, CC_OP_FLAGS); |
| @@ -984,8 +955,8 @@ static unsigned int dec_asrq(DisasContext *dc) | @@ -984,8 +955,8 @@ static unsigned int dec_asrq(DisasContext *dc) | ||
| 984 | dc->op1 = EXTRACT_FIELD(dc->ir, 0, 4); | 955 | dc->op1 = EXTRACT_FIELD(dc->ir, 0, 4); |
| 985 | DIS(fprintf (logfile, "asrq %u, $r%d\n", dc->op1, dc->op2)); | 956 | DIS(fprintf (logfile, "asrq %u, $r%d\n", dc->op1, dc->op2)); |
| 986 | cris_cc_mask(dc, CC_MASK_NZ); | 957 | cris_cc_mask(dc, CC_MASK_NZ); |
| 987 | - gen_movl_T0_reg[dc->op2](); | ||
| 988 | - gen_op_movl_T1_im(dc->op1); | 958 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 959 | + t_gen_mov_TN_im(cpu_T[1], dc->op1); | ||
| 989 | crisv32_alu_op(dc, CC_OP_ASR, dc->op2, 4); | 960 | crisv32_alu_op(dc, CC_OP_ASR, dc->op2, 4); |
| 990 | return 2; | 961 | return 2; |
| 991 | } | 962 | } |
| @@ -995,8 +966,8 @@ static unsigned int dec_lslq(DisasContext *dc) | @@ -995,8 +966,8 @@ static unsigned int dec_lslq(DisasContext *dc) | ||
| 995 | DIS(fprintf (logfile, "lslq %u, $r%d\n", dc->op1, dc->op2)); | 966 | DIS(fprintf (logfile, "lslq %u, $r%d\n", dc->op1, dc->op2)); |
| 996 | 967 | ||
| 997 | cris_cc_mask(dc, CC_MASK_NZ); | 968 | cris_cc_mask(dc, CC_MASK_NZ); |
| 998 | - gen_movl_T0_reg[dc->op2](); | ||
| 999 | - gen_op_movl_T1_im(dc->op1); | 969 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 970 | + t_gen_mov_TN_im(cpu_T[1], dc->op1); | ||
| 1000 | crisv32_alu_op(dc, CC_OP_LSL, dc->op2, 4); | 971 | crisv32_alu_op(dc, CC_OP_LSL, dc->op2, 4); |
| 1001 | return 2; | 972 | return 2; |
| 1002 | } | 973 | } |
| @@ -1006,8 +977,8 @@ static unsigned int dec_lsrq(DisasContext *dc) | @@ -1006,8 +977,8 @@ static unsigned int dec_lsrq(DisasContext *dc) | ||
| 1006 | DIS(fprintf (logfile, "lsrq %u, $r%d\n", dc->op1, dc->op2)); | 977 | DIS(fprintf (logfile, "lsrq %u, $r%d\n", dc->op1, dc->op2)); |
| 1007 | 978 | ||
| 1008 | cris_cc_mask(dc, CC_MASK_NZ); | 979 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1009 | - gen_movl_T0_reg[dc->op2](); | ||
| 1010 | - gen_op_movl_T1_im(dc->op1); | 980 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 981 | + t_gen_mov_TN_im(cpu_T[1], dc->op1); | ||
| 1011 | crisv32_alu_op(dc, CC_OP_LSR, dc->op2, 4); | 982 | crisv32_alu_op(dc, CC_OP_LSR, dc->op2, 4); |
| 1012 | return 2; | 983 | return 2; |
| 1013 | } | 984 | } |
| @@ -1075,7 +1046,7 @@ static unsigned int dec_lsl_r(DisasContext *dc) | @@ -1075,7 +1046,7 @@ static unsigned int dec_lsl_r(DisasContext *dc) | ||
| 1075 | memsize_char(size), dc->op1, dc->op2)); | 1046 | memsize_char(size), dc->op1, dc->op2)); |
| 1076 | cris_cc_mask(dc, CC_MASK_NZ); | 1047 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1077 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); | 1048 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); |
| 1078 | - gen_op_andl_T1_im(63); | 1049 | + tcg_gen_andi_tl(cpu_T[1], cpu_T[1], 63); |
| 1079 | crisv32_alu_op(dc, CC_OP_LSL, dc->op2, size); | 1050 | crisv32_alu_op(dc, CC_OP_LSL, dc->op2, size); |
| 1080 | return 2; | 1051 | return 2; |
| 1081 | } | 1052 | } |
| @@ -1088,7 +1059,7 @@ static unsigned int dec_lsr_r(DisasContext *dc) | @@ -1088,7 +1059,7 @@ static unsigned int dec_lsr_r(DisasContext *dc) | ||
| 1088 | memsize_char(size), dc->op1, dc->op2)); | 1059 | memsize_char(size), dc->op1, dc->op2)); |
| 1089 | cris_cc_mask(dc, CC_MASK_NZ); | 1060 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1090 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); | 1061 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); |
| 1091 | - gen_op_andl_T1_im(63); | 1062 | + tcg_gen_andi_tl(cpu_T[1], cpu_T[1], 63); |
| 1092 | crisv32_alu_op(dc, CC_OP_LSR, dc->op2, size); | 1063 | crisv32_alu_op(dc, CC_OP_LSR, dc->op2, size); |
| 1093 | return 2; | 1064 | return 2; |
| 1094 | } | 1065 | } |
| @@ -1101,7 +1072,7 @@ static unsigned int dec_asr_r(DisasContext *dc) | @@ -1101,7 +1072,7 @@ static unsigned int dec_asr_r(DisasContext *dc) | ||
| 1101 | memsize_char(size), dc->op1, dc->op2)); | 1072 | memsize_char(size), dc->op1, dc->op2)); |
| 1102 | cris_cc_mask(dc, CC_MASK_NZ); | 1073 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1103 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 1); | 1074 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 1); |
| 1104 | - gen_op_andl_T1_im(63); | 1075 | + tcg_gen_andi_tl(cpu_T[1], cpu_T[1], 63); |
| 1105 | crisv32_alu_op(dc, CC_OP_ASR, dc->op2, size); | 1076 | crisv32_alu_op(dc, CC_OP_ASR, dc->op2, size); |
| 1106 | return 2; | 1077 | return 2; |
| 1107 | } | 1078 | } |
| @@ -1114,7 +1085,7 @@ static unsigned int dec_muls_r(DisasContext *dc) | @@ -1114,7 +1085,7 @@ static unsigned int dec_muls_r(DisasContext *dc) | ||
| 1114 | memsize_char(size), dc->op1, dc->op2)); | 1085 | memsize_char(size), dc->op1, dc->op2)); |
| 1115 | cris_cc_mask(dc, CC_MASK_NZV); | 1086 | cris_cc_mask(dc, CC_MASK_NZV); |
| 1116 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 1); | 1087 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 1); |
| 1117 | - gen_sext_T0_T0(size); | 1088 | + t_gen_sext(cpu_T[0], cpu_T[0], size); |
| 1118 | crisv32_alu_op(dc, CC_OP_MULS, dc->op2, 4); | 1089 | crisv32_alu_op(dc, CC_OP_MULS, dc->op2, 4); |
| 1119 | return 2; | 1090 | return 2; |
| 1120 | } | 1091 | } |
| @@ -1127,7 +1098,7 @@ static unsigned int dec_mulu_r(DisasContext *dc) | @@ -1127,7 +1098,7 @@ static unsigned int dec_mulu_r(DisasContext *dc) | ||
| 1127 | memsize_char(size), dc->op1, dc->op2)); | 1098 | memsize_char(size), dc->op1, dc->op2)); |
| 1128 | cris_cc_mask(dc, CC_MASK_NZV); | 1099 | cris_cc_mask(dc, CC_MASK_NZV); |
| 1129 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); | 1100 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); |
| 1130 | - gen_zext_T0_T0(size); | 1101 | + t_gen_zext(cpu_T[0], cpu_T[0], size); |
| 1131 | crisv32_alu_op(dc, CC_OP_MULU, dc->op2, 4); | 1102 | crisv32_alu_op(dc, CC_OP_MULU, dc->op2, 4); |
| 1132 | return 2; | 1103 | return 2; |
| 1133 | } | 1104 | } |
| @@ -1137,9 +1108,8 @@ static unsigned int dec_dstep_r(DisasContext *dc) | @@ -1137,9 +1108,8 @@ static unsigned int dec_dstep_r(DisasContext *dc) | ||
| 1137 | { | 1108 | { |
| 1138 | DIS(fprintf (logfile, "dstep $r%u, $r%u\n", dc->op1, dc->op2)); | 1109 | DIS(fprintf (logfile, "dstep $r%u, $r%u\n", dc->op1, dc->op2)); |
| 1139 | cris_cc_mask(dc, CC_MASK_NZ); | 1110 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1140 | - gen_movl_T0_reg[dc->op1](); | ||
| 1141 | - gen_op_movl_T1_T0(); | ||
| 1142 | - gen_movl_T0_reg[dc->op2](); | 1111 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); |
| 1112 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); | ||
| 1143 | crisv32_alu_op(dc, CC_OP_DSTEP, dc->op2, 4); | 1113 | crisv32_alu_op(dc, CC_OP_DSTEP, dc->op2, 4); |
| 1144 | return 2; | 1114 | return 2; |
| 1145 | } | 1115 | } |
| @@ -1165,7 +1135,7 @@ static unsigned int dec_bound_r(DisasContext *dc) | @@ -1165,7 +1135,7 @@ static unsigned int dec_bound_r(DisasContext *dc) | ||
| 1165 | /* TODO: needs optmimization. */ | 1135 | /* TODO: needs optmimization. */ |
| 1166 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); | 1136 | dec_prep_alu_r(dc, dc->op1, dc->op2, size, 0); |
| 1167 | /* rd should be 4. */ | 1137 | /* rd should be 4. */ |
| 1168 | - gen_movl_T0_reg[dc->op2](); | 1138 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); |
| 1169 | crisv32_alu_op(dc, CC_OP_BOUND, dc->op2, 4); | 1139 | crisv32_alu_op(dc, CC_OP_BOUND, dc->op2, 4); |
| 1170 | return 2; | 1140 | return 2; |
| 1171 | } | 1141 | } |
| @@ -1220,9 +1190,8 @@ static unsigned int dec_mcp_r(DisasContext *dc) | @@ -1220,9 +1190,8 @@ static unsigned int dec_mcp_r(DisasContext *dc) | ||
| 1220 | dc->op2, dc->op1)); | 1190 | dc->op2, dc->op1)); |
| 1221 | cris_evaluate_flags(dc); | 1191 | cris_evaluate_flags(dc); |
| 1222 | cris_cc_mask(dc, CC_MASK_RNZV); | 1192 | cris_cc_mask(dc, CC_MASK_RNZV); |
| 1223 | - gen_movl_T0_preg[dc->op2](); | ||
| 1224 | - gen_op_movl_T1_T0(); | ||
| 1225 | - gen_movl_T0_reg[dc->op1](); | 1193 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1194 | + t_gen_mov_TN_preg(cpu_T[1], dc->op2); | ||
| 1226 | crisv32_alu_op(dc, CC_OP_MCP, dc->op1, 4); | 1195 | crisv32_alu_op(dc, CC_OP_MCP, dc->op1, 4); |
| 1227 | return 2; | 1196 | return 2; |
| 1228 | } | 1197 | } |
| @@ -1250,7 +1219,7 @@ static unsigned int dec_swap_r(DisasContext *dc) | @@ -1250,7 +1219,7 @@ static unsigned int dec_swap_r(DisasContext *dc) | ||
| 1250 | swapmode_name(dc->op2, modename), dc->op1)); | 1219 | swapmode_name(dc->op2, modename), dc->op1)); |
| 1251 | 1220 | ||
| 1252 | cris_cc_mask(dc, CC_MASK_NZ); | 1221 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1253 | - gen_movl_T0_reg[dc->op1](); | 1222 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1254 | if (dc->op2 & 8) | 1223 | if (dc->op2 & 8) |
| 1255 | gen_op_not_T0_T0(); | 1224 | gen_op_not_T0_T0(); |
| 1256 | if (dc->op2 & 4) | 1225 | if (dc->op2 & 4) |
| @@ -1281,9 +1250,9 @@ static unsigned int dec_addi_r(DisasContext *dc) | @@ -1281,9 +1250,9 @@ static unsigned int dec_addi_r(DisasContext *dc) | ||
| 1281 | memsize_char(memsize_zz(dc)), dc->op2, dc->op1)); | 1250 | memsize_char(memsize_zz(dc)), dc->op2, dc->op1)); |
| 1282 | cris_cc_mask(dc, 0); | 1251 | cris_cc_mask(dc, 0); |
| 1283 | dec_prep_alu_r(dc, dc->op1, dc->op2, 4, 0); | 1252 | dec_prep_alu_r(dc, dc->op1, dc->op2, 4, 0); |
| 1284 | - gen_op_lsll_T0_im(dc->zzsize); | ||
| 1285 | - gen_op_addl_T0_T1(); | ||
| 1286 | - gen_movl_reg_T0[dc->op1](); | 1253 | + t_gen_lsl(cpu_T[0], cpu_T[0], tcg_const_i32(dc->zzsize)); |
| 1254 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); | ||
| 1255 | + t_gen_mov_reg_TN(dc->op1, cpu_T[0]); | ||
| 1287 | return 2; | 1256 | return 2; |
| 1288 | } | 1257 | } |
| 1289 | 1258 | ||
| @@ -1293,9 +1262,10 @@ static unsigned int dec_addi_acr(DisasContext *dc) | @@ -1293,9 +1262,10 @@ static unsigned int dec_addi_acr(DisasContext *dc) | ||
| 1293 | memsize_char(memsize_zz(dc)), dc->op2, dc->op1)); | 1262 | memsize_char(memsize_zz(dc)), dc->op2, dc->op1)); |
| 1294 | cris_cc_mask(dc, 0); | 1263 | cris_cc_mask(dc, 0); |
| 1295 | dec_prep_alu_r(dc, dc->op1, dc->op2, 4, 0); | 1264 | dec_prep_alu_r(dc, dc->op1, dc->op2, 4, 0); |
| 1296 | - gen_op_lsll_T0_im(dc->zzsize); | ||
| 1297 | - gen_op_addl_T0_T1(); | ||
| 1298 | - gen_movl_reg_T0[R_ACR](); | 1265 | + t_gen_lsl(cpu_T[0], cpu_T[0], tcg_const_i32(dc->zzsize)); |
| 1266 | + | ||
| 1267 | + tcg_gen_add_tl(cpu_T[0], cpu_T[0], cpu_T[1]); | ||
| 1268 | + t_gen_mov_reg_TN(R_ACR, cpu_T[0]); | ||
| 1299 | return 2; | 1269 | return 2; |
| 1300 | } | 1270 | } |
| 1301 | 1271 | ||
| @@ -1358,9 +1328,9 @@ static unsigned int dec_movs_r(DisasContext *dc) | @@ -1358,9 +1328,9 @@ static unsigned int dec_movs_r(DisasContext *dc) | ||
| 1358 | dc->op1, dc->op2)); | 1328 | dc->op1, dc->op2)); |
| 1359 | 1329 | ||
| 1360 | cris_cc_mask(dc, CC_MASK_NZ); | 1330 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1361 | - gen_movl_T0_reg[dc->op1](); | 1331 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1362 | /* Size can only be qi or hi. */ | 1332 | /* Size can only be qi or hi. */ |
| 1363 | - gen_sext_T1_T0(size); | 1333 | + t_gen_sext(cpu_T[1], cpu_T[0], size); |
| 1364 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); | 1334 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); |
| 1365 | return 2; | 1335 | return 2; |
| 1366 | } | 1336 | } |
| @@ -1374,13 +1344,14 @@ static unsigned int dec_addu_r(DisasContext *dc) | @@ -1374,13 +1344,14 @@ static unsigned int dec_addu_r(DisasContext *dc) | ||
| 1374 | dc->op1, dc->op2)); | 1344 | dc->op1, dc->op2)); |
| 1375 | 1345 | ||
| 1376 | cris_cc_mask(dc, CC_MASK_NZVC); | 1346 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 1377 | - gen_movl_T0_reg[dc->op1](); | 1347 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); |
| 1378 | /* Size can only be qi or hi. */ | 1348 | /* Size can only be qi or hi. */ |
| 1379 | - gen_zext_T1_T0(size); | ||
| 1380 | - gen_movl_T0_reg[dc->op2](); | 1349 | + t_gen_zext(cpu_T[1], cpu_T[1], size); |
| 1350 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); | ||
| 1381 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); | 1351 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); |
| 1382 | return 2; | 1352 | return 2; |
| 1383 | } | 1353 | } |
| 1354 | + | ||
| 1384 | /* Sign extension. From size to dword. */ | 1355 | /* Sign extension. From size to dword. */ |
| 1385 | static unsigned int dec_adds_r(DisasContext *dc) | 1356 | static unsigned int dec_adds_r(DisasContext *dc) |
| 1386 | { | 1357 | { |
| @@ -1390,10 +1361,11 @@ static unsigned int dec_adds_r(DisasContext *dc) | @@ -1390,10 +1361,11 @@ static unsigned int dec_adds_r(DisasContext *dc) | ||
| 1390 | dc->op1, dc->op2)); | 1361 | dc->op1, dc->op2)); |
| 1391 | 1362 | ||
| 1392 | cris_cc_mask(dc, CC_MASK_NZVC); | 1363 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 1393 | - gen_movl_T0_reg[dc->op1](); | 1364 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); |
| 1394 | /* Size can only be qi or hi. */ | 1365 | /* Size can only be qi or hi. */ |
| 1395 | - gen_sext_T1_T0(size); | ||
| 1396 | - gen_movl_T0_reg[dc->op2](); | 1366 | + t_gen_sext(cpu_T[1], cpu_T[1], size); |
| 1367 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); | ||
| 1368 | + | ||
| 1397 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); | 1369 | crisv32_alu_op(dc, CC_OP_ADD, dc->op2, 4); |
| 1398 | return 2; | 1370 | return 2; |
| 1399 | } | 1371 | } |
| @@ -1407,10 +1379,10 @@ static unsigned int dec_subu_r(DisasContext *dc) | @@ -1407,10 +1379,10 @@ static unsigned int dec_subu_r(DisasContext *dc) | ||
| 1407 | dc->op1, dc->op2)); | 1379 | dc->op1, dc->op2)); |
| 1408 | 1380 | ||
| 1409 | cris_cc_mask(dc, CC_MASK_NZVC); | 1381 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 1410 | - gen_movl_T0_reg[dc->op1](); | 1382 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); |
| 1411 | /* Size can only be qi or hi. */ | 1383 | /* Size can only be qi or hi. */ |
| 1412 | - gen_zext_T1_T0(size); | ||
| 1413 | - gen_movl_T0_reg[dc->op2](); | 1384 | + t_gen_zext(cpu_T[1], cpu_T[1], size); |
| 1385 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); | ||
| 1414 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); | 1386 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); |
| 1415 | return 2; | 1387 | return 2; |
| 1416 | } | 1388 | } |
| @@ -1424,10 +1396,10 @@ static unsigned int dec_subs_r(DisasContext *dc) | @@ -1424,10 +1396,10 @@ static unsigned int dec_subs_r(DisasContext *dc) | ||
| 1424 | dc->op1, dc->op2)); | 1396 | dc->op1, dc->op2)); |
| 1425 | 1397 | ||
| 1426 | cris_cc_mask(dc, CC_MASK_NZVC); | 1398 | cris_cc_mask(dc, CC_MASK_NZVC); |
| 1427 | - gen_movl_T0_reg[dc->op1](); | 1399 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); |
| 1428 | /* Size can only be qi or hi. */ | 1400 | /* Size can only be qi or hi. */ |
| 1429 | - gen_sext_T1_T0(size); | ||
| 1430 | - gen_movl_T0_reg[dc->op2](); | 1401 | + t_gen_sext(cpu_T[1], cpu_T[1], size); |
| 1402 | + t_gen_mov_TN_reg(cpu_T[0], dc->op2); | ||
| 1431 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); | 1403 | crisv32_alu_op(dc, CC_OP_SUB, dc->op2, 4); |
| 1432 | return 2; | 1404 | return 2; |
| 1433 | } | 1405 | } |
| @@ -1469,29 +1441,34 @@ static unsigned int dec_move_rs(DisasContext *dc) | @@ -1469,29 +1441,34 @@ static unsigned int dec_move_rs(DisasContext *dc) | ||
| 1469 | { | 1441 | { |
| 1470 | DIS(fprintf (logfile, "move $r%u, $s%u\n", dc->op1, dc->op2)); | 1442 | DIS(fprintf (logfile, "move $r%u, $s%u\n", dc->op1, dc->op2)); |
| 1471 | cris_cc_mask(dc, 0); | 1443 | cris_cc_mask(dc, 0); |
| 1472 | - gen_movl_T0_reg[dc->op1](); | 1444 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1473 | gen_op_movl_sreg_T0(dc->op2); | 1445 | gen_op_movl_sreg_T0(dc->op2); |
| 1474 | 1446 | ||
| 1475 | - if (dc->op2 == 5) /* srs is checked at runtime. */ | 1447 | +#if !defined(CONFIG_USER_ONLY) |
| 1448 | + if (dc->op2 == 6) | ||
| 1449 | + gen_op_movl_tlb_hi_T0(); | ||
| 1450 | + else if (dc->op2 == 5) { /* srs is checked at runtime. */ | ||
| 1451 | + tcg_gen_helper_0_1(helper_tlb_update, cpu_T[0]); | ||
| 1476 | gen_op_movl_tlb_lo_T0(); | 1452 | gen_op_movl_tlb_lo_T0(); |
| 1453 | + } | ||
| 1454 | +#endif | ||
| 1477 | return 2; | 1455 | return 2; |
| 1478 | } | 1456 | } |
| 1479 | static unsigned int dec_move_sr(DisasContext *dc) | 1457 | static unsigned int dec_move_sr(DisasContext *dc) |
| 1480 | { | 1458 | { |
| 1481 | - DIS(fprintf (logfile, "move $s%u, $r%u\n", dc->op1, dc->op2)); | 1459 | + DIS(fprintf (logfile, "move $s%u, $r%u\n", dc->op2, dc->op1)); |
| 1482 | cris_cc_mask(dc, 0); | 1460 | cris_cc_mask(dc, 0); |
| 1483 | - gen_op_movl_T0_sreg(dc->op1); | ||
| 1484 | - gen_op_movl_T1_T0(); | ||
| 1485 | - crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); | 1461 | + gen_op_movl_T0_sreg(dc->op2); |
| 1462 | + tcg_gen_mov_tl(cpu_T[1], cpu_T[0]); | ||
| 1463 | + crisv32_alu_op(dc, CC_OP_MOVE, dc->op1, 4); | ||
| 1486 | return 2; | 1464 | return 2; |
| 1487 | } | 1465 | } |
| 1488 | static unsigned int dec_move_rp(DisasContext *dc) | 1466 | static unsigned int dec_move_rp(DisasContext *dc) |
| 1489 | { | 1467 | { |
| 1490 | DIS(fprintf (logfile, "move $r%u, $p%u\n", dc->op1, dc->op2)); | 1468 | DIS(fprintf (logfile, "move $r%u, $p%u\n", dc->op1, dc->op2)); |
| 1491 | cris_cc_mask(dc, 0); | 1469 | cris_cc_mask(dc, 0); |
| 1492 | - gen_movl_T0_reg[dc->op1](); | ||
| 1493 | - gen_op_movl_T1_T0(); | ||
| 1494 | - gen_movl_preg_T0[dc->op2](); | 1470 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1471 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 1495 | return 2; | 1472 | return 2; |
| 1496 | } | 1473 | } |
| 1497 | static unsigned int dec_move_pr(DisasContext *dc) | 1474 | static unsigned int dec_move_pr(DisasContext *dc) |
| @@ -1501,11 +1478,9 @@ static unsigned int dec_move_pr(DisasContext *dc) | @@ -1501,11 +1478,9 @@ static unsigned int dec_move_pr(DisasContext *dc) | ||
| 1501 | /* Support register 0 is hardwired to zero. | 1478 | /* Support register 0 is hardwired to zero. |
| 1502 | Treat it specially. */ | 1479 | Treat it specially. */ |
| 1503 | if (dc->op2 == 0) | 1480 | if (dc->op2 == 0) |
| 1504 | - gen_op_movl_T1_im(0); | ||
| 1505 | - else { | ||
| 1506 | - gen_movl_T0_preg[dc->op2](); | ||
| 1507 | - gen_op_movl_T1_T0(); | ||
| 1508 | - } | 1481 | + tcg_gen_movi_tl(cpu_T[1], 0); |
| 1482 | + else | ||
| 1483 | + t_gen_mov_TN_preg(cpu_T[1], dc->op2); | ||
| 1509 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op1, preg_sizes[dc->op2]); | 1484 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op1, preg_sizes[dc->op2]); |
| 1510 | return 2; | 1485 | return 2; |
| 1511 | } | 1486 | } |
| @@ -1688,8 +1663,8 @@ static unsigned int dec_test_m(DisasContext *dc) | @@ -1688,8 +1663,8 @@ static unsigned int dec_test_m(DisasContext *dc) | ||
| 1688 | cris_cc_mask(dc, CC_MASK_NZ); | 1663 | cris_cc_mask(dc, CC_MASK_NZ); |
| 1689 | gen_op_clrf(3); | 1664 | gen_op_clrf(3); |
| 1690 | insn_len = dec_prep_alu_m(dc, 0, memsize); | 1665 | insn_len = dec_prep_alu_m(dc, 0, memsize); |
| 1691 | - gen_op_swp_T0_T1(); | ||
| 1692 | - gen_op_movl_T1_im(0); | 1666 | + tcg_gen_mov_tl(cpu_T[0], cpu_T[1]); |
| 1667 | + tcg_gen_movi_tl(cpu_T[1], 0); | ||
| 1693 | crisv32_alu_op(dc, CC_OP_CMP, dc->op2, memsize_zz(dc)); | 1668 | crisv32_alu_op(dc, CC_OP_CMP, dc->op2, memsize_zz(dc)); |
| 1694 | do_postinc(dc, memsize); | 1669 | do_postinc(dc, memsize); |
| 1695 | return insn_len; | 1670 | return insn_len; |
| @@ -1819,8 +1794,7 @@ static unsigned int dec_move_mp(DisasContext *dc) | @@ -1819,8 +1794,7 @@ static unsigned int dec_move_mp(DisasContext *dc) | ||
| 1819 | 1794 | ||
| 1820 | cris_cc_mask(dc, 0); | 1795 | cris_cc_mask(dc, 0); |
| 1821 | insn_len = dec_prep_alu_m(dc, 0, memsize); | 1796 | insn_len = dec_prep_alu_m(dc, 0, memsize); |
| 1822 | - gen_op_movl_T0_T1(); | ||
| 1823 | - gen_movl_preg_T0[dc->op2](); | 1797 | + t_gen_mov_preg_TN(dc->op2, cpu_T[1]); |
| 1824 | 1798 | ||
| 1825 | do_postinc(dc, memsize); | 1799 | do_postinc(dc, memsize); |
| 1826 | return insn_len; | 1800 | return insn_len; |
| @@ -1838,21 +1812,13 @@ static unsigned int dec_move_pm(DisasContext *dc) | @@ -1838,21 +1812,13 @@ static unsigned int dec_move_pm(DisasContext *dc) | ||
| 1838 | 1812 | ||
| 1839 | cris_cc_mask(dc, 0); | 1813 | cris_cc_mask(dc, 0); |
| 1840 | /* prepare store. Address in T0, value in T1. */ | 1814 | /* prepare store. Address in T0, value in T1. */ |
| 1841 | - /* Support register 0 is hardwired to zero. | ||
| 1842 | - Treat it specially. */ | ||
| 1843 | - if (dc->op2 == 0) | ||
| 1844 | - gen_op_movl_T1_im(0); | ||
| 1845 | - else | ||
| 1846 | - { | ||
| 1847 | - gen_movl_T0_preg[dc->op2](); | ||
| 1848 | - gen_op_movl_T1_T0(); | ||
| 1849 | - } | ||
| 1850 | - gen_movl_T0_reg[dc->op1](); | 1815 | + t_gen_mov_TN_preg(cpu_T[1], dc->op2); |
| 1816 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); | ||
| 1851 | gen_store_T0_T1(dc, memsize); | 1817 | gen_store_T0_T1(dc, memsize); |
| 1852 | if (dc->postinc) | 1818 | if (dc->postinc) |
| 1853 | { | 1819 | { |
| 1854 | - gen_op_addl_T0_im(memsize); | ||
| 1855 | - gen_movl_reg_T0[dc->op1](); | 1820 | + tcg_gen_addi_tl(cpu_T[0], cpu_T[0], memsize); |
| 1821 | + t_gen_mov_reg_TN(dc->op1, cpu_T[0]); | ||
| 1856 | } | 1822 | } |
| 1857 | return 2; | 1823 | return 2; |
| 1858 | } | 1824 | } |
| @@ -1865,21 +1831,18 @@ static unsigned int dec_movem_mr(DisasContext *dc) | @@ -1865,21 +1831,18 @@ static unsigned int dec_movem_mr(DisasContext *dc) | ||
| 1865 | dc->postinc ? "+]" : "]", dc->op2)); | 1831 | dc->postinc ? "+]" : "]", dc->op2)); |
| 1866 | 1832 | ||
| 1867 | cris_cc_mask(dc, 0); | 1833 | cris_cc_mask(dc, 0); |
| 1868 | - /* fetch the address into T1. */ | ||
| 1869 | - gen_movl_T0_reg[dc->op1](); | ||
| 1870 | - gen_op_movl_T1_T0(); | 1834 | + /* fetch the address into T0 and T1. */ |
| 1835 | + t_gen_mov_TN_reg(cpu_T[1], dc->op1); | ||
| 1871 | for (i = 0; i <= dc->op2; i++) { | 1836 | for (i = 0; i <= dc->op2; i++) { |
| 1872 | /* Perform the load onto regnum i. Always dword wide. */ | 1837 | /* Perform the load onto regnum i. Always dword wide. */ |
| 1838 | + tcg_gen_mov_tl(cpu_T[0], cpu_T[1]); | ||
| 1873 | gen_load_T0_T0(dc, 4, 0); | 1839 | gen_load_T0_T0(dc, 4, 0); |
| 1874 | - gen_movl_reg_T0[i](); | ||
| 1875 | - /* Update the address. */ | ||
| 1876 | - gen_op_addl_T1_im(4); | ||
| 1877 | - gen_op_movl_T0_T1(); | ||
| 1878 | - } | ||
| 1879 | - if (dc->postinc) { | ||
| 1880 | - /* writeback the updated pointer value. */ | ||
| 1881 | - gen_movl_reg_T0[dc->op1](); | 1840 | + t_gen_mov_reg_TN(i, cpu_T[0]); |
| 1841 | + tcg_gen_addi_tl(cpu_T[1], cpu_T[1], 4); | ||
| 1882 | } | 1842 | } |
| 1843 | + /* writeback the updated pointer value. */ | ||
| 1844 | + if (dc->postinc) | ||
| 1845 | + t_gen_mov_reg_TN(dc->op1, cpu_T[1]); | ||
| 1883 | return 2; | 1846 | return 2; |
| 1884 | } | 1847 | } |
| 1885 | 1848 | ||
| @@ -1893,22 +1856,20 @@ static unsigned int dec_movem_rm(DisasContext *dc) | @@ -1893,22 +1856,20 @@ static unsigned int dec_movem_rm(DisasContext *dc) | ||
| 1893 | cris_cc_mask(dc, 0); | 1856 | cris_cc_mask(dc, 0); |
| 1894 | for (i = 0; i <= dc->op2; i++) { | 1857 | for (i = 0; i <= dc->op2; i++) { |
| 1895 | /* Fetch register i into T1. */ | 1858 | /* Fetch register i into T1. */ |
| 1896 | - gen_movl_T0_reg[i](); | ||
| 1897 | - gen_op_movl_T1_T0(); | ||
| 1898 | - | 1859 | + t_gen_mov_TN_reg(cpu_T[1], i); |
| 1899 | /* Fetch the address into T0. */ | 1860 | /* Fetch the address into T0. */ |
| 1900 | - gen_movl_T0_reg[dc->op1](); | 1861 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1901 | /* Displace it. */ | 1862 | /* Displace it. */ |
| 1902 | - gen_op_addl_T0_im(i * 4); | ||
| 1903 | - | 1863 | + tcg_gen_addi_tl(cpu_T[0], cpu_T[0], i * 4); |
| 1904 | /* Perform the store. */ | 1864 | /* Perform the store. */ |
| 1905 | gen_store_T0_T1(dc, 4); | 1865 | gen_store_T0_T1(dc, 4); |
| 1906 | } | 1866 | } |
| 1907 | if (dc->postinc) { | 1867 | if (dc->postinc) { |
| 1908 | - /* Update the address. */ | ||
| 1909 | - gen_op_addl_T0_im(4); | 1868 | + /* T0 should point to the last written addr, advance one more |
| 1869 | + step. */ | ||
| 1870 | + tcg_gen_addi_tl(cpu_T[0], cpu_T[0], 4); | ||
| 1910 | /* writeback the updated pointer value. */ | 1871 | /* writeback the updated pointer value. */ |
| 1911 | - gen_movl_reg_T0[dc->op1](); | 1872 | + t_gen_mov_reg_TN(dc->op1, cpu_T[0]); |
| 1912 | } | 1873 | } |
| 1913 | return 2; | 1874 | return 2; |
| 1914 | } | 1875 | } |
| @@ -1924,25 +1885,23 @@ static unsigned int dec_move_rm(DisasContext *dc) | @@ -1924,25 +1885,23 @@ static unsigned int dec_move_rm(DisasContext *dc) | ||
| 1924 | 1885 | ||
| 1925 | cris_cc_mask(dc, 0); | 1886 | cris_cc_mask(dc, 0); |
| 1926 | /* prepare store. */ | 1887 | /* prepare store. */ |
| 1927 | - gen_movl_T0_reg[dc->op2](); | ||
| 1928 | - gen_op_movl_T1_T0(); | ||
| 1929 | - gen_movl_T0_reg[dc->op1](); | 1888 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1889 | + t_gen_mov_TN_reg(cpu_T[1], dc->op2); | ||
| 1930 | gen_store_T0_T1(dc, memsize); | 1890 | gen_store_T0_T1(dc, memsize); |
| 1931 | if (dc->postinc) | 1891 | if (dc->postinc) |
| 1932 | { | 1892 | { |
| 1933 | - gen_op_addl_T0_im(memsize); | ||
| 1934 | - gen_movl_reg_T0[dc->op1](); | 1893 | + tcg_gen_addi_tl(cpu_T[0], cpu_T[0], memsize); |
| 1894 | + t_gen_mov_reg_TN(dc->op1, cpu_T[0]); | ||
| 1935 | } | 1895 | } |
| 1936 | return 2; | 1896 | return 2; |
| 1937 | } | 1897 | } |
| 1938 | 1898 | ||
| 1939 | - | ||
| 1940 | static unsigned int dec_lapcq(DisasContext *dc) | 1899 | static unsigned int dec_lapcq(DisasContext *dc) |
| 1941 | { | 1900 | { |
| 1942 | DIS(fprintf (logfile, "lapcq %x, $r%u\n", | 1901 | DIS(fprintf (logfile, "lapcq %x, $r%u\n", |
| 1943 | dc->pc + dc->op1*2, dc->op2)); | 1902 | dc->pc + dc->op1*2, dc->op2)); |
| 1944 | cris_cc_mask(dc, 0); | 1903 | cris_cc_mask(dc, 0); |
| 1945 | - gen_op_movl_T1_im(dc->pc + dc->op1*2); | 1904 | + tcg_gen_movi_tl(cpu_T[1], dc->pc + dc->op1 * 2); |
| 1946 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); | 1905 | crisv32_alu_op(dc, CC_OP_MOVE, dc->op2, 4); |
| 1947 | return 2; | 1906 | return 2; |
| 1948 | } | 1907 | } |
| @@ -1951,16 +1910,14 @@ static unsigned int dec_lapc_im(DisasContext *dc) | @@ -1951,16 +1910,14 @@ static unsigned int dec_lapc_im(DisasContext *dc) | ||
| 1951 | { | 1910 | { |
| 1952 | unsigned int rd; | 1911 | unsigned int rd; |
| 1953 | int32_t imm; | 1912 | int32_t imm; |
| 1954 | - int insn_len = 6; | ||
| 1955 | 1913 | ||
| 1956 | rd = dc->op2; | 1914 | rd = dc->op2; |
| 1957 | 1915 | ||
| 1958 | cris_cc_mask(dc, 0); | 1916 | cris_cc_mask(dc, 0); |
| 1959 | imm = ldl_code(dc->pc + 2); | 1917 | imm = ldl_code(dc->pc + 2); |
| 1960 | DIS(fprintf (logfile, "lapc 0x%x, $r%u\n", imm + dc->pc, dc->op2)); | 1918 | DIS(fprintf (logfile, "lapc 0x%x, $r%u\n", imm + dc->pc, dc->op2)); |
| 1961 | - gen_op_movl_T0_im (dc->pc + imm); | ||
| 1962 | - gen_movl_reg_T0[rd] (); | ||
| 1963 | - return insn_len; | 1919 | + t_gen_mov_reg_TN(rd, tcg_const_i32(dc->pc + imm)); |
| 1920 | + return 6; | ||
| 1964 | } | 1921 | } |
| 1965 | 1922 | ||
| 1966 | /* Jump to special reg. */ | 1923 | /* Jump to special reg. */ |
| @@ -1969,7 +1926,7 @@ static unsigned int dec_jump_p(DisasContext *dc) | @@ -1969,7 +1926,7 @@ static unsigned int dec_jump_p(DisasContext *dc) | ||
| 1969 | DIS(fprintf (logfile, "jump $p%u\n", dc->op2)); | 1926 | DIS(fprintf (logfile, "jump $p%u\n", dc->op2)); |
| 1970 | cris_cc_mask(dc, 0); | 1927 | cris_cc_mask(dc, 0); |
| 1971 | /* Store the return address in Pd. */ | 1928 | /* Store the return address in Pd. */ |
| 1972 | - gen_movl_T0_preg[dc->op2](); | 1929 | + t_gen_mov_TN_preg(cpu_T[0], dc->op2); |
| 1973 | gen_op_movl_btarget_T0(); | 1930 | gen_op_movl_btarget_T0(); |
| 1974 | cris_prepare_dyn_jmp(dc); | 1931 | cris_prepare_dyn_jmp(dc); |
| 1975 | return 2; | 1932 | return 2; |
| @@ -1981,10 +1938,10 @@ static unsigned int dec_jas_r(DisasContext *dc) | @@ -1981,10 +1938,10 @@ static unsigned int dec_jas_r(DisasContext *dc) | ||
| 1981 | DIS(fprintf (logfile, "jas $r%u, $p%u\n", dc->op1, dc->op2)); | 1938 | DIS(fprintf (logfile, "jas $r%u, $p%u\n", dc->op1, dc->op2)); |
| 1982 | cris_cc_mask(dc, 0); | 1939 | cris_cc_mask(dc, 0); |
| 1983 | /* Stor the return address in Pd. */ | 1940 | /* Stor the return address in Pd. */ |
| 1984 | - gen_movl_T0_reg[dc->op1](); | 1941 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 1985 | gen_op_movl_btarget_T0(); | 1942 | gen_op_movl_btarget_T0(); |
| 1986 | - gen_op_movl_T0_im(dc->pc + 4); | ||
| 1987 | - gen_movl_preg_T0[dc->op2](); | 1943 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 4); |
| 1944 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 1988 | cris_prepare_dyn_jmp(dc); | 1945 | cris_prepare_dyn_jmp(dc); |
| 1989 | return 2; | 1946 | return 2; |
| 1990 | } | 1947 | } |
| @@ -1998,10 +1955,10 @@ static unsigned int dec_jas_im(DisasContext *dc) | @@ -1998,10 +1955,10 @@ static unsigned int dec_jas_im(DisasContext *dc) | ||
| 1998 | DIS(fprintf (logfile, "jas 0x%x\n", imm)); | 1955 | DIS(fprintf (logfile, "jas 0x%x\n", imm)); |
| 1999 | cris_cc_mask(dc, 0); | 1956 | cris_cc_mask(dc, 0); |
| 2000 | /* Stor the return address in Pd. */ | 1957 | /* Stor the return address in Pd. */ |
| 2001 | - gen_op_movl_T0_im(imm); | 1958 | + tcg_gen_movi_tl(cpu_T[0], imm); |
| 2002 | gen_op_movl_btarget_T0(); | 1959 | gen_op_movl_btarget_T0(); |
| 2003 | - gen_op_movl_T0_im(dc->pc + 8); | ||
| 2004 | - gen_movl_preg_T0[dc->op2](); | 1960 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 8); |
| 1961 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 2005 | cris_prepare_dyn_jmp(dc); | 1962 | cris_prepare_dyn_jmp(dc); |
| 2006 | return 6; | 1963 | return 6; |
| 2007 | } | 1964 | } |
| @@ -2015,10 +1972,10 @@ static unsigned int dec_jasc_im(DisasContext *dc) | @@ -2015,10 +1972,10 @@ static unsigned int dec_jasc_im(DisasContext *dc) | ||
| 2015 | DIS(fprintf (logfile, "jasc 0x%x\n", imm)); | 1972 | DIS(fprintf (logfile, "jasc 0x%x\n", imm)); |
| 2016 | cris_cc_mask(dc, 0); | 1973 | cris_cc_mask(dc, 0); |
| 2017 | /* Stor the return address in Pd. */ | 1974 | /* Stor the return address in Pd. */ |
| 2018 | - gen_op_movl_T0_im(imm); | 1975 | + tcg_gen_movi_tl(cpu_T[0], imm); |
| 2019 | gen_op_movl_btarget_T0(); | 1976 | gen_op_movl_btarget_T0(); |
| 2020 | - gen_op_movl_T0_im(dc->pc + 8 + 4); | ||
| 2021 | - gen_movl_preg_T0[dc->op2](); | 1977 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 8 + 4); |
| 1978 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 2022 | cris_prepare_dyn_jmp(dc); | 1979 | cris_prepare_dyn_jmp(dc); |
| 2023 | return 6; | 1980 | return 6; |
| 2024 | } | 1981 | } |
| @@ -2028,10 +1985,10 @@ static unsigned int dec_jasc_r(DisasContext *dc) | @@ -2028,10 +1985,10 @@ static unsigned int dec_jasc_r(DisasContext *dc) | ||
| 2028 | DIS(fprintf (logfile, "jasc_r $r%u, $p%u\n", dc->op1, dc->op2)); | 1985 | DIS(fprintf (logfile, "jasc_r $r%u, $p%u\n", dc->op1, dc->op2)); |
| 2029 | cris_cc_mask(dc, 0); | 1986 | cris_cc_mask(dc, 0); |
| 2030 | /* Stor the return address in Pd. */ | 1987 | /* Stor the return address in Pd. */ |
| 2031 | - gen_movl_T0_reg[dc->op1](); | 1988 | + t_gen_mov_TN_reg(cpu_T[0], dc->op1); |
| 2032 | gen_op_movl_btarget_T0(); | 1989 | gen_op_movl_btarget_T0(); |
| 2033 | - gen_op_movl_T0_im(dc->pc + 4 + 4); | ||
| 2034 | - gen_movl_preg_T0[dc->op2](); | 1990 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 4 + 4); |
| 1991 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 2035 | cris_prepare_dyn_jmp(dc); | 1992 | cris_prepare_dyn_jmp(dc); |
| 2036 | return 2; | 1993 | return 2; |
| 2037 | } | 1994 | } |
| @@ -2064,10 +2021,10 @@ static unsigned int dec_bas_im(DisasContext *dc) | @@ -2064,10 +2021,10 @@ static unsigned int dec_bas_im(DisasContext *dc) | ||
| 2064 | DIS(fprintf (logfile, "bas 0x%x, $p%u\n", dc->pc + simm, dc->op2)); | 2021 | DIS(fprintf (logfile, "bas 0x%x, $p%u\n", dc->pc + simm, dc->op2)); |
| 2065 | cris_cc_mask(dc, 0); | 2022 | cris_cc_mask(dc, 0); |
| 2066 | /* Stor the return address in Pd. */ | 2023 | /* Stor the return address in Pd. */ |
| 2067 | - gen_op_movl_T0_im(dc->pc + simm); | 2024 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + simm); |
| 2068 | gen_op_movl_btarget_T0(); | 2025 | gen_op_movl_btarget_T0(); |
| 2069 | - gen_op_movl_T0_im(dc->pc + 8); | ||
| 2070 | - gen_movl_preg_T0[dc->op2](); | 2026 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 8); |
| 2027 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 2071 | cris_prepare_dyn_jmp(dc); | 2028 | cris_prepare_dyn_jmp(dc); |
| 2072 | return 6; | 2029 | return 6; |
| 2073 | } | 2030 | } |
| @@ -2080,10 +2037,10 @@ static unsigned int dec_basc_im(DisasContext *dc) | @@ -2080,10 +2037,10 @@ static unsigned int dec_basc_im(DisasContext *dc) | ||
| 2080 | DIS(fprintf (logfile, "basc 0x%x, $p%u\n", dc->pc + simm, dc->op2)); | 2037 | DIS(fprintf (logfile, "basc 0x%x, $p%u\n", dc->pc + simm, dc->op2)); |
| 2081 | cris_cc_mask(dc, 0); | 2038 | cris_cc_mask(dc, 0); |
| 2082 | /* Stor the return address in Pd. */ | 2039 | /* Stor the return address in Pd. */ |
| 2083 | - gen_op_movl_T0_im(dc->pc + simm); | 2040 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + simm); |
| 2084 | gen_op_movl_btarget_T0(); | 2041 | gen_op_movl_btarget_T0(); |
| 2085 | - gen_op_movl_T0_im(dc->pc + 12); | ||
| 2086 | - gen_movl_preg_T0[dc->op2](); | 2042 | + tcg_gen_movi_tl(cpu_T[0], dc->pc + 12); |
| 2043 | + t_gen_mov_preg_TN(dc->op2, cpu_T[0]); | ||
| 2087 | cris_prepare_dyn_jmp(dc); | 2044 | cris_prepare_dyn_jmp(dc); |
| 2088 | return 6; | 2045 | return 6; |
| 2089 | } | 2046 | } |
| @@ -2096,7 +2053,7 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | @@ -2096,7 +2053,7 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | ||
| 2096 | cris_cc_mask(dc, 0); | 2053 | cris_cc_mask(dc, 0); |
| 2097 | 2054 | ||
| 2098 | if (dc->op2 == 15) /* ignore halt. */ | 2055 | if (dc->op2 == 15) /* ignore halt. */ |
| 2099 | - goto done; | 2056 | + return 2; |
| 2100 | 2057 | ||
| 2101 | switch (dc->op2 & 7) { | 2058 | switch (dc->op2 & 7) { |
| 2102 | case 2: | 2059 | case 2: |
| @@ -2110,7 +2067,7 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | @@ -2110,7 +2067,7 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | ||
| 2110 | break; | 2067 | break; |
| 2111 | case 6: | 2068 | case 6: |
| 2112 | /* break. */ | 2069 | /* break. */ |
| 2113 | - gen_op_movl_T0_im(dc->pc); | 2070 | + tcg_gen_movi_tl(cpu_T[0], dc->pc); |
| 2114 | gen_op_movl_pc_T0(); | 2071 | gen_op_movl_pc_T0(); |
| 2115 | /* Breaks start at 16 in the exception vector. */ | 2072 | /* Breaks start at 16 in the exception vector. */ |
| 2116 | gen_op_break_im(dc->op1 + 16); | 2073 | gen_op_break_im(dc->op1 + 16); |
| @@ -2122,7 +2079,6 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | @@ -2122,7 +2079,6 @@ static unsigned int dec_rfe_etc(DisasContext *dc) | ||
| 2122 | break; | 2079 | break; |
| 2123 | 2080 | ||
| 2124 | } | 2081 | } |
| 2125 | - done: | ||
| 2126 | return 2; | 2082 | return 2; |
| 2127 | } | 2083 | } |
| 2128 | 2084 | ||
| @@ -2296,7 +2252,7 @@ static void check_breakpoint(CPUState *env, DisasContext *dc) | @@ -2296,7 +2252,7 @@ static void check_breakpoint(CPUState *env, DisasContext *dc) | ||
| 2296 | for(j = 0; j < env->nb_breakpoints; j++) { | 2252 | for(j = 0; j < env->nb_breakpoints; j++) { |
| 2297 | if (env->breakpoints[j] == dc->pc) { | 2253 | if (env->breakpoints[j] == dc->pc) { |
| 2298 | cris_evaluate_flags (dc); | 2254 | cris_evaluate_flags (dc); |
| 2299 | - gen_op_movl_T0_im((long)dc->pc); | 2255 | + tcg_gen_movi_tl(cpu_T[0], dc->pc); |
| 2300 | gen_op_movl_pc_T0(); | 2256 | gen_op_movl_pc_T0(); |
| 2301 | gen_op_debug(); | 2257 | gen_op_debug(); |
| 2302 | dc->is_jmp = DISAS_UPDATE; | 2258 | dc->is_jmp = DISAS_UPDATE; |
| @@ -2305,7 +2261,6 @@ static void check_breakpoint(CPUState *env, DisasContext *dc) | @@ -2305,7 +2261,6 @@ static void check_breakpoint(CPUState *env, DisasContext *dc) | ||
| 2305 | } | 2261 | } |
| 2306 | } | 2262 | } |
| 2307 | 2263 | ||
| 2308 | - | ||
| 2309 | /* generate intermediate code for basic block 'tb'. */ | 2264 | /* generate intermediate code for basic block 'tb'. */ |
| 2310 | struct DisasContext ctx; | 2265 | struct DisasContext ctx; |
| 2311 | static int | 2266 | static int |
| @@ -2356,11 +2311,7 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb, | @@ -2356,11 +2311,7 @@ gen_intermediate_code_internal(CPUState *env, TranslationBlock *tb, | ||
| 2356 | if (!dc->flagx_live | 2311 | if (!dc->flagx_live |
| 2357 | || (dc->flagx_live && | 2312 | || (dc->flagx_live && |
| 2358 | !(dc->cc_op == CC_OP_FLAGS && dc->flags_x))) { | 2313 | !(dc->cc_op == CC_OP_FLAGS && dc->flags_x))) { |
| 2359 | - gen_movl_T0_preg[PR_CCS](); | ||
| 2360 | - gen_op_andl_T0_im(~X_FLAG); | ||
| 2361 | - gen_movl_preg_T0[PR_CCS](); | ||
| 2362 | - dc->flagx_live = 1; | ||
| 2363 | - dc->flags_x = 0; | 2314 | + cris_clear_x_flag(dc); |
| 2364 | } | 2315 | } |
| 2365 | 2316 | ||
| 2366 | /* Check for delayed branches here. If we do it before | 2317 | /* Check for delayed branches here. If we do it before |
| @@ -2488,6 +2439,10 @@ void cpu_dump_state (CPUState *env, FILE *f, | @@ -2488,6 +2439,10 @@ void cpu_dump_state (CPUState *env, FILE *f, | ||
| 2488 | 2439 | ||
| 2489 | } | 2440 | } |
| 2490 | 2441 | ||
| 2442 | +static void tcg_macro_func(TCGContext *s, int macro_id, const int *dead_args) | ||
| 2443 | +{ | ||
| 2444 | +} | ||
| 2445 | + | ||
| 2491 | CPUCRISState *cpu_cris_init (const char *cpu_model) | 2446 | CPUCRISState *cpu_cris_init (const char *cpu_model) |
| 2492 | { | 2447 | { |
| 2493 | CPUCRISState *env; | 2448 | CPUCRISState *env; |
| @@ -2496,6 +2451,19 @@ CPUCRISState *cpu_cris_init (const char *cpu_model) | @@ -2496,6 +2451,19 @@ CPUCRISState *cpu_cris_init (const char *cpu_model) | ||
| 2496 | if (!env) | 2451 | if (!env) |
| 2497 | return NULL; | 2452 | return NULL; |
| 2498 | cpu_exec_init(env); | 2453 | cpu_exec_init(env); |
| 2454 | + | ||
| 2455 | + tcg_set_macro_func(&tcg_ctx, tcg_macro_func); | ||
| 2456 | + cpu_env = tcg_global_reg_new(TCG_TYPE_PTR, TCG_AREG0, "env"); | ||
| 2457 | +#if TARGET_LONG_BITS > HOST_LONG_BITS | ||
| 2458 | + cpu_T[0] = tcg_global_mem_new(TCG_TYPE_TL, | ||
| 2459 | + TCG_AREG0, offsetof(CPUState, t0), "T0"); | ||
| 2460 | + cpu_T[1] = tcg_global_mem_new(TCG_TYPE_TL, | ||
| 2461 | + TCG_AREG0, offsetof(CPUState, t1), "T1"); | ||
| 2462 | +#else | ||
| 2463 | + cpu_T[0] = tcg_global_reg_new(TCG_TYPE_TL, TCG_AREG1, "T0"); | ||
| 2464 | + cpu_T[1] = tcg_global_reg_new(TCG_TYPE_TL, TCG_AREG2, "T1"); | ||
| 2465 | +#endif | ||
| 2466 | + | ||
| 2499 | cpu_reset(env); | 2467 | cpu_reset(env); |
| 2500 | return env; | 2468 | return env; |
| 2501 | } | 2469 | } |