|
@@ -16,6 +16,7 @@
|
|
|
* Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
|
*/
|
|
|
|
|
|
+#include <linux/arm-smccc.h>
|
|
|
#include <linux/linkage.h>
|
|
|
#include <asm/kvm_arm.h>
|
|
|
#include <asm/kvm_asm.h>
|
|
@@ -202,7 +203,7 @@ hyp_hvc:
|
|
|
lsr r2, r2, #16
|
|
|
and r2, r2, #0xff
|
|
|
cmp r2, #0
|
|
|
- bne guest_trap @ Guest called HVC
|
|
|
+ bne guest_hvc_trap @ Guest called HVC
|
|
|
|
|
|
/*
|
|
|
* Getting here means host called HVC, we shift parameters and branch
|
|
@@ -253,6 +254,20 @@ THUMB( orr lr, #1)
|
|
|
pop {r2, lr}
|
|
|
eret
|
|
|
|
|
|
+guest_hvc_trap:
|
|
|
+ movw r2, #:lower16:ARM_SMCCC_ARCH_WORKAROUND_1
|
|
|
+ movt r2, #:upper16:ARM_SMCCC_ARCH_WORKAROUND_1
|
|
|
+ ldr r0, [sp] @ Guest's r0
|
|
|
+ teq r0, r2
|
|
|
+ bne guest_trap
|
|
|
+ add sp, sp, #12
|
|
|
+ @ Returns:
|
|
|
+ @ r0 = 0
|
|
|
+ @ r1 = HSR value (perfectly predictable)
|
|
|
+ @ r2 = ARM_SMCCC_ARCH_WORKAROUND_1
|
|
|
+ mov r0, #0
|
|
|
+ eret
|
|
|
+
|
|
|
guest_trap:
|
|
|
load_vcpu r0 @ Load VCPU pointer to r0
|
|
|
|