mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
target/sparc: Use env_cpu, env_archcpu
Cleanup in the boilerplate that each target must define. Replace sparc_env_get_cpu with env_archcpu. The combination CPU(sparc_env_get_cpu) should have used ENV_GET_CPU to begin; use env_cpu now. Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Philippe Mathieu-Daudé <philmd@redhat.com> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
dad1c8ecc7
commit
5a59fbce91
10 changed files with 32 additions and 40 deletions
|
@ -122,13 +122,13 @@ static uint64_t ultrasparc_tag_target(uint64_t tag_access_register)
|
|||
|
||||
static void replace_tlb_entry(SparcTLBEntry *tlb,
|
||||
uint64_t tlb_tag, uint64_t tlb_tte,
|
||||
CPUSPARCState *env1)
|
||||
CPUSPARCState *env)
|
||||
{
|
||||
target_ulong mask, size, va, offset;
|
||||
|
||||
/* flush page range if translation is valid */
|
||||
if (TTE_IS_VALID(tlb->tte)) {
|
||||
CPUState *cs = CPU(sparc_env_get_cpu(env1));
|
||||
CPUState *cs = env_cpu(env);
|
||||
|
||||
size = 8192ULL << 3 * TTE_PGSIZE(tlb->tte);
|
||||
mask = 1ULL + ~size;
|
||||
|
@ -499,7 +499,7 @@ uint64_t helper_ld_asi(CPUSPARCState *env, target_ulong addr,
|
|||
{
|
||||
int size = 1 << (memop & MO_SIZE);
|
||||
int sign = memop & MO_SIGN;
|
||||
CPUState *cs = CPU(sparc_env_get_cpu(env));
|
||||
CPUState *cs = env_cpu(env);
|
||||
uint64_t ret = 0;
|
||||
#if defined(DEBUG_MXCC) || defined(DEBUG_ASI)
|
||||
uint32_t last_addr = addr;
|
||||
|
@ -725,8 +725,7 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, uint64_t val,
|
|||
int asi, uint32_t memop)
|
||||
{
|
||||
int size = 1 << (memop & MO_SIZE);
|
||||
SPARCCPU *cpu = sparc_env_get_cpu(env);
|
||||
CPUState *cs = CPU(cpu);
|
||||
CPUState *cs = env_cpu(env);
|
||||
|
||||
do_check_align(env, addr, size - 1, GETPC());
|
||||
switch (asi) {
|
||||
|
@ -874,13 +873,13 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, uint64_t val,
|
|||
DPRINTF_MMU("mmu flush level %d\n", mmulev);
|
||||
switch (mmulev) {
|
||||
case 0: /* flush page */
|
||||
tlb_flush_page(CPU(cpu), addr & 0xfffff000);
|
||||
tlb_flush_page(cs, addr & 0xfffff000);
|
||||
break;
|
||||
case 1: /* flush segment (256k) */
|
||||
case 2: /* flush region (16M) */
|
||||
case 3: /* flush context (4G) */
|
||||
case 4: /* flush entire */
|
||||
tlb_flush(CPU(cpu));
|
||||
tlb_flush(cs);
|
||||
break;
|
||||
default:
|
||||
break;
|
||||
|
@ -905,7 +904,7 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, uint64_t val,
|
|||
are invalid in normal mode. */
|
||||
if ((oldreg ^ env->mmuregs[reg])
|
||||
& (MMU_NF | env->def.mmu_bm)) {
|
||||
tlb_flush(CPU(cpu));
|
||||
tlb_flush(cs);
|
||||
}
|
||||
break;
|
||||
case 1: /* Context Table Pointer Register */
|
||||
|
@ -916,7 +915,7 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, uint64_t val,
|
|||
if (oldreg != env->mmuregs[reg]) {
|
||||
/* we flush when the MMU context changes because
|
||||
QEMU has no MMU context support */
|
||||
tlb_flush(CPU(cpu));
|
||||
tlb_flush(cs);
|
||||
}
|
||||
break;
|
||||
case 3: /* Synchronous Fault Status Register with Clear */
|
||||
|
@ -1027,8 +1026,7 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, uint64_t val,
|
|||
case ASI_USERTXT: /* User code access, XXX */
|
||||
case ASI_KERNELTXT: /* Supervisor code access, XXX */
|
||||
default:
|
||||
cpu_unassigned_access(CPU(sparc_env_get_cpu(env)),
|
||||
addr, true, false, asi, size);
|
||||
cpu_unassigned_access(cs, addr, true, false, asi, size);
|
||||
break;
|
||||
|
||||
case ASI_USERDATA: /* User data access */
|
||||
|
@ -1175,7 +1173,7 @@ uint64_t helper_ld_asi(CPUSPARCState *env, target_ulong addr,
|
|||
{
|
||||
int size = 1 << (memop & MO_SIZE);
|
||||
int sign = memop & MO_SIGN;
|
||||
CPUState *cs = CPU(sparc_env_get_cpu(env));
|
||||
CPUState *cs = env_cpu(env);
|
||||
uint64_t ret = 0;
|
||||
#if defined(DEBUG_ASI)
|
||||
target_ulong last_addr = addr;
|
||||
|
@ -1481,8 +1479,7 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, target_ulong val,
|
|||
int asi, uint32_t memop)
|
||||
{
|
||||
int size = 1 << (memop & MO_SIZE);
|
||||
SPARCCPU *cpu = sparc_env_get_cpu(env);
|
||||
CPUState *cs = CPU(cpu);
|
||||
CPUState *cs = env_cpu(env);
|
||||
|
||||
#ifdef DEBUG_ASI
|
||||
dump_asi("write", addr, asi, size, val);
|
||||
|
@ -1686,13 +1683,13 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, target_ulong val,
|
|||
env->dmmu.mmu_primary_context = val;
|
||||
/* can be optimized to only flush MMU_USER_IDX
|
||||
and MMU_KERNEL_IDX entries */
|
||||
tlb_flush(CPU(cpu));
|
||||
tlb_flush(cs);
|
||||
break;
|
||||
case 2: /* Secondary context */
|
||||
env->dmmu.mmu_secondary_context = val;
|
||||
/* can be optimized to only flush MMU_USER_SECONDARY_IDX
|
||||
and MMU_KERNEL_SECONDARY_IDX entries */
|
||||
tlb_flush(CPU(cpu));
|
||||
tlb_flush(cs);
|
||||
break;
|
||||
case 5: /* TSB access */
|
||||
DPRINTF_MMU("dmmu TSB write: 0x%016" PRIx64 " -> 0x%016"
|
||||
|
@ -1768,13 +1765,13 @@ void helper_st_asi(CPUSPARCState *env, target_ulong addr, target_ulong val,
|
|||
case 1:
|
||||
env->dmmu.mmu_primary_context = val;
|
||||
env->immu.mmu_primary_context = val;
|
||||
tlb_flush_by_mmuidx(CPU(cpu),
|
||||
tlb_flush_by_mmuidx(cs,
|
||||
(1 << MMU_USER_IDX) | (1 << MMU_KERNEL_IDX));
|
||||
break;
|
||||
case 2:
|
||||
env->dmmu.mmu_secondary_context = val;
|
||||
env->immu.mmu_secondary_context = val;
|
||||
tlb_flush_by_mmuidx(CPU(cpu),
|
||||
tlb_flush_by_mmuidx(cs,
|
||||
(1 << MMU_USER_SECONDARY_IDX) |
|
||||
(1 << MMU_KERNEL_SECONDARY_IDX));
|
||||
break;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue