diff options
| author | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-26 13:51:09 -0400 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@g5.osdl.org> | 2006-06-26 13:51:09 -0400 | 
| commit | 81a07d7588d376c530d006e24d7981304ce96e16 (patch) | |
| tree | 1608e094c88b9702c86cf2e6f65339aab9ea3f3f /kernel/sched.c | |
| parent | 8871e73fdbde07d0a41393f7ee30787b65387b36 (diff) | |
| parent | 8501a2fbe762b21d2504ed3aca3b52be61b5e6e4 (diff) | |
Merge branch 'x86-64'
* x86-64: (83 commits)
  [PATCH] x86_64: x86_64 stack usage debugging
  [PATCH] x86_64: (resend) x86_64 stack overflow debugging
  [PATCH] x86_64: msi_apic.c build fix
  [PATCH] x86_64: i386/x86-64 Add nmi watchdog support for new Intel CPUs
  [PATCH] x86_64: Avoid broadcasting NMI IPIs
  [PATCH] x86_64: fix apic error on bootup
  [PATCH] x86_64: enlarge window for stack growth
  [PATCH] x86_64: Minor string functions optimizations
  [PATCH] x86_64: Move export symbols to their C functions
  [PATCH] x86_64: Standardize i386/x86_64 handling of NMI_VECTOR
  [PATCH] x86_64: Fix modular pc speaker
  [PATCH] x86_64: remove sys32_ni_syscall()
  [PATCH] x86_64: Do not use -ffunction-sections for modules
  [PATCH] x86_64: Add cpu_relax to apic_wait_icr_idle
  [PATCH] x86_64: adjust kstack_depth_to_print default
  [PATCH] i386/x86-64: adjust /proc/interrupts column headings
  [PATCH] x86_64: Fix race in cpu_local_* on preemptible kernels
  [PATCH] x86_64: Fix fast check in safe_smp_processor_id
  [PATCH] x86_64: x86_64 setup.c - printing cmp related boottime information
  [PATCH] i386/x86-64/ia64: Move polling flag into thread_info_status
  ...
Manual resolve of trivial conflict in arch/i386/kernel/Makefile
Diffstat (limited to 'kernel/sched.c')
| -rw-r--r-- | kernel/sched.c | 9 | 
1 files changed, 7 insertions, 2 deletions
| diff --git a/kernel/sched.c b/kernel/sched.c index cfaf3fabeecd..a856040c200a 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
| @@ -818,6 +818,11 @@ static void deactivate_task(struct task_struct *p, runqueue_t *rq) | |||
| 818 | * the target CPU. | 818 | * the target CPU. | 
| 819 | */ | 819 | */ | 
| 820 | #ifdef CONFIG_SMP | 820 | #ifdef CONFIG_SMP | 
| 821 | |||
| 822 | #ifndef tsk_is_polling | ||
| 823 | #define tsk_is_polling(t) test_tsk_thread_flag(t, TIF_POLLING_NRFLAG) | ||
| 824 | #endif | ||
| 825 | |||
| 821 | static void resched_task(task_t *p) | 826 | static void resched_task(task_t *p) | 
| 822 | { | 827 | { | 
| 823 | int cpu; | 828 | int cpu; | 
| @@ -833,9 +838,9 @@ static void resched_task(task_t *p) | |||
| 833 | if (cpu == smp_processor_id()) | 838 | if (cpu == smp_processor_id()) | 
| 834 | return; | 839 | return; | 
| 835 | 840 | ||
| 836 | /* NEED_RESCHED must be visible before we test POLLING_NRFLAG */ | 841 | /* NEED_RESCHED must be visible before we test polling */ | 
| 837 | smp_mb(); | 842 | smp_mb(); | 
| 838 | if (!test_tsk_thread_flag(p, TIF_POLLING_NRFLAG)) | 843 | if (!tsk_is_polling(p)) | 
| 839 | smp_send_reschedule(cpu); | 844 | smp_send_reschedule(cpu); | 
| 840 | } | 845 | } | 
| 841 | #else | 846 | #else | 
