On 12/01/20 16:56, Will Deacon wrote: > On Fri, Nov 27, 2020 at 01:12:17PM +0000, Qais Yousef wrote: > > On 11/24/20 15:50, Will Deacon wrote: > > > Scheduling a 32-bit application on a 64-bit-only CPU is a bad idea. > > > > > > Ensure that 32-bit applications always take the slow-path when returning > > > to userspace on a system with mismatched support at EL0, so that we can > > > avoid trying to run on a 64-bit-only CPU and force a SIGKILL instead. > > > > > > Signed-off-by: Will Deacon <will@xxxxxxxxxx> > > > --- > > > > nit: We drop this patch at the end. Can't we avoid it altogether instead? > > I did it like this so that the last patch can be reverted for > testing/debugging, but also because I think it helps the structure of the > series. Cool. I had a comment about the barrier(), you were worried about cpu_affinity_invalid() being inlined by the compiler and then things get mangled such that TIF_NOTIFY_RESUME clearing is moved after the call as you described? Can the compiler move things if cpu_affinity_invalid() is a proper function call (not inlined)? > > > > diff --git a/arch/arm64/kernel/signal.c b/arch/arm64/kernel/signal.c > > > index a8184cad8890..bcb6ca2d9a7c 100644 > > > --- a/arch/arm64/kernel/signal.c > > > +++ b/arch/arm64/kernel/signal.c > > > @@ -911,6 +911,19 @@ static void do_signal(struct pt_regs *regs) > > > restore_saved_sigmask(); > > > } > > > > > > +static bool cpu_affinity_invalid(struct pt_regs *regs) > > > +{ > > > + if (!compat_user_mode(regs)) > > > + return false; > > > > Silly question. Is there an advantage of using compat_user_mode() vs > > is_compat_task()? I see the latter used in the file although struct pt_regs > > *regs is passed to the functions calling it. > > > > Nothing's wrong with it, just curious. > > Not sure about advantages, but is_compat_task() is available in core code, > whereas compat_user_mode() is specific to arm64. The former implicitly > operates on 'current' and just checks thread flag, whereas the latter > actually goes and looks at mode field of the spsr to see what we're > going to be returning into. Okay, so just 2 different ways to do the same thing and you happened to pick the one that first came to mind. Thanks -- Qais Yousef