[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 2/9] target/m68k: don't set SSW ATC bit for physical bus errors
From: |
Laurent Vivier |
Subject: |
[PULL 2/9] target/m68k: don't set SSW ATC bit for physical bus errors |
Date: |
Thu, 11 Mar 2021 22:09:27 +0100 |
From: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
If a NuBus slot doesn't contain a card, the Quadra hardware generates a physical
bus error if the CPU attempts to access the slot address space. Both Linux and
MacOS use a separate bus error handler during NuBus accesses in order to detect
and recover when addressing empty slots.
According to the MC68040 users manual the ATC bit of the SSW is used to
distinguish between ATC faults and physical bus errors. MacOS specifically
checks
the stack frame generated by a NuBus error and panics if the SSW ATC bit is set.
Update m68k_cpu_transaction_failed() so that the SSW ATC bit is not set if the
memory API returns MEMTX_DECODE_ERROR which will be used to indicate that an
access to an empty NuBus slot occurred.
Signed-off-by: Mark Cave-Ayland <mark.cave-ayland@ilande.co.uk>
Reviewed-by: Laurent Vivier <laurent@vivier.eu>
Message-Id: <20210308121155.2476-2-mark.cave-ayland@ilande.co.uk>
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
---
target/m68k/op_helper.c | 12 +++++++++++-
1 file changed, 11 insertions(+), 1 deletion(-)
diff --git a/target/m68k/op_helper.c b/target/m68k/op_helper.c
index 730cdf774445..5f981e5bf628 100644
--- a/target/m68k/op_helper.c
+++ b/target/m68k/op_helper.c
@@ -468,7 +468,17 @@ void m68k_cpu_transaction_failed(CPUState *cs, hwaddr
physaddr, vaddr addr,
if (m68k_feature(env, M68K_FEATURE_M68040)) {
env->mmu.mmusr = 0;
- env->mmu.ssw |= M68K_ATC_040;
+
+ /*
+ * According to the MC68040 users manual the ATC bit of the SSW is
+ * used to distinguish between ATC faults and physical bus errors.
+ * In the case of a bus error e.g. during nubus read from an empty
+ * slot this bit should not be set
+ */
+ if (response != MEMTX_DECODE_ERROR) {
+ env->mmu.ssw |= M68K_ATC_040;
+ }
+
/* FIXME: manage MMU table access error */
env->mmu.ssw &= ~M68K_TM_040;
if (env->sr & SR_S) { /* SUPERVISOR */
--
2.29.2
- [PULL 0/9] M68k for 6.0 patches, Laurent Vivier, 2021/03/11
- [PULL 2/9] target/m68k: don't set SSW ATC bit for physical bus errors,
Laurent Vivier <=
- [PULL 1/9] target/m68k: implement rtr instruction, Laurent Vivier, 2021/03/11
- [PULL 4/9] target/m68k: add M68K_FEATURE_UNALIGNED_DATA feature, Laurent Vivier, 2021/03/11
- [PULL 3/9] target/m68k: reformat m68k_features enum, Laurent Vivier, 2021/03/11
- [PULL 7/9] m68k: add an interrupt controller, Laurent Vivier, 2021/03/11
- [PULL 5/9] char: add goldfish-tty, Laurent Vivier, 2021/03/11
- Re: [PULL 5/9] char: add goldfish-tty, Daniel P . Berrangé, 2021/03/15