提交 d0e39c5d 编写于 作者: A Andreas Färber

target-ppc: Use PowerPCCPU in PowerPCCPUClass::handle_mmu_fault hook

Signed-off-by: NAndreas Färber <afaerber@suse.de>
上级 611d4f99
...@@ -38,6 +38,8 @@ ...@@ -38,6 +38,8 @@
#define POWERPC_CPU_GET_CLASS(obj) \ #define POWERPC_CPU_GET_CLASS(obj) \
OBJECT_GET_CLASS(PowerPCCPUClass, (obj), TYPE_POWERPC_CPU) OBJECT_GET_CLASS(PowerPCCPUClass, (obj), TYPE_POWERPC_CPU)
typedef struct PowerPCCPU PowerPCCPU;
/** /**
* PowerPCCPUClass: * PowerPCCPUClass:
* @parent_realize: The parent class' realize handler. * @parent_realize: The parent class' realize handler.
...@@ -71,7 +73,7 @@ typedef struct PowerPCCPUClass { ...@@ -71,7 +73,7 @@ typedef struct PowerPCCPUClass {
void (*init_proc)(CPUPPCState *env); void (*init_proc)(CPUPPCState *env);
int (*check_pow)(CPUPPCState *env); int (*check_pow)(CPUPPCState *env);
#if defined(CONFIG_SOFTMMU) #if defined(CONFIG_SOFTMMU)
int (*handle_mmu_fault)(CPUPPCState *env, target_ulong eaddr, int rwx, int (*handle_mmu_fault)(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
int mmu_idx); int mmu_idx);
#endif #endif
} PowerPCCPUClass; } PowerPCCPUClass;
...@@ -83,14 +85,14 @@ typedef struct PowerPCCPUClass { ...@@ -83,14 +85,14 @@ typedef struct PowerPCCPUClass {
* *
* A PowerPC CPU. * A PowerPC CPU.
*/ */
typedef struct PowerPCCPU { struct PowerPCCPU {
/*< private >*/ /*< private >*/
CPUState parent_obj; CPUState parent_obj;
/*< public >*/ /*< public >*/
CPUPPCState env; CPUPPCState env;
int cpu_dt_id; int cpu_dt_id;
} PowerPCCPU; };
static inline PowerPCCPU *ppc_env_get_cpu(CPUPPCState *env) static inline PowerPCCPU *ppc_env_get_cpu(CPUPPCState *env)
{ {
......
...@@ -381,10 +381,11 @@ static hwaddr ppc_hash32_pte_raddr(target_ulong sr, ppc_hash_pte32_t pte, ...@@ -381,10 +381,11 @@ static hwaddr ppc_hash32_pte_raddr(target_ulong sr, ppc_hash_pte32_t pte,
return (rpn & ~mask) | (eaddr & mask); return (rpn & ~mask) | (eaddr & mask);
} }
int ppc_hash32_handle_mmu_fault(CPUPPCState *env, target_ulong eaddr, int rwx, int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr, int rwx,
int mmu_idx) int mmu_idx)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUState *cs = CPU(cpu);
CPUPPCState *env = &cpu->env;
target_ulong sr; target_ulong sr;
hwaddr pte_offset; hwaddr pte_offset;
ppc_hash_pte32_t pte; ppc_hash_pte32_t pte;
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
hwaddr get_pteg_offset32(CPUPPCState *env, hwaddr hash); hwaddr get_pteg_offset32(CPUPPCState *env, hwaddr hash);
hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong addr); hwaddr ppc_hash32_get_phys_page_debug(CPUPPCState *env, target_ulong addr);
int ppc_hash32_handle_mmu_fault(CPUPPCState *env, target_ulong address, int rw, int ppc_hash32_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw,
int mmu_idx); int mmu_idx);
/* /*
......
...@@ -454,10 +454,11 @@ static hwaddr ppc_hash64_pte_raddr(ppc_slb_t *slb, ppc_hash_pte64_t pte, ...@@ -454,10 +454,11 @@ static hwaddr ppc_hash64_pte_raddr(ppc_slb_t *slb, ppc_hash_pte64_t pte,
return (rpn & ~mask) | (eaddr & mask); return (rpn & ~mask) | (eaddr & mask);
} }
int ppc_hash64_handle_mmu_fault(CPUPPCState *env, target_ulong eaddr, int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong eaddr,
int rwx, int mmu_idx) int rwx, int mmu_idx)
{ {
CPUState *cs = CPU(ppc_env_get_cpu(env)); CPUState *cs = CPU(cpu);
CPUPPCState *env = &cpu->env;
ppc_slb_t *slb; ppc_slb_t *slb;
hwaddr pte_offset; hwaddr pte_offset;
ppc_hash_pte64_t pte; ppc_hash_pte64_t pte;
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
void dump_slb(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env); void dump_slb(FILE *f, fprintf_function cpu_fprintf, CPUPPCState *env);
int ppc_store_slb (CPUPPCState *env, target_ulong rb, target_ulong rs); int ppc_store_slb (CPUPPCState *env, target_ulong rb, target_ulong rs);
hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr); hwaddr ppc_hash64_get_phys_page_debug(CPUPPCState *env, target_ulong addr);
int ppc_hash64_handle_mmu_fault(CPUPPCState *env, target_ulong address, int rw, int ppc_hash64_handle_mmu_fault(PowerPCCPU *cpu, target_ulong address, int rw,
int mmu_idx); int mmu_idx);
void ppc_hash64_store_hpte(CPUPPCState *env, target_ulong index, void ppc_hash64_store_hpte(CPUPPCState *env, target_ulong index,
target_ulong pte0, target_ulong pte1); target_ulong pte0, target_ulong pte1);
......
...@@ -2902,7 +2902,7 @@ void tlb_fill(CPUState *cs, target_ulong addr, int is_write, int mmu_idx, ...@@ -2902,7 +2902,7 @@ void tlb_fill(CPUState *cs, target_ulong addr, int is_write, int mmu_idx,
int ret; int ret;
if (pcc->handle_mmu_fault) { if (pcc->handle_mmu_fault) {
ret = pcc->handle_mmu_fault(env, addr, is_write, mmu_idx); ret = pcc->handle_mmu_fault(cpu, addr, is_write, mmu_idx);
} else { } else {
ret = cpu_ppc_handle_mmu_fault(env, addr, is_write, mmu_idx); ret = cpu_ppc_handle_mmu_fault(env, addr, is_write, mmu_idx);
} }
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册