Subject: CVS commit: src/sys/arch/arm
To: None <source-changes@NetBSD.org>
From: Steve Woodford <scw@netbsd.org>
List: source-changes
Date: 10/31/2003 16:30:15
Module Name:	src
Committed By:	scw
Date:		Fri Oct 31 16:30:15 UTC 2003

Modified Files:
	src/sys/arch/arm/arm: bcopyinout.S
	src/sys/arch/arm/arm32: exception.S fault.c
	src/sys/arch/arm/include: armreg.h

Log Message:
Overhaul arm32's abort handlers:

 - Assume a permission fault is always the result of an attempted
   write, so no need to disassemble the opcode.
   (as discussed with Richard Earnshaw/Jason Thorpe a week or two ago)

 - Split out non-MMU data aborts into separate functions, and deal
   correctly with XScale imprecise aborts. Specifically, the old code
   made no attempt to handle the double abort faults which can occur
   as a result of two consecutive external (imprecise) aborts. This
   was easy to provoke by read(2)ing from a /dev/mem offset which caused
   an external abort. With the old code, this would bring the system
   down instantly, with little clue as to why. (hint: tf_spsr held
   PSR_ABT32_MODE...)

 - Re-write badaddr_read() to use pcb_onfault instead of adding extra
   overhead to data_abort_handler(). A side effect of this is that it
   now benefits from the XScale double abort recovery.

 - Invoke the cpu-specific prefetch/data abort fixup routines only if
   the host cpu actually needs it. On other cpus, the code is optimised
   away.

 - Sprinkle __predict_{false,true} in all the right places.

 - G/C some excess debugging baggage.


To generate a diff of this commit:
cvs rdiff -r1.11 -r1.12 src/sys/arch/arm/arm/bcopyinout.S
cvs rdiff -r1.12 -r1.13 src/sys/arch/arm/arm32/exception.S
cvs rdiff -r1.38 -r1.39 src/sys/arch/arm/arm32/fault.c
cvs rdiff -r1.27 -r1.28 src/sys/arch/arm/include/armreg.h

Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.