diff options
author | Nicholas Piggin <npiggin@gmail.com> | 2019-09-25 11:01:34 +1000 |
---|---|---|
committer | Oliver O'Halloran <oohall@gmail.com> | 2019-10-03 09:55:58 +1000 |
commit | 9ddc1a6bfaef8669efd00b36fa1b699c04f6488d (patch) | |
tree | 1e3b1585813e5db510f0b7e31914afed040e45b9 /include/processor.h | |
parent | b70e8afdb09f56e3c7db643862cd3d2fd15a4544 (diff) | |
download | skiboot-9ddc1a6bfaef8669efd00b36fa1b699c04f6488d.zip skiboot-9ddc1a6bfaef8669efd00b36fa1b699c04f6488d.tar.gz skiboot-9ddc1a6bfaef8669efd00b36fa1b699c04f6488d.tar.bz2 |
core/util: trap based assertions
Using traps for assertions like Linux does gives a few advantages:
- The asm code leading to the failure condition is nicer.
- The interrupt gives a clean snapshot of machine state to dump.
The difficulty with using traps for this in OPAL is that the runtime
component will not deal well with the OS taking the 0x700 interrupt
caused by a trap in OPAL.
The long term goal is to improve the ability of the OS to inspect and
debug OPAL at runtime. For now though, the traps are patched out before
passing control to the OS, and the assert falls through to in-line
failure handling.
Signed-off-by: Nicholas Piggin <npiggin@gmail.com>
[oliver: commit prefix, added and renamed the FWTS label, fix tests]
Signed-off-by: Oliver O'Halloran <oohall@gmail.com>
Diffstat (limited to 'include/processor.h')
-rw-r--r-- | include/processor.h | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/include/processor.h b/include/processor.h index 352fd1e..a0c2864 100644 --- a/include/processor.h +++ b/include/processor.h @@ -206,6 +206,9 @@ #include <stdbool.h> #include <stdint.h> +#define PPC_INST_NOP 0x60000000UL +#define PPC_INST_TRAP 0x7fe00008UL + #define RB(b) (((b) & 0x1f) << 11) #define MSGSND(b) stringify(.long 0x7c00019c | RB(b)) #define MSGCLR(b) stringify(.long 0x7c0001dc | RB(b)) |