Sign Up
Log In
Log In
or
Sign Up
Places
All Projects
Status Monitor
Collapse sidebar
openSUSE:Step:FrontRunner
xen.26345
5dbafbda-Arm32-entry-Split-__DEFINE_ENTRY_TRAP....
Overview
Repositories
Revisions
Requests
Users
Attributes
Meta
File 5dbafbda-Arm32-entry-Split-__DEFINE_ENTRY_TRAP.patch of Package xen.26345
# Commit 6eeef7ecaeec002bb1da7e20c9cfaec5549bd940 # Date 2019-10-31 16:20:58 +0100 # Author Julien Grall <julien.grall@arm.com> # Committer Jan Beulich <jbeulich@suse.com> xen/arm32: entry: Split __DEFINE_ENTRY_TRAP in two The preprocessing macro __DEFINE_ENTRY_TRAP is used to generate trap entry function. While the macro is fairly small today, follow-up patches will increase the size signicantly. In general, assembly macros are more readable as they allow you to name parameters and avoid '\'. So the actual implementation of the trap is now switched to an assembly macro. This is part of XSA-303. Reported-by: Julien Grall <Julien.Grall@arm.com> Signed-off-by: Julien Grall <julien.grall@arm.com> Reviewed-by: Stefano Stabellini <sstabellini@kernel.org> Reviewed-by: Andre Przywara <andre.przywara@arm.com> --- a/xen/arch/arm/arm32/entry.S +++ b/xen/arch/arm/arm32/entry.S @@ -125,24 +125,28 @@ abort_guest_exit_end: skip_check: mov pc, lr -/* - * Macro to define trap entry. The iflags corresponds to the list of - * interrupts (Asynchronous Abort, IRQ, FIQ) to unmask. - */ + /* + * Macro to define trap entry. The iflags corresponds to the list of + * interrupts (Asynchronous Abort, IRQ, FIQ) to unmask. + */ + .macro vector trap, iflags + SAVE_ALL + cpsie \iflags + adr lr, return_from_trap + mov r0, sp + /* + * Save the stack pointer in r11. It will be restored after the + * trap has been handled (see return_from_trap). + */ + mov r11, sp + bic sp, #7 /* Align the stack pointer (noop on guest trap) */ + b do_trap_\trap + .endm + #define __DEFINE_TRAP_ENTRY(trap, iflags) \ ALIGN; \ trap_##trap: \ - SAVE_ALL; \ - cpsie iflags; \ - adr lr, return_from_trap; \ - mov r0, sp; \ - /* \ - * Save the stack pointer in r11. It will be restored after the \ - * trap has been handled (see return_from_trap). \ - */ \ - mov r11, sp; \ - bic sp, #7; /* Align the stack pointer (noop on guest trap) */ \ - b do_trap_##trap + vector trap, iflags /* Trap handler which unmask IRQ/Abort, keep FIQ masked */ #define DEFINE_TRAP_ENTRY(trap) __DEFINE_TRAP_ENTRY(trap, ai)
Locations
Projects
Search
Status Monitor
Help
OpenBuildService.org
Documentation
API Documentation
Code of Conduct
Contact
Support
@OBShq
Terms
openSUSE Build Service is sponsored by
The Open Build Service is an
openSUSE project
.
Sign Up
Log In
Places
Places
All Projects
Status Monitor