mirror of https://github.com/xemu-project/xemu.git
target-xtensa: implement CPENABLE and PRID SRs
Signed-off-by: Max Filippov <jcmvbkbc@gmail.com> Signed-off-by: Blue Swirl <blauwirbel@gmail.com>
This commit is contained in:
parent
772177c194
commit
f3df4c04d8
|
@ -55,6 +55,7 @@ static void xtensa_init(ram_addr_t ram_size,
|
||||||
exit(1);
|
exit(1);
|
||||||
}
|
}
|
||||||
qemu_register_reset(xtensa_sample_reset, env);
|
qemu_register_reset(xtensa_sample_reset, env);
|
||||||
|
env->sregs[PRID] = n;
|
||||||
}
|
}
|
||||||
|
|
||||||
ram = g_malloc(sizeof(*ram));
|
ram = g_malloc(sizeof(*ram));
|
||||||
|
|
|
@ -118,12 +118,14 @@ enum {
|
||||||
DEPC = 192,
|
DEPC = 192,
|
||||||
EPS2 = 194,
|
EPS2 = 194,
|
||||||
EXCSAVE1 = 209,
|
EXCSAVE1 = 209,
|
||||||
|
CPENABLE = 224,
|
||||||
INTSET = 226,
|
INTSET = 226,
|
||||||
INTCLEAR = 227,
|
INTCLEAR = 227,
|
||||||
INTENABLE = 228,
|
INTENABLE = 228,
|
||||||
PS = 230,
|
PS = 230,
|
||||||
EXCCAUSE = 232,
|
EXCCAUSE = 232,
|
||||||
CCOUNT = 234,
|
CCOUNT = 234,
|
||||||
|
PRID = 235,
|
||||||
EXCVADDR = 238,
|
EXCVADDR = 238,
|
||||||
CCOMPARE = 240,
|
CCOMPARE = 240,
|
||||||
};
|
};
|
||||||
|
|
|
@ -101,12 +101,14 @@ static const char * const sregnames[256] = {
|
||||||
[EXCSAVE1 + 4] = "EXCSAVE5",
|
[EXCSAVE1 + 4] = "EXCSAVE5",
|
||||||
[EXCSAVE1 + 5] = "EXCSAVE6",
|
[EXCSAVE1 + 5] = "EXCSAVE6",
|
||||||
[EXCSAVE1 + 6] = "EXCSAVE7",
|
[EXCSAVE1 + 6] = "EXCSAVE7",
|
||||||
|
[CPENABLE] = "CPENABLE",
|
||||||
[INTSET] = "INTSET",
|
[INTSET] = "INTSET",
|
||||||
[INTCLEAR] = "INTCLEAR",
|
[INTCLEAR] = "INTCLEAR",
|
||||||
[INTENABLE] = "INTENABLE",
|
[INTENABLE] = "INTENABLE",
|
||||||
[PS] = "PS",
|
[PS] = "PS",
|
||||||
[EXCCAUSE] = "EXCCAUSE",
|
[EXCCAUSE] = "EXCCAUSE",
|
||||||
[CCOUNT] = "CCOUNT",
|
[CCOUNT] = "CCOUNT",
|
||||||
|
[PRID] = "PRID",
|
||||||
[EXCVADDR] = "EXCVADDR",
|
[EXCVADDR] = "EXCVADDR",
|
||||||
[CCOMPARE] = "CCOMPARE0",
|
[CCOMPARE] = "CCOMPARE0",
|
||||||
[CCOMPARE + 1] = "CCOMPARE1",
|
[CCOMPARE + 1] = "CCOMPARE1",
|
||||||
|
@ -476,6 +478,10 @@ static void gen_wsr_ps(DisasContext *dc, uint32_t sr, TCGv_i32 v)
|
||||||
gen_jumpi_check_loop_end(dc, -1);
|
gen_jumpi_check_loop_end(dc, -1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void gen_wsr_prid(DisasContext *dc, uint32_t sr, TCGv_i32 v)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
static void gen_wsr_ccompare(DisasContext *dc, uint32_t sr, TCGv_i32 v)
|
static void gen_wsr_ccompare(DisasContext *dc, uint32_t sr, TCGv_i32 v)
|
||||||
{
|
{
|
||||||
uint32_t id = sr - CCOMPARE;
|
uint32_t id = sr - CCOMPARE;
|
||||||
|
@ -502,6 +508,7 @@ static void gen_wsr(DisasContext *dc, uint32_t sr, TCGv_i32 s)
|
||||||
[INTCLEAR] = gen_wsr_intclear,
|
[INTCLEAR] = gen_wsr_intclear,
|
||||||
[INTENABLE] = gen_wsr_intenable,
|
[INTENABLE] = gen_wsr_intenable,
|
||||||
[PS] = gen_wsr_ps,
|
[PS] = gen_wsr_ps,
|
||||||
|
[PRID] = gen_wsr_prid,
|
||||||
[CCOMPARE] = gen_wsr_ccompare,
|
[CCOMPARE] = gen_wsr_ccompare,
|
||||||
[CCOMPARE + 1] = gen_wsr_ccompare,
|
[CCOMPARE + 1] = gen_wsr_ccompare,
|
||||||
[CCOMPARE + 2] = gen_wsr_ccompare,
|
[CCOMPARE + 2] = gen_wsr_ccompare,
|
||||||
|
|
Loading…
Reference in New Issue