[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 2/9] target-ppc: Handle memory-forced I/O controller
From: |
Alexander Graf |
Subject: |
[Qemu-devel] [PATCH 2/9] target-ppc: Handle memory-forced I/O controller access |
Date: |
Fri, 17 Jun 2011 16:43:57 +0200 |
From: Hervé Poussineau <address@hidden>
On at least the PowerPC 601, a direct-store (T=1) with bus unit ID 0x07F
is special-cased as memory-forced I/O controller access. It is supposed
to be checked immediately if T=1, bypassing all protection mechanisms
and acting cache-inhibited and global.
Signed-off-by: Hervé Poussineau <address@hidden>
Simplified by avoiding reindentation. Added explanatory comments.
Cc: Alexander Graf <address@hidden>
Signed-off-by: Andreas Färber <address@hidden>
Signed-off-by: Alexander Graf <address@hidden>
---
target-ppc/helper.c | 16 ++++++++++++++++
1 files changed, 16 insertions(+), 0 deletions(-)
diff --git a/target-ppc/helper.c b/target-ppc/helper.c
index cf2a368..2944b06 100644
--- a/target-ppc/helper.c
+++ b/target-ppc/helper.c
@@ -949,8 +949,24 @@ static inline int get_segment(CPUState *env, mmu_ctx_t
*ctx,
ret = -3;
}
} else {
+ target_ulong sr;
LOG_MMU("direct store...\n");
/* Direct-store segment : absolutely *BUGGY* for now */
+
+ /* Direct-store implies a 32-bit MMU.
+ * Check the Segment Register's bus unit ID (BUID).
+ */
+ sr = env->sr[eaddr >> 28];
+ if ((sr & 0x1FF00000) >> 20 == 0x07f) {
+ /* Memory-forced I/O controller interface access */
+ /* If T=1 and BUID=x'07F', the 601 performs a memory access
+ * to SR[28-31] LA[4-31], bypassing all protection mechanisms.
+ */
+ ctx->raddr = ((sr & 0xF) << 28) | (eaddr & 0x0FFFFFFF);
+ ctx->prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
+ return 0;
+ }
+
switch (type) {
case ACCESS_INT:
/* Integer load/store : only access allowed */
--
1.6.0.2
[Qemu-devel] [PATCH 8/9] PPC: 440: Use 440 style MMU as default, so Qemu knows the MMU type, Alexander Graf, 2011/06/17
[Qemu-devel] [PATCH 1/9] PPC: E500: Implement reboot controller, Alexander Graf, 2011/06/17
[Qemu-devel] [PATCH 9/9] PPC: move TLBs to their own arrays, Alexander Graf, 2011/06/17
[Qemu-devel] [PATCH 4/9] PPC: mpc8544ds: Add hypervisor node, Alexander Graf, 2011/06/17
[Qemu-devel] [PATCH 6/9] PPC: Only set lower 32bits with mtmsr, Alexander Graf, 2011/06/17
[Qemu-devel] [PATCH 3/9] PPC: calculate kernel, initrd, cmdline locations dynamically, Alexander Graf, 2011/06/17