diff options
| author | Andy Lutomirski <luto@kernel.org> | 2016-08-02 17:05:36 -0400 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2016-08-02 19:35:23 -0400 |
| commit | 7e7814180b334dff97ef8f56c7c40c277ad4531c (patch) | |
| tree | 8f2f0ce6b3aca6dcce64a46047c42df63f43a7e9 /arch/tile/include/asm | |
| parent | 0a11b9aae49adf1f952427ef1a1d9e793dd6ffb6 (diff) | |
signal: consolidate {TS,TLF}_RESTORE_SIGMASK code
In general, there's no need for the "restore sigmask" flag to live in
ti->flags. alpha, ia64, microblaze, powerpc, sh, sparc (64-bit only),
tile, and x86 use essentially identical alternative implementations,
placing the flag in ti->status.
Replace those optimized implementations with an equally good common
implementation that stores it in a bitfield in struct task_struct and
drop the custom implementations.
Additional architectures can opt in by removing their
TIF_RESTORE_SIGMASK defines.
Link: http://lkml.kernel.org/r/8a14321d64a28e40adfddc90e18a96c086a6d6f9.1468522723.git.luto@kernel.org
Signed-off-by: Andy Lutomirski <luto@kernel.org>
Tested-by: Michael Ellerman <mpe@ellerman.id.au> [powerpc]
Cc: Richard Henderson <rth@twiddle.net>
Cc: Ivan Kokshaysky <ink@jurassic.park.msu.ru>
Cc: Matt Turner <mattst88@gmail.com>
Cc: Tony Luck <tony.luck@intel.com>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: Michal Simek <monstr@monstr.eu>
Cc: Benjamin Herrenschmidt <benh@kernel.crashing.org>
Cc: Paul Mackerras <paulus@samba.org>
Cc: Yoshinori Sato <ysato@users.sourceforge.jp>
Cc: Rich Felker <dalias@libc.org>
Cc: "David S. Miller" <davem@davemloft.net>
Cc: Chris Metcalf <cmetcalf@mellanox.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Borislav Petkov <bp@suse.de>
Cc: Brian Gerst <brgerst@gmail.com>
Cc: Dmitry Safonov <dsafonov@virtuozzo.com>
Cc: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/tile/include/asm')
| -rw-r--r-- | arch/tile/include/asm/thread_info.h | 27 |
1 files changed, 0 insertions, 27 deletions
diff --git a/arch/tile/include/asm/thread_info.h b/arch/tile/include/asm/thread_info.h index c1467ac59ce6..b7659b8f1117 100644 --- a/arch/tile/include/asm/thread_info.h +++ b/arch/tile/include/asm/thread_info.h | |||
| @@ -166,32 +166,5 @@ extern void _cpu_idle(void); | |||
| 166 | #ifdef __tilegx__ | 166 | #ifdef __tilegx__ |
| 167 | #define TS_COMPAT 0x0001 /* 32-bit compatibility mode */ | 167 | #define TS_COMPAT 0x0001 /* 32-bit compatibility mode */ |
| 168 | #endif | 168 | #endif |
| 169 | #define TS_RESTORE_SIGMASK 0x0008 /* restore signal mask in do_signal */ | ||
| 170 | |||
| 171 | #ifndef __ASSEMBLY__ | ||
| 172 | #define HAVE_SET_RESTORE_SIGMASK 1 | ||
| 173 | static inline void set_restore_sigmask(void) | ||
| 174 | { | ||
| 175 | struct thread_info *ti = current_thread_info(); | ||
| 176 | ti->status |= TS_RESTORE_SIGMASK; | ||
| 177 | WARN_ON(!test_bit(TIF_SIGPENDING, &ti->flags)); | ||
| 178 | } | ||
| 179 | static inline void clear_restore_sigmask(void) | ||
| 180 | { | ||
| 181 | current_thread_info()->status &= ~TS_RESTORE_SIGMASK; | ||
| 182 | } | ||
| 183 | static inline bool test_restore_sigmask(void) | ||
| 184 | { | ||
| 185 | return current_thread_info()->status & TS_RESTORE_SIGMASK; | ||
| 186 | } | ||
| 187 | static inline bool test_and_clear_restore_sigmask(void) | ||
| 188 | { | ||
| 189 | struct thread_info *ti = current_thread_info(); | ||
| 190 | if (!(ti->status & TS_RESTORE_SIGMASK)) | ||
| 191 | return false; | ||
| 192 | ti->status &= ~TS_RESTORE_SIGMASK; | ||
| 193 | return true; | ||
| 194 | } | ||
| 195 | #endif /* !__ASSEMBLY__ */ | ||
| 196 | 169 | ||
| 197 | #endif /* _ASM_TILE_THREAD_INFO_H */ | 170 | #endif /* _ASM_TILE_THREAD_INFO_H */ |
