mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-09 18:44:58 -06:00
xtensa queue 2013-07-29
-----BEGIN PGP SIGNATURE----- Version: GnuPG v1.4.13 (GNU/Linux) iQIcBAABAgAGBQJR9oJeAAoJEFH5zJH4P6BEqzQQAIdlk2X1s6xrPhxiuC0xQmK6 eHoYVVqVy8wQiXXY+NgbTK6VsbEI/2B58lngFKkUiXQggWHIDUytYpcwymZqVSRS 9r+VEwy/sa6R/hAGkl7Igs++bsPEkwQqH2b0kDwX+Mi0sCYXZ6Ihe+kqGBkIjzUO QXvk3LIVF+ESCeroFUOifgAYncMVDN6er8THJnNHUvfP2lAobkYbh4jbBhmOyKJ6 kjh0I/rndEyyF0gVfhzPJpdb5whXBlIwjN1CjvoER3Ax24rnfJcBTuDvhV/vtuZY dPEOiN/ZDyCeowIMuFDxbtdA5oH2nc6Sm2mqk6iB669ki87vn5vLI6nSAp2C5zAY CMPP9JNkhWsBcvjPQOMws/aloru5G2g7ljp7Drd4Ij/gwvlEpAozFtzjhc7QbcMc 6h7spZ01pRqqICimgUHVf6hYZNeRvhQvzybTA9ccIa0yhyTKTpzQwhNWl+6a2O0x 4w6SV3RJ9Z+eftS3MOlMpe7raJMg0F5rJQak73hkc07jDB8iaUsJk/8ZAPzT3Y8x HwbCE6bGU/ipO8xcGpPC4Lc+vY0+CQXJWRq/x/AiY8SAR6QwRvb9h+Sw0T/5/nYg 0D12NV5C33ou5RACXdp76Mpxig2rnusWsAj+XSEU8QLB2/TrJ2hMGIdCXUyajCGy pr3+BwxWdZkKH7N3oi61 =JPm8 -----END PGP SIGNATURE----- Merge remote-tracking branch 'filippov/tags/20130729-xtensa' into staging xtensa queue 2013-07-29 * filippov/tags/20130729-xtensa: target-xtensa: check register window inline target-xtensa: don't generate dead code to access invalid SRs tests/tcg/xtensa: Fix out-of-tree build target-xtensa: avoid double-stopping at breakpoints target-xtensa: add fallthrough markers target-xtensa: add extui unit test Conflicts: configure Signed-off-by: Anthony Liguori <aliguori@us.ibm.com>
This commit is contained in:
commit
64160cd2a3
6 changed files with 93 additions and 34 deletions
|
@ -484,6 +484,7 @@ static inline int cpu_mmu_index(CPUXtensaState *env)
|
|||
#define XTENSA_TBFLAG_ICOUNT 0x20
|
||||
#define XTENSA_TBFLAG_CPENABLE_MASK 0x3fc0
|
||||
#define XTENSA_TBFLAG_CPENABLE_SHIFT 6
|
||||
#define XTENSA_TBFLAG_EXCEPTION 0x4000
|
||||
|
||||
static inline void cpu_get_tb_cpu_state(CPUXtensaState *env, target_ulong *pc,
|
||||
target_ulong *cs_base, int *flags)
|
||||
|
@ -510,6 +511,9 @@ static inline void cpu_get_tb_cpu_state(CPUXtensaState *env, target_ulong *pc,
|
|||
if (xtensa_option_enabled(env->config, XTENSA_OPTION_COPROCESSOR)) {
|
||||
*flags |= env->sregs[CPENABLE] << XTENSA_TBFLAG_CPENABLE_SHIFT;
|
||||
}
|
||||
if (ENV_GET_CPU(env)->singlestep_enabled && env->exception_taken) {
|
||||
*flags |= XTENSA_TBFLAG_EXCEPTION;
|
||||
}
|
||||
}
|
||||
|
||||
#include "exec/cpu-all.h"
|
||||
|
|
|
@ -96,6 +96,9 @@ static void tb_invalidate_virtual_addr(CPUXtensaState *env, uint32_t vaddr)
|
|||
void HELPER(exception)(CPUXtensaState *env, uint32_t excp)
|
||||
{
|
||||
env->exception_index = excp;
|
||||
if (excp == EXCP_DEBUG) {
|
||||
env->exception_taken = 0;
|
||||
}
|
||||
cpu_loop_exit(env);
|
||||
}
|
||||
|
||||
|
@ -448,8 +451,10 @@ void HELPER(check_atomctl)(CPUXtensaState *env, uint32_t pc, uint32_t vaddr)
|
|||
switch (access & PAGE_CACHE_MASK) {
|
||||
case PAGE_CACHE_WB:
|
||||
atomctl >>= 2;
|
||||
/* fall through */
|
||||
case PAGE_CACHE_WT:
|
||||
atomctl >>= 2;
|
||||
/* fall through */
|
||||
case PAGE_CACHE_BYPASS:
|
||||
if ((atomctl & 0x3) == 0) {
|
||||
HELPER(exception_cause_vaddr)(env, pc,
|
||||
|
|
|
@ -305,16 +305,21 @@ static void gen_left_shift_sar(DisasContext *dc, TCGv_i32 sa)
|
|||
tcg_temp_free(tmp);
|
||||
}
|
||||
|
||||
static void gen_advance_ccount(DisasContext *dc)
|
||||
static void gen_advance_ccount_cond(DisasContext *dc)
|
||||
{
|
||||
if (dc->ccount_delta > 0) {
|
||||
TCGv_i32 tmp = tcg_const_i32(dc->ccount_delta);
|
||||
dc->ccount_delta = 0;
|
||||
gen_helper_advance_ccount(cpu_env, tmp);
|
||||
tcg_temp_free(tmp);
|
||||
}
|
||||
}
|
||||
|
||||
static void gen_advance_ccount(DisasContext *dc)
|
||||
{
|
||||
gen_advance_ccount_cond(dc);
|
||||
dc->ccount_delta = 0;
|
||||
}
|
||||
|
||||
static void reset_used_window(DisasContext *dc)
|
||||
{
|
||||
dc->used_window = 0;
|
||||
|
@ -491,7 +496,7 @@ static void gen_brcondi(DisasContext *dc, TCGCond cond,
|
|||
tcg_temp_free(tmp);
|
||||
}
|
||||
|
||||
static void gen_check_sr(DisasContext *dc, uint32_t sr, unsigned access)
|
||||
static bool gen_check_sr(DisasContext *dc, uint32_t sr, unsigned access)
|
||||
{
|
||||
if (!xtensa_option_bits_enabled(dc->config, sregnames[sr].opt_bits)) {
|
||||
if (sregnames[sr].name) {
|
||||
|
@ -500,6 +505,7 @@ static void gen_check_sr(DisasContext *dc, uint32_t sr, unsigned access)
|
|||
qemu_log("SR %d is not implemented\n", sr);
|
||||
}
|
||||
gen_exception_cause(dc, ILLEGAL_INSTRUCTION_CAUSE);
|
||||
return false;
|
||||
} else if (!(sregnames[sr].access & access)) {
|
||||
static const char * const access_text[] = {
|
||||
[SR_R] = "rsr",
|
||||
|
@ -510,7 +516,9 @@ static void gen_check_sr(DisasContext *dc, uint32_t sr, unsigned access)
|
|||
qemu_log("SR %s is not available for %s\n", sregnames[sr].name,
|
||||
access_text[access]);
|
||||
gen_exception_cause(dc, ILLEGAL_INSTRUCTION_CAUSE);
|
||||
return false;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
static void gen_rsr_ccount(DisasContext *dc, TCGv_i32 d, uint32_t sr)
|
||||
|
@ -826,15 +834,27 @@ static void gen_window_check1(DisasContext *dc, unsigned r1)
|
|||
}
|
||||
if (option_enabled(dc, XTENSA_OPTION_WINDOWED_REGISTER) &&
|
||||
r1 / 4 > dc->used_window) {
|
||||
TCGv_i32 pc = tcg_const_i32(dc->pc);
|
||||
TCGv_i32 w = tcg_const_i32(r1 / 4);
|
||||
int label = gen_new_label();
|
||||
TCGv_i32 ws = tcg_temp_new_i32();
|
||||
|
||||
dc->used_window = r1 / 4;
|
||||
gen_advance_ccount(dc);
|
||||
gen_helper_window_check(cpu_env, pc, w);
|
||||
tcg_gen_deposit_i32(ws, cpu_SR[WINDOW_START], cpu_SR[WINDOW_START],
|
||||
dc->config->nareg / 4, dc->config->nareg / 4);
|
||||
tcg_gen_shr_i32(ws, ws, cpu_SR[WINDOW_BASE]);
|
||||
tcg_gen_andi_i32(ws, ws, (2 << (r1 / 4)) - 2);
|
||||
tcg_gen_brcondi_i32(TCG_COND_EQ, ws, 0, label);
|
||||
{
|
||||
TCGv_i32 pc = tcg_const_i32(dc->pc);
|
||||
TCGv_i32 w = tcg_const_i32(r1 / 4);
|
||||
|
||||
tcg_temp_free(w);
|
||||
tcg_temp_free(pc);
|
||||
gen_advance_ccount_cond(dc);
|
||||
gen_helper_window_check(cpu_env, pc, w);
|
||||
|
||||
tcg_temp_free(w);
|
||||
tcg_temp_free(pc);
|
||||
}
|
||||
gen_set_label(label);
|
||||
tcg_temp_free(ws);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1482,9 +1502,9 @@ static void disas_xtensa_insn(CPUXtensaState *env, DisasContext *dc)
|
|||
break;
|
||||
|
||||
case 6: /*XSR*/
|
||||
{
|
||||
if (gen_check_sr(dc, RSR_SR, SR_X)) {
|
||||
TCGv_i32 tmp = tcg_temp_new_i32();
|
||||
gen_check_sr(dc, RSR_SR, SR_X);
|
||||
|
||||
if (RSR_SR >= 64) {
|
||||
gen_check_privilege(dc);
|
||||
}
|
||||
|
@ -1707,21 +1727,23 @@ static void disas_xtensa_insn(CPUXtensaState *env, DisasContext *dc)
|
|||
case 3: /*RST3*/
|
||||
switch (OP2) {
|
||||
case 0: /*RSR*/
|
||||
gen_check_sr(dc, RSR_SR, SR_R);
|
||||
if (RSR_SR >= 64) {
|
||||
gen_check_privilege(dc);
|
||||
if (gen_check_sr(dc, RSR_SR, SR_R)) {
|
||||
if (RSR_SR >= 64) {
|
||||
gen_check_privilege(dc);
|
||||
}
|
||||
gen_window_check1(dc, RRR_T);
|
||||
gen_rsr(dc, cpu_R[RRR_T], RSR_SR);
|
||||
}
|
||||
gen_window_check1(dc, RRR_T);
|
||||
gen_rsr(dc, cpu_R[RRR_T], RSR_SR);
|
||||
break;
|
||||
|
||||
case 1: /*WSR*/
|
||||
gen_check_sr(dc, RSR_SR, SR_W);
|
||||
if (RSR_SR >= 64) {
|
||||
gen_check_privilege(dc);
|
||||
if (gen_check_sr(dc, RSR_SR, SR_W)) {
|
||||
if (RSR_SR >= 64) {
|
||||
gen_check_privilege(dc);
|
||||
}
|
||||
gen_window_check1(dc, RRR_T);
|
||||
gen_wsr(dc, RSR_SR, cpu_R[RRR_T]);
|
||||
}
|
||||
gen_window_check1(dc, RRR_T);
|
||||
gen_wsr(dc, RSR_SR, cpu_R[RRR_T]);
|
||||
break;
|
||||
|
||||
case 2: /*SEXTu*/
|
||||
|
@ -2918,8 +2940,7 @@ void gen_intermediate_code_internal(XtensaCPU *cpu,
|
|||
|
||||
gen_tb_start();
|
||||
|
||||
if (cs->singlestep_enabled && env->exception_taken) {
|
||||
env->exception_taken = 0;
|
||||
if (tb->flags & XTENSA_TBFLAG_EXCEPTION) {
|
||||
tcg_gen_movi_i32(cpu_pc, dc.pc);
|
||||
gen_exception(&dc, EXCP_DEBUG);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue