Skip to content

Commit

Permalink
preempt: Make PREEMPT_ACTIVE generic
Browse files Browse the repository at this point in the history
No point in having this bit defined by architecture.

Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Acked-by: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20130917183629.090698799@linutronix.de
  • Loading branch information
KAGA-KOKO committed Nov 13, 2013
1 parent 9385d94 commit 00d1a39
Show file tree
Hide file tree
Showing 32 changed files with 8 additions and 89 deletions.
2 changes: 0 additions & 2 deletions arch/alpha/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,6 @@ register struct thread_info *__current_thread_info __asm__("$8");
#define THREAD_SIZE_ORDER 1
#define THREAD_SIZE (2*PAGE_SIZE)

#define PREEMPT_ACTIVE 0x40000000

/*
* Thread information flags:
* - these are process state flags and used from assembly
Expand Down
2 changes: 0 additions & 2 deletions arch/arc/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -80,8 +80,6 @@ static inline __attribute_const__ struct thread_info *current_thread_info(void)

#endif /* !__ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flags
* - these are process state flags that various assembly files may need to
Expand Down
6 changes: 0 additions & 6 deletions arch/arm/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -140,12 +140,6 @@ extern int vfp_restore_user_hwstate(struct user_vfp __user *,
struct user_vfp_exc __user *);
#endif

/*
* We use bit 30 of the preempt_count to indicate that kernel
* preemption is occurring. See <asm/hardirq.h>.
*/
#define PREEMPT_ACTIVE 0x40000000

/*
* thread information flags:
* TIF_SYSCALL_TRACE - syscall trace active
Expand Down
6 changes: 0 additions & 6 deletions arch/arm64/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,12 +88,6 @@ static inline struct thread_info *current_thread_info(void)

#endif

/*
* We use bit 30 of the preempt_count to indicate that kernel
* preemption is occurring. See <asm/hardirq.h>.
*/
#define PREEMPT_ACTIVE 0x40000000

/*
* thread information flags:
* TIF_SYSCALL_TRACE - syscall trace active
Expand Down
2 changes: 0 additions & 2 deletions arch/avr32/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -66,8 +66,6 @@ static inline struct thread_info *current_thread_info(void)

#endif /* !__ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x40000000

/*
* Thread information flags
* - these are process state flags that various assembly files may need to access
Expand Down
2 changes: 0 additions & 2 deletions arch/blackfin/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -88,8 +88,6 @@ static inline struct thread_info *current_thread_info(void)
#define TI_CPU 12
#define TI_PREEMPT 16

#define PREEMPT_ACTIVE 0x4000000

/*
* thread information flag bit numbers
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/c6x/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -84,8 +84,6 @@ struct thread_info *current_thread_info(void)
#define put_thread_info(ti) put_task_struct((ti)->task)
#endif /* __ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flag bit numbers
* - pending work-to-be-done flags are in LSW
Expand Down
2 changes: 0 additions & 2 deletions arch/cris/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

/*
* macros/functions for gaining access to the thread information structure
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/frv/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -52,8 +52,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

/*
* macros/functions for gaining access to the thread information structure
*/
Expand Down
4 changes: 0 additions & 4 deletions arch/hexagon/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,6 @@ struct thread_info {

#endif /* __ASSEMBLY__ */

/* looks like "linux/hardirq.h" uses this. */

#define PREEMPT_ACTIVE 0x10000000

#ifndef __ASSEMBLY__

#define INIT_THREAD_INFO(tsk) \
Expand Down
3 changes: 0 additions & 3 deletions arch/ia64/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,9 +11,6 @@
#include <asm/processor.h>
#include <asm/ptrace.h>

#define PREEMPT_ACTIVE_BIT 30
#define PREEMPT_ACTIVE (1 << PREEMPT_ACTIVE_BIT)

#ifndef __ASSEMBLY__

/*
Expand Down
2 changes: 0 additions & 2 deletions arch/m32r/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -53,8 +53,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

#define THREAD_SIZE (PAGE_SIZE << 1)
#define THREAD_SIZE_ORDER 1
/*
Expand Down
2 changes: 0 additions & 2 deletions arch/m68k/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -35,8 +35,6 @@ struct thread_info {
};
#endif /* __ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x4000000

#define INIT_THREAD_INFO(tsk) \
{ \
.task = &tsk, \
Expand Down
2 changes: 0 additions & 2 deletions arch/metag/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,8 +46,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

#ifdef CONFIG_4KSTACKS
#define THREAD_SHIFT 12
#else
Expand Down
2 changes: 0 additions & 2 deletions arch/microblaze/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -106,8 +106,6 @@ static inline struct thread_info *current_thread_info(void)
/* thread information allocation */
#endif /* __ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flags
* - these are process state flags that various assembly files may
Expand Down
2 changes: 0 additions & 2 deletions arch/mips/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -92,8 +92,6 @@ static inline struct thread_info *current_thread_info(void)

#define STACK_WARN (THREAD_SIZE / 8)

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flags
* - these are process state flags that various assembly files may need to
Expand Down
2 changes: 0 additions & 2 deletions arch/mn10300/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -16,8 +16,6 @@

#include <asm/page.h>

#define PREEMPT_ACTIVE 0x10000000

#ifdef CONFIG_4KSTACKS
#define THREAD_SIZE (4096)
#define THREAD_SIZE_ORDER (0)
Expand Down
3 changes: 0 additions & 3 deletions arch/parisc/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -46,9 +46,6 @@ struct thread_info {
#define THREAD_SIZE (PAGE_SIZE << THREAD_SIZE_ORDER)
#define THREAD_SHIFT (PAGE_SHIFT + THREAD_SIZE_ORDER)

#define PREEMPT_ACTIVE_BIT 28
#define PREEMPT_ACTIVE (1 << PREEMPT_ACTIVE_BIT)

/*
* thread information flags
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/powerpc/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -82,8 +82,6 @@ static inline struct thread_info *current_thread_info(void)

#endif /* __ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flag bit numbers
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/s390/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -111,6 +111,4 @@ static inline struct thread_info *current_thread_info(void)
#define is_32bit_task() (1)
#endif

#define PREEMPT_ACTIVE 0x4000000

#endif /* _ASM_THREAD_INFO_H */
2 changes: 0 additions & 2 deletions arch/score/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -72,8 +72,6 @@ register struct thread_info *__current_thread_info __asm__("r28");

#endif /* !__ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* thread information flags
* - these are process state flags that various assembly files may need to
Expand Down
2 changes: 0 additions & 2 deletions arch/sh/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -41,8 +41,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

#if defined(CONFIG_4KSTACKS)
#define THREAD_SHIFT 12
#else
Expand Down
6 changes: 2 additions & 4 deletions arch/sh/kernel/entry-common.S
Original file line number Diff line number Diff line change
Expand Up @@ -108,7 +108,7 @@ need_resched:
and #(0xf0>>1), r0 ! interrupts off (exception path)?
cmp/eq #(0xf0>>1), r0
bt noresched
mov.l 3f, r0
mov.l 1f, r0
jsr @r0 ! call preempt_schedule_irq
nop
bra need_resched
Expand All @@ -119,9 +119,7 @@ noresched:
nop

.align 2
1: .long PREEMPT_ACTIVE
2: .long schedule
3: .long preempt_schedule_irq
1: .long preempt_schedule_irq
#endif

ENTRY(resume_userspace)
Expand Down
2 changes: 0 additions & 2 deletions arch/sparc/include/asm/thread_info_32.h
Original file line number Diff line number Diff line change
Expand Up @@ -105,8 +105,6 @@ register struct thread_info *current_thread_info_reg asm("g6");
#define TI_W_SAVED 0x250
/* #define TI_RESTART_BLOCK 0x25n */ /* Nobody cares */

#define PREEMPT_ACTIVE 0x4000000

/*
* thread information flag bit numbers
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/sparc/include/asm/thread_info_64.h
Original file line number Diff line number Diff line change
Expand Up @@ -111,8 +111,6 @@ struct thread_info {
#define THREAD_SHIFT PAGE_SHIFT
#endif /* PAGE_SHIFT == 13 */

#define PREEMPT_ACTIVE 0x10000000

/*
* macros/functions for gaining access to the thread information structure
*/
Expand Down
2 changes: 0 additions & 2 deletions arch/tile/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -113,8 +113,6 @@ extern void _cpu_idle(void);

#endif /* !__ASSEMBLY__ */

#define PREEMPT_ACTIVE 0x10000000

/*
* Thread information flags that various assembly files may need to access.
* Keep flags accessed frequently in low bits, particular since it makes
Expand Down
2 changes: 0 additions & 2 deletions arch/um/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -60,8 +60,6 @@ static inline struct thread_info *current_thread_info(void)

#endif

#define PREEMPT_ACTIVE 0x10000000

#define TIF_SYSCALL_TRACE 0 /* syscall trace active */
#define TIF_SIGPENDING 1 /* signal pending */
#define TIF_NEED_RESCHED 2 /* rescheduling necessary */
Expand Down
6 changes: 0 additions & 6 deletions arch/unicore32/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -117,12 +117,6 @@ static inline struct thread_info *current_thread_info(void)

#endif

/*
* We use bit 30 of the preempt_count to indicate that kernel
* preemption is occurring. See <asm/hardirq.h>.
*/
#define PREEMPT_ACTIVE 0x40000000

/*
* thread information flags:
* TIF_SYSCALL_TRACE - syscall trace active
Expand Down
2 changes: 0 additions & 2 deletions arch/x86/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -153,8 +153,6 @@ struct thread_info {
#define _TIF_WORK_CTXSW_PREV (_TIF_WORK_CTXSW|_TIF_USER_RETURN_NOTIFY)
#define _TIF_WORK_CTXSW_NEXT (_TIF_WORK_CTXSW)

#define PREEMPT_ACTIVE 0x10000000

#ifdef CONFIG_X86_32

#define STACK_WARN (THREAD_SIZE/8)
Expand Down
2 changes: 0 additions & 2 deletions arch/xtensa/include/asm/thread_info.h
Original file line number Diff line number Diff line change
Expand Up @@ -76,8 +76,6 @@ struct thread_info {

#endif

#define PREEMPT_ACTIVE 0x10000000

/*
* macros/functions for gaining access to the thread information structure
*/
Expand Down
15 changes: 5 additions & 10 deletions include/linux/preempt_mask.h
Original file line number Diff line number Diff line change
Expand Up @@ -17,10 +17,11 @@
* there are a few palaeontologic drivers which reenable interrupts in
* the handler, so we need more than one bit here.
*
* PREEMPT_MASK: 0x000000ff
* SOFTIRQ_MASK: 0x0000ff00
* HARDIRQ_MASK: 0x000f0000
* NMI_MASK: 0x00100000
* PREEMPT_MASK: 0x000000ff
* SOFTIRQ_MASK: 0x0000ff00
* HARDIRQ_MASK: 0x000f0000
* NMI_MASK: 0x00100000
* PREEMPT_ACTIVE: 0x00200000
*/
#define PREEMPT_BITS 8
#define SOFTIRQ_BITS 8
Expand All @@ -46,15 +47,9 @@

#define SOFTIRQ_DISABLE_OFFSET (2 * SOFTIRQ_OFFSET)

#ifndef PREEMPT_ACTIVE
#define PREEMPT_ACTIVE_BITS 1
#define PREEMPT_ACTIVE_SHIFT (NMI_SHIFT + NMI_BITS)
#define PREEMPT_ACTIVE (__IRQ_MASK(PREEMPT_ACTIVE_BITS) << PREEMPT_ACTIVE_SHIFT)
#endif

#if PREEMPT_ACTIVE < (1 << (NMI_SHIFT + NMI_BITS))
#error PREEMPT_ACTIVE is too low!
#endif

#define hardirq_count() (preempt_count() & HARDIRQ_MASK)
#define softirq_count() (preempt_count() & SOFTIRQ_MASK)
Expand Down
2 changes: 1 addition & 1 deletion include/linux/sched.h
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ struct sched_param {
#include <linux/errno.h>
#include <linux/nodemask.h>
#include <linux/mm_types.h>
#include <linux/preempt.h>
#include <linux/preempt_mask.h>

#include <asm/page.h>
#include <asm/ptrace.h>
Expand Down

0 comments on commit 00d1a39

Please sign in to comment.