From: Ralf Baechle <ralf@linux-mips.org>
To: Geert Uytterhoeven <geert@linux-m68k.org>
Cc: Mike Uhler <uhler@mips.com>,
Linux/MIPS Development <linux-mips@linux-mips.org>
Subject: Re: unaligned load in branch delay slot
Date: Tue, 28 Jan 2003 03:39:01 +0100 [thread overview]
Message-ID: <20030128033901.A23492@linux-mips.org> (raw)
In-Reply-To: <Pine.GSO.4.21.0301131901500.21279-100000@vervain.sonytel.be>; from geert@linux-m68k.org on Mon, Jan 13, 2003 at 07:04:36PM +0100
On Mon, Jan 13, 2003 at 07:04:36PM +0100, Geert Uytterhoeven wrote:
> The following patch (against linux-mips-2.4.x CVS) cures my crash.
>
> I don't know on which CPUs this may happen (need #ifdef CONFIG_CPU_VR41XX?),
> nor whether all branch and jump instructions are affected (I included
> everything that starts with a `b' or `j').
I'm suggesting this alternative patch below. Comments?
Ralf
diff -u -r1.4.2.1 branch.h
--- include/asm-mips/branch.h 7 May 2002 03:48:08 -0000
+++ include/asm-mips/branch.h 28 Jan 2003 02:34:12 -0000
@@ -8,11 +8,52 @@
#ifndef _ASM_BRANCH_H
#define _ASM_BRANCH_H
+#include <asm/inst.h>
#include <asm/ptrace.h>
+#include <asm/uaccess.h>
+#include <asm/war.h>
static inline int delay_slot(struct pt_regs *regs)
{
- return regs->cp0_cause & CAUSEF_BD;
+#ifdef BDSLOT_WAR
+ union mips_instruction insn;
+ mm_segment_t seg;
+#endif
+ int ds;
+
+ ds = regs->cp0_cause & CAUSEF_BD;
+ if (ds)
+ return ds;
+
+#ifdef BDSLOT_WAR
+ if (!user_mode(regs))
+ set_fs(KERNEL_DS);
+ __get_user(insn.word, (unsigned int *)regs->cp0_epc);
+ set_fs(seg);
+
+ switch (insn.i_format.opcode) {
+ /*
+ * On some CPUs, if an unaligned access happens in a branch delay slot
+ * and the branch is not taken, EPC points at the branch instruction,
+ * but the BD bit in the cause register is not set.
+ */
+ case bcond_op:
+ case j_op:
+ case jal_op:
+ case beq_op:
+ case bne_op:
+ case blez_op:
+ case bgtz_op:
+ case beql_op:
+ case bnel_op:
+ case blezl_op:
+ case bgtzl_op:
+ case jalx_op:
+ return 1;
+ }
+#endif
+
+ return 0;
}
static inline unsigned long exception_epc(struct pt_regs *regs)
diff -u -r1.1.2.4 war.h
--- include/asm-mips/war.h 2 Oct 2002 19:42:04 -0000
+++ include/asm-mips/war.h 28 Jan 2003 02:34:13 -0000
@@ -84,4 +84,17 @@
#endif
+#if !defined(CONFIG_CPU_MIPS32) && !defined(CONFIG_CPU_MIPS64)
+
+/*
+ * A bunch of CPUs predating the MIPS32 and MIPS64 specs do not always set
+ * the BD bit in c0_cause on an exception. For those we need to look at
+ * the faulting instruction to deciede if we were faulting in a delay slot.
+ * There might be further CPUs where BD works as expected but for now we're
+ * paranoid.
+ */
+#define BDSLOT_WAR
+
+#endif
+
#endif /* _ASM_WAR_H */
next prev parent reply other threads:[~2003-01-28 2:39 UTC|newest]
Thread overview: 21+ messages / expand[flat|nested] mbox.gz Atom feed top
2003-01-13 16:13 unaligned load in branch delay slot Geert Uytterhoeven
2003-01-13 17:19 ` Mike Uhler
2003-01-13 17:19 ` Mike Uhler
2003-01-13 18:04 ` Geert Uytterhoeven
2003-01-13 20:12 ` Mike Uhler
2003-01-13 20:12 ` Mike Uhler
2003-01-28 2:39 ` Ralf Baechle [this message]
2003-01-28 9:30 ` Geert Uytterhoeven
2003-01-28 11:47 ` Ralf Baechle
2003-01-28 12:27 ` Geert Uytterhoeven
2003-01-29 1:39 ` Brad Parker
2003-01-29 6:40 ` Ralf Baechle
2003-01-28 12:30 ` Maciej W. Rozycki
2003-01-28 12:54 ` Ralf Baechle
2003-01-28 17:53 ` Jun Sun
2003-01-28 19:48 ` Mike Uhler
2003-01-28 19:48 ` Mike Uhler
2003-01-28 21:30 ` [OT] " justinca
2003-01-28 21:39 ` Mike Uhler
2003-01-28 21:39 ` Mike Uhler
2003-01-29 14:25 ` Ralf Baechle
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20030128033901.A23492@linux-mips.org \
--to=ralf@linux-mips.org \
--cc=geert@linux-m68k.org \
--cc=linux-mips@linux-mips.org \
--cc=uhler@mips.com \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox