Commit f24e5695e5fab2d4d143c34ffe8164ddeac9b12b

Authored by bellard
1 parent 7668a27f

avoid generating useless exceptions (Jocelyn Mayer)


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@1656 c046a42c-6fe2-441c-8c8c-71466251a162
Showing 1 changed file with 26 additions and 11 deletions
target-ppc/translate.c
@@ -177,17 +177,16 @@ RET_EXCP((ctx), EXCP_PROGRAM, EXCP_INVAL | EXCP_PRIV_OPC) @@ -177,17 +177,16 @@ RET_EXCP((ctx), EXCP_PROGRAM, EXCP_INVAL | EXCP_PRIV_OPC)
177 #define RET_PRIVREG(ctx) \ 177 #define RET_PRIVREG(ctx) \
178 RET_EXCP((ctx), EXCP_PROGRAM, EXCP_INVAL | EXCP_PRIV_REG) 178 RET_EXCP((ctx), EXCP_PROGRAM, EXCP_INVAL | EXCP_PRIV_REG)
179 179
180 -#define RET_MTMSR(ctx) \  
181 -RET_EXCP((ctx), EXCP_MTMSR, 0)  
182 - 180 +/* Stop translation */
183 static inline void RET_STOP (DisasContext *ctx) 181 static inline void RET_STOP (DisasContext *ctx)
184 { 182 {
185 - RET_EXCP(ctx, EXCP_MTMSR, 0); 183 + gen_op_update_nip((ctx)->nip);
  184 + ctx->exception = EXCP_MTMSR;
186 } 185 }
187 186
  187 +/* No need to update nip here, as execution flow will change */
188 static inline void RET_CHG_FLOW (DisasContext *ctx) 188 static inline void RET_CHG_FLOW (DisasContext *ctx)
189 { 189 {
190 - gen_op_raise_exception_err(EXCP_MTMSR, 0);  
191 ctx->exception = EXCP_MTMSR; 190 ctx->exception = EXCP_MTMSR;
192 } 191 }
193 192
@@ -2051,11 +2050,19 @@ static inline void gen_op_mfspr (DisasContext *ctx) @@ -2051,11 +2050,19 @@ static inline void gen_op_mfspr (DisasContext *ctx)
2051 gen_op_store_T0_gpr(rD(ctx->opcode)); 2050 gen_op_store_T0_gpr(rD(ctx->opcode));
2052 } else { 2051 } else {
2053 /* Privilege exception */ 2052 /* Privilege exception */
  2053 + if (loglevel) {
  2054 + fprintf(logfile, "Trying to read priviledged spr %d %03x\n",
  2055 + sprn, sprn);
  2056 + }
2054 printf("Trying to read priviledged spr %d %03x\n", sprn, sprn); 2057 printf("Trying to read priviledged spr %d %03x\n", sprn, sprn);
2055 RET_PRIVREG(ctx); 2058 RET_PRIVREG(ctx);
2056 } 2059 }
2057 } else { 2060 } else {
2058 /* Not defined */ 2061 /* Not defined */
  2062 + if (loglevel) {
  2063 + fprintf(logfile, "Trying to read invalid spr %d %03x\n",
  2064 + sprn, sprn);
  2065 + }
2059 printf("Trying to read invalid spr %d %03x\n", sprn, sprn); 2066 printf("Trying to read invalid spr %d %03x\n", sprn, sprn);
2060 RET_EXCP(ctx, EXCP_PROGRAM, EXCP_INVAL | EXCP_INVAL_SPR); 2067 RET_EXCP(ctx, EXCP_PROGRAM, EXCP_INVAL | EXCP_INVAL_SPR);
2061 } 2068 }
@@ -2093,7 +2100,7 @@ GEN_HANDLER(mtmsr, 0x1F, 0x12, 0x04, 0x001FF801, PPC_MISC) @@ -2093,7 +2100,7 @@ GEN_HANDLER(mtmsr, 0x1F, 0x12, 0x04, 0x001FF801, PPC_MISC)
2093 gen_op_load_gpr_T0(rS(ctx->opcode)); 2100 gen_op_load_gpr_T0(rS(ctx->opcode));
2094 gen_op_store_msr(); 2101 gen_op_store_msr();
2095 /* Must stop the translation as machine state (may have) changed */ 2102 /* Must stop the translation as machine state (may have) changed */
2096 - RET_MTMSR(ctx); 2103 + RET_STOP(ctx);
2097 #endif 2104 #endif
2098 } 2105 }
2099 2106
@@ -2115,11 +2122,19 @@ GEN_HANDLER(mtspr, 0x1F, 0x13, 0x0E, 0x00000001, PPC_MISC) @@ -2115,11 +2122,19 @@ GEN_HANDLER(mtspr, 0x1F, 0x13, 0x0E, 0x00000001, PPC_MISC)
2115 (*write_cb)(ctx, sprn); 2122 (*write_cb)(ctx, sprn);
2116 } else { 2123 } else {
2117 /* Privilege exception */ 2124 /* Privilege exception */
  2125 + if (loglevel) {
  2126 + fprintf(logfile, "Trying to write priviledged spr %d %03x\n",
  2127 + sprn, sprn);
  2128 + }
2118 printf("Trying to write priviledged spr %d %03x\n", sprn, sprn); 2129 printf("Trying to write priviledged spr %d %03x\n", sprn, sprn);
2119 RET_PRIVREG(ctx); 2130 RET_PRIVREG(ctx);
2120 } 2131 }
2121 } else { 2132 } else {
2122 /* Not defined */ 2133 /* Not defined */
  2134 + if (loglevel) {
  2135 + fprintf(logfile, "Trying to write invalid spr %d %03x\n",
  2136 + sprn, sprn);
  2137 + }
2123 printf("Trying to write invalid spr %d %03x\n", sprn, sprn); 2138 printf("Trying to write invalid spr %d %03x\n", sprn, sprn);
2124 RET_EXCP(ctx, EXCP_PROGRAM, EXCP_INVAL | EXCP_INVAL_SPR); 2139 RET_EXCP(ctx, EXCP_PROGRAM, EXCP_INVAL | EXCP_INVAL_SPR);
2125 } 2140 }
@@ -2278,7 +2293,7 @@ GEN_HANDLER(mtsr, 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT) @@ -2278,7 +2293,7 @@ GEN_HANDLER(mtsr, 0x1F, 0x12, 0x06, 0x0010F801, PPC_SEGMENT)
2278 } 2293 }
2279 gen_op_load_gpr_T0(rS(ctx->opcode)); 2294 gen_op_load_gpr_T0(rS(ctx->opcode));
2280 gen_op_store_sr(SR(ctx->opcode)); 2295 gen_op_store_sr(SR(ctx->opcode));
2281 - RET_MTMSR(ctx); 2296 + RET_STOP(ctx);
2282 #endif 2297 #endif
2283 } 2298 }
2284 2299
@@ -2295,7 +2310,7 @@ GEN_HANDLER(mtsrin, 0x1F, 0x12, 0x07, 0x001F0001, PPC_SEGMENT) @@ -2295,7 +2310,7 @@ GEN_HANDLER(mtsrin, 0x1F, 0x12, 0x07, 0x001F0001, PPC_SEGMENT)
2295 gen_op_load_gpr_T0(rS(ctx->opcode)); 2310 gen_op_load_gpr_T0(rS(ctx->opcode));
2296 gen_op_load_gpr_T1(rB(ctx->opcode)); 2311 gen_op_load_gpr_T1(rB(ctx->opcode));
2297 gen_op_store_srin(); 2312 gen_op_store_srin();
2298 - RET_MTMSR(ctx); 2313 + RET_STOP(ctx);
2299 #endif 2314 #endif
2300 } 2315 }
2301 2316
@@ -2314,7 +2329,7 @@ GEN_HANDLER(tlbia, 0x1F, 0x12, 0x0B, 0x03FFFC01, PPC_MEM_TLBIA) @@ -2314,7 +2329,7 @@ GEN_HANDLER(tlbia, 0x1F, 0x12, 0x0B, 0x03FFFC01, PPC_MEM_TLBIA)
2314 return; 2329 return;
2315 } 2330 }
2316 gen_op_tlbia(); 2331 gen_op_tlbia();
2317 - RET_MTMSR(ctx); 2332 + RET_STOP(ctx);
2318 #endif 2333 #endif
2319 } 2334 }
2320 2335
@@ -2330,7 +2345,7 @@ GEN_HANDLER(tlbie, 0x1F, 0x12, 0x09, 0x03FF0001, PPC_MEM) @@ -2330,7 +2345,7 @@ GEN_HANDLER(tlbie, 0x1F, 0x12, 0x09, 0x03FF0001, PPC_MEM)
2330 } 2345 }
2331 gen_op_load_gpr_T0(rB(ctx->opcode)); 2346 gen_op_load_gpr_T0(rB(ctx->opcode));
2332 gen_op_tlbie(); 2347 gen_op_tlbie();
2333 - RET_MTMSR(ctx); 2348 + RET_STOP(ctx);
2334 #endif 2349 #endif
2335 } 2350 }
2336 2351
@@ -2347,7 +2362,7 @@ GEN_HANDLER(tlbsync, 0x1F, 0x16, 0x11, 0x03FFF801, PPC_MEM) @@ -2347,7 +2362,7 @@ GEN_HANDLER(tlbsync, 0x1F, 0x16, 0x11, 0x03FFF801, PPC_MEM)
2347 /* This has no effect: it should ensure that all previous 2362 /* This has no effect: it should ensure that all previous
2348 * tlbie have completed 2363 * tlbie have completed
2349 */ 2364 */
2350 - RET_MTMSR(ctx); 2365 + RET_STOP(ctx);
2351 #endif 2366 #endif
2352 } 2367 }
2353 2368