|
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index] [Xen-changelog] [xen stable-4.12] xen/arm64: entry: Introduce a macro to generate guest vector and use it
commit c88640c188cf94680a702efe08116a14974a2e12
Author: Julien Grall <julien.grall@xxxxxxx>
AuthorDate: Thu Oct 31 15:09:10 2019 +0000
Commit: Stefano Stabellini <sstabellini@xxxxxxxxxx>
CommitDate: Wed Nov 27 14:30:06 2019 -0800
xen/arm64: entry: Introduce a macro to generate guest vector and use it
Most of the guest vectors are using the same pattern. This makes fairly
tedious to alter the pattern and risk introducing mistakes when updating
each path.
A new macro is introduced to generate the guest vectors and now use it
in the one that use the open-code version.
Signed-off-by: Julien Grall <julien.grall@xxxxxxx>
Reviewed-by: Stefano Stabellini <sstabellini@xxxxxxxxxx>
Release-acked-by: Juergen Gross <jgross@xxxxxxxx>
(cherry picked from commit 32e195645cb693af9bfd43f2b1e90c204f9b3377)
---
xen/arch/arm/arm64/entry.S | 84 ++++++++++++++++------------------------------
1 file changed, 28 insertions(+), 56 deletions(-)
diff --git a/xen/arch/arm/arm64/entry.S b/xen/arch/arm/arm64/entry.S
index 5c67858e16..402833766b 100644
--- a/xen/arch/arm/arm64/entry.S
+++ b/xen/arch/arm/arm64/entry.S
@@ -180,6 +180,30 @@ lr .req x30 /* link register */
.endm
+ /*
+ * Generate a guest vector.
+ *
+ * iflags: Correspond to the list of interrupts to unmask
+ * save_x0_x1: See the description on top of the macro 'entry'
+ */
+ .macro guest_vector compat, iflags, trap, save_x0_x1=1
+ entry hyp=0, compat=\compat, save_x0_x1=\save_x0_x1
+ /*
+ * The vSError will be checked while SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT
+ * is not set. If a vSError took place, the initial exception will be
+ * skipped. Exit ASAP
+ */
+ ALTERNATIVE("bl check_pending_vserror; cbnz x0, 1f",
+ "nop; nop",
+ SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT)
+ msr daifclr, \iflags
+ mov x0, sp
+ bl do_trap_\trap
+1:
+ exit hyp=0, compat=\compat
+ .endm
+
+
/*
* Bad Abort numbers
*-----------------
@@ -352,36 +376,10 @@ guest_sync_slowpath:
* x0/x1 may have been scratch by the fast path above, so avoid
* to save them.
*/
- entry hyp=0, compat=0, save_x0_x1=0
- /*
- * The vSError will be checked while SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT
- * is not set. If a vSError took place, the initial exception will be
- * skipped. Exit ASAP
- */
- ALTERNATIVE("bl check_pending_vserror; cbnz x0, 1f",
- "nop; nop",
- SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT)
- msr daifclr, #IFLAGS__AI_
- mov x0, sp
- bl do_trap_guest_sync
-1:
- exit hyp=0, compat=0
+ guest_vector compat=0, iflags=IFLAGS__AI_, trap=guest_sync,
save_x0_x1=0
guest_irq:
- entry hyp=0, compat=0
- /*
- * The vSError will be checked while SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT
- * is not set. If a vSError took place, the initial exception will be
- * skipped. Exit ASAP
- */
- ALTERNATIVE("bl check_pending_vserror; cbnz x0, 1f",
- "nop; nop",
- SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT)
- msr daifclr, #IFLAGS__A__
- mov x0, sp
- bl do_trap_irq
-1:
- exit hyp=0, compat=0
+ guest_vector compat=0, iflags=IFLAGS__A__, trap=irq
guest_fiq_invalid:
entry hyp=0, compat=0
@@ -395,36 +393,10 @@ guest_error:
exit hyp=0, compat=0
guest_sync_compat:
- entry hyp=0, compat=1
- /*
- * The vSError will be checked while SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT
- * is not set. If a vSError took place, the initial exception will be
- * skipped. Exit ASAP
- */
- ALTERNATIVE("bl check_pending_vserror; cbnz x0, 1f",
- "nop; nop",
- SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT)
- msr daifclr, #IFLAGS__AI_
- mov x0, sp
- bl do_trap_guest_sync
-1:
- exit hyp=0, compat=1
+ guest_vector compat=1, iflags=IFLAGS__AI_, trap=guest_sync
guest_irq_compat:
- entry hyp=0, compat=1
- /*
- * The vSError will be checked while SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT
- * is not set. If a vSError took place, the initial exception will be
- * skipped. Exit ASAP
- */
- ALTERNATIVE("bl check_pending_vserror; cbnz x0, 1f",
- "nop; nop",
- SKIP_SYNCHRONIZE_SERROR_ENTRY_EXIT)
- msr daifclr, #IFLAGS__A__
- mov x0, sp
- bl do_trap_irq
-1:
- exit hyp=0, compat=1
+ guest_vector compat=1, iflags=IFLAGS__A__, trap=irq
guest_fiq_invalid_compat:
entry hyp=0, compat=1
--
generated by git-patchbot for /home/xen/git/xen.git#stable-4.12
_______________________________________________
Xen-changelog mailing list
Xen-changelog@xxxxxxxxxxxxxxxxxxxx
https://lists.xenproject.org/xen-changelog
|
![]() |
Lists.xenproject.org is hosted with RackSpace, monitoring our |