[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Qemu-devel] [PATCH 5/6] linux-user: Implement PR_PAC_RESET_KEYS
From: |
Richard Henderson |
Subject: |
[Qemu-devel] [PATCH 5/6] linux-user: Implement PR_PAC_RESET_KEYS |
Date: |
Fri, 25 Jan 2019 14:57:13 -0800 |
Signed-off-by: Richard Henderson <address@hidden>
---
linux-user/aarch64/target_syscall.h | 7 ++++++
linux-user/syscall.c | 33 +++++++++++++++++++++++++++++
2 files changed, 40 insertions(+)
diff --git a/linux-user/aarch64/target_syscall.h
b/linux-user/aarch64/target_syscall.h
index 937fd7989e..b595e5da82 100644
--- a/linux-user/aarch64/target_syscall.h
+++ b/linux-user/aarch64/target_syscall.h
@@ -22,6 +22,13 @@ struct target_pt_regs {
#define TARGET_PR_SVE_SET_VL 50
#define TARGET_PR_SVE_GET_VL 51
+#define TARGET_PR_PAC_RESET_KEYS 54
+# define TARGET_PR_PAC_APIAKEY (1 << 0)
+# define TARGET_PR_PAC_APIBKEY (1 << 1)
+# define TARGET_PR_PAC_APDAKEY (1 << 2)
+# define TARGET_PR_PAC_APDBKEY (1 << 3)
+# define TARGET_PR_PAC_APGAKEY (1 << 4)
+
void arm_init_pauth_key(ARMPACKey *key);
#endif /* AARCH64_TARGET_SYSCALL_H */
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
index b5786d4fc1..3e2949aa2f 100644
--- a/linux-user/syscall.c
+++ b/linux-user/syscall.c
@@ -9691,6 +9691,39 @@ static abi_long do_syscall1(void *cpu_env, int num,
abi_long arg1,
}
}
return ret;
+ case TARGET_PR_PAC_RESET_KEYS:
+ {
+ CPUARMState *env = cpu_env;
+ ARMCPU *cpu = arm_env_get_cpu(env);
+
+ if (cpu_isar_feature(aa64_pauth, cpu)) {
+ int all = (TARGET_PR_PAC_APIAKEY | TARGET_PR_PAC_APIBKEY |
+ TARGET_PR_PAC_APDAKEY | TARGET_PR_PAC_APDBKEY |
+ TARGET_PR_PAC_APGAKEY);
+ if (arg2 == 0) {
+ arg2 = all;
+ } else if (arg2 & ~all) {
+ return -TARGET_EINVAL;
+ }
+ if (arg2 & TARGET_PR_PAC_APIAKEY) {
+ arm_init_pauth_key(&env->apia_key);
+ }
+ if (arg2 & TARGET_PR_PAC_APIBKEY) {
+ arm_init_pauth_key(&env->apib_key);
+ }
+ if (arg2 & TARGET_PR_PAC_APDAKEY) {
+ arm_init_pauth_key(&env->apda_key);
+ }
+ if (arg2 & TARGET_PR_PAC_APDBKEY) {
+ arm_init_pauth_key(&env->apdb_key);
+ }
+ if (arg2 & TARGET_PR_PAC_APGAKEY) {
+ arm_init_pauth_key(&env->apga_key);
+ }
+ return 0;
+ }
+ }
+ return -TARGET_EINVAL;
#endif /* AARCH64 */
case PR_GET_SECCOMP:
case PR_SET_SECCOMP:
--
2.17.2
- [Qemu-devel] [PATCH 0/6] target/arm: Complete ARMv8.3-PAuth linux-user, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 6/6] tests/tcg/aarch64: Add pauth smoke tests, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 2/6] aarch64-linux-user: Update HWCAP bits from linux 5.0-rc1, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 3/6] aarch64-linux-user: Enable HWCAP bits for PAuth, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 4/6] linux-user: Initialize aarch64 pac keys, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 5/6] linux-user: Implement PR_PAC_RESET_KEYS,
Richard Henderson <=
- [Qemu-devel] [PATCH] target/arm: Fix validation of 32-bit address spaces for aa32, Richard Henderson, 2019/01/25
- [Qemu-devel] [PATCH 1/6] target/arm: Always enable pac keys for user-only, Richard Henderson, 2019/01/25