Message ID | 1447795019-30176-11-git-send-email-ynorov@caviumnetworks.com (mailing list archive) |
---|---|
State | New, archived |
Headers | show |
On Wed, Nov 18, 2015 at 12:16:50AM +0300, Yury Norov wrote: > --- a/arch/arm64/include/asm/processor.h > +++ b/arch/arm64/include/asm/processor.h > @@ -28,6 +28,7 @@ > #ifdef __KERNEL__ > > #include <linux/string.h> > +#include <linux/thread_info.h> > > #include <asm/fpsimd.h> > #include <asm/hw_breakpoint.h> > @@ -123,6 +124,15 @@ static inline void start_thread(struct pt_regs *regs, unsigned long pc, > static inline void compat_start_thread(struct pt_regs *regs, unsigned long pc, > unsigned long sp) > { > +#ifdef CONFIG_ARM64_ILP32 > + /* ILP32 thread are started the same way as LP64 threads. > + Note we cannot use is_ilp32_compat_task here as that > + would introduce a header depency issue. */ > + if (test_thread_flag(TIF_32BIT_AARCH64)) { > + start_thread(regs, pc, sp); > + return; > + } Nitpicks: use IS_ENABLED(CONFIG_ARM64_ILP32) instead of #ifdef. Also follow the coding style for multi-line comments: /* * ..... * ..... */
diff --git a/arch/arm64/include/asm/processor.h b/arch/arm64/include/asm/processor.h index a415dd0..e244cb4 100644 --- a/arch/arm64/include/asm/processor.h +++ b/arch/arm64/include/asm/processor.h @@ -28,6 +28,7 @@ #ifdef __KERNEL__ #include <linux/string.h> +#include <linux/thread_info.h> #include <asm/fpsimd.h> #include <asm/hw_breakpoint.h> @@ -123,6 +124,15 @@ static inline void start_thread(struct pt_regs *regs, unsigned long pc, static inline void compat_start_thread(struct pt_regs *regs, unsigned long pc, unsigned long sp) { +#ifdef CONFIG_ARM64_ILP32 + /* ILP32 thread are started the same way as LP64 threads. + Note we cannot use is_ilp32_compat_task here as that + would introduce a header depency issue. */ + if (test_thread_flag(TIF_32BIT_AARCH64)) { + start_thread(regs, pc, sp); + return; + } +#endif start_thread_common(regs, pc); regs->pstate = COMPAT_PSR_MODE_USR; if (pc & 1)