diff options
author | Yury Norov <ynorov@caviumnetworks.com> | 2017-08-20 06:20:48 -0400 |
---|---|---|
committer | Catalin Marinas <catalin.marinas@arm.com> | 2017-08-22 13:41:47 -0400 |
commit | d1be5c99a0341249bf6f74eb1cbc3d5fc4ef2be7 (patch) | |
tree | 31a7daef1d274b216b66249cbda63516f2fad2ec | |
parent | 5ce93ab624cee4ed68086c946bd6d18b9b3f64aa (diff) |
arm64: cleanup {COMPAT_,}SET_PERSONALITY() macro
There is some work that should be done after setting the personality.
Currently it's done in the macro, which is not the best idea.
In this patch new arch_setup_new_exec() routine is introduced, and all
setup code is moved there, as suggested by Catalin:
https://lkml.org/lkml/2017/8/4/494
Cc: Pratyush Anand <panand@redhat.com>
Signed-off-by: Yury Norov <ynorov@caviumnetworks.com>
[catalin.marinas@arm.com: comments changed or removed]
Signed-off-by: Catalin Marinas <catalin.marinas@arm.com>
-rw-r--r-- | arch/arm64/include/asm/elf.h | 2 | ||||
-rw-r--r-- | arch/arm64/include/asm/thread_info.h | 3 | ||||
-rw-r--r-- | arch/arm64/kernel/process.c | 8 |
3 files changed, 11 insertions, 2 deletions
diff --git a/arch/arm64/include/asm/elf.h b/arch/arm64/include/asm/elf.h index f4e33f8356ca..c55043709c69 100644 --- a/arch/arm64/include/asm/elf.h +++ b/arch/arm64/include/asm/elf.h | |||
@@ -139,7 +139,6 @@ typedef struct user_fpsimd_state elf_fpregset_t; | |||
139 | 139 | ||
140 | #define SET_PERSONALITY(ex) \ | 140 | #define SET_PERSONALITY(ex) \ |
141 | ({ \ | 141 | ({ \ |
142 | current->mm->context.flags = 0; \ | ||
143 | clear_thread_flag(TIF_32BIT); \ | 142 | clear_thread_flag(TIF_32BIT); \ |
144 | current->personality &= ~READ_IMPLIES_EXEC; \ | 143 | current->personality &= ~READ_IMPLIES_EXEC; \ |
145 | }) | 144 | }) |
@@ -195,7 +194,6 @@ typedef compat_elf_greg_t compat_elf_gregset_t[COMPAT_ELF_NGREG]; | |||
195 | */ | 194 | */ |
196 | #define COMPAT_SET_PERSONALITY(ex) \ | 195 | #define COMPAT_SET_PERSONALITY(ex) \ |
197 | ({ \ | 196 | ({ \ |
198 | current->mm->context.flags = MMCF_AARCH32; \ | ||
199 | set_thread_flag(TIF_32BIT); \ | 197 | set_thread_flag(TIF_32BIT); \ |
200 | }) | 198 | }) |
201 | #define COMPAT_ARCH_DLINFO | 199 | #define COMPAT_ARCH_DLINFO |
diff --git a/arch/arm64/include/asm/thread_info.h b/arch/arm64/include/asm/thread_info.h index aa04b733b349..2eca178bc943 100644 --- a/arch/arm64/include/asm/thread_info.h +++ b/arch/arm64/include/asm/thread_info.h | |||
@@ -60,6 +60,9 @@ struct thread_info { | |||
60 | #define thread_saved_fp(tsk) \ | 60 | #define thread_saved_fp(tsk) \ |
61 | ((unsigned long)(tsk->thread.cpu_context.fp)) | 61 | ((unsigned long)(tsk->thread.cpu_context.fp)) |
62 | 62 | ||
63 | void arch_setup_new_exec(void); | ||
64 | #define arch_setup_new_exec arch_setup_new_exec | ||
65 | |||
63 | #endif | 66 | #endif |
64 | 67 | ||
65 | /* | 68 | /* |
diff --git a/arch/arm64/kernel/process.c b/arch/arm64/kernel/process.c index 85b953dd023a..e6bf19c1dddb 100644 --- a/arch/arm64/kernel/process.c +++ b/arch/arm64/kernel/process.c | |||
@@ -414,3 +414,11 @@ unsigned long arch_randomize_brk(struct mm_struct *mm) | |||
414 | else | 414 | else |
415 | return randomize_page(mm->brk, SZ_1G); | 415 | return randomize_page(mm->brk, SZ_1G); |
416 | } | 416 | } |
417 | |||
418 | /* | ||
419 | * Called from setup_new_exec() after (COMPAT_)SET_PERSONALITY. | ||
420 | */ | ||
421 | void arch_setup_new_exec(void) | ||
422 | { | ||
423 | current->mm->context.flags = is_compat_task() ? MMCF_AARCH32 : 0; | ||
424 | } | ||