Commit 72b7a9e5 authored by Christophe Leroy's avatar Christophe Leroy Committed by Michael Ellerman

powerpc/syscall: Use is_compat_task()

Instead of hard comparing task flags with _TIF_32BIT, use
is_compat_task(). The advantage is that it returns 0 on PPC32
allthough _TIF_32BIT is always set.
Signed-off-by: default avatarChristophe Leroy <christophe.leroy@csgroup.eu>
Reviewed-by: default avatarNicholas Piggin <npiggin@gmail.com>
Signed-off-by: default avatarMichael Ellerman <mpe@ellerman.id.au>
Link: https://lore.kernel.org/r/c8094662199337a7200fea9f6e1d1f8b1b6d5f69.1612796617.git.christophe.leroy@csgroup.eu
parent 344bb20b
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
#include <linux/context_tracking.h> #include <linux/context_tracking.h>
#include <linux/err.h> #include <linux/err.h>
#include <linux/compat.h>
#include <asm/asm-prototypes.h> #include <asm/asm-prototypes.h>
#include <asm/kup.h> #include <asm/kup.h>
#include <asm/cputime.h> #include <asm/cputime.h>
...@@ -118,7 +120,7 @@ notrace long system_call_exception(long r3, long r4, long r5, ...@@ -118,7 +120,7 @@ notrace long system_call_exception(long r3, long r4, long r5,
/* May be faster to do array_index_nospec? */ /* May be faster to do array_index_nospec? */
barrier_nospec(); barrier_nospec();
if (unlikely(is_32bit_task())) { if (unlikely(is_compat_task())) {
f = (void *)compat_sys_call_table[r0]; f = (void *)compat_sys_call_table[r0];
r3 &= 0x00000000ffffffffULL; r3 &= 0x00000000ffffffffULL;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment