Add OS_AbortTrap implementation
This supports all the load/store instructions, including FPA & VFP/NEON. Most instructions are handled directly via the base version of the AbortTrap API that was first implemented in RISC OS Select. However, to properly cope with LDREX/STREX, and future support for prefetch aborts, the API has been extended to allow the kernel to request that a block of memory is mapped in with certain permissions. For LDREX/STREX the kernel will then rewind the PC so that the instruction can be retried directly. Test code in Dev/AbortTrap exists in order to allow checking of all major functionality, along with code for building the code in a softloadable module for easier/quicker testing.
Showing
Dev/AbortTrap/attest_ap,fd1
0 → 100644
This source diff could not be displayed because it is too large. You can view the blob instead.
Dev/AbortTrap/runtests,feb
0 → 100644
aborttrap/actions/ARMv3
0 → 100644
aborttrap/actions/ARMv4
0 → 100644
aborttrap/actions/ARMv5TE
0 → 100644
aborttrap/actions/ARMv6
0 → 100644
Please register or sign in to comment