diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-23 13:59:07 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-05-23 13:59:07 -0400 |
commit | ec0d7f18ab7b5097d7c0c8f3d909ca1031b9d5cd (patch) | |
tree | 7d62c924592145f819ecaa5d60460a05a10dfdbd /arch/sparc | |
parent | 269af9a1a08d368b46d72e74126564d04c354f7e (diff) | |
parent | 1dcc8d7ba235a316a056f993e88f0d18b92c60d9 (diff) |
Merge branch 'x86-fpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip
Pull fpu state cleanups from Ingo Molnar:
"This tree streamlines further aspects of FPU handling by eliminating
the prepare_to_copy() complication and moving that logic to
arch_dup_task_struct().
It also fixes the FPU dumps in threaded core dumps, removes and old
(and now invalid) assumption plus micro-optimizes the exit path by
avoiding an FPU save for dead tasks."
Fixed up trivial add-add conflict in arch/sh/kernel/process.c that came
in because we now do the FPU handling in arch_dup_task_struct() rather
than the legacy (and now gone) prepare_to_copy().
* 'x86-fpu-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/tip/tip:
x86, fpu: drop the fpu state during thread exit
x86, xsave: remove thread_has_fpu() bug check in __sanitize_i387_state()
coredump: ensure the fpu state is flushed for proper multi-threaded core dump
fork: move the real prepare_to_copy() users to arch_dup_task_struct()
Diffstat (limited to 'arch/sparc')
-rw-r--r-- | arch/sparc/include/asm/processor_32.h | 3 | ||||
-rw-r--r-- | arch/sparc/include/asm/processor_64.h | 3 |
2 files changed, 0 insertions, 6 deletions
diff --git a/arch/sparc/include/asm/processor_32.h b/arch/sparc/include/asm/processor_32.h index 9cbd854fdfdd..f74ac9ee33a8 100644 --- a/arch/sparc/include/asm/processor_32.h +++ b/arch/sparc/include/asm/processor_32.h | |||
@@ -108,9 +108,6 @@ static inline void start_thread(struct pt_regs * regs, unsigned long pc, | |||
108 | #define release_thread(tsk) do { } while(0) | 108 | #define release_thread(tsk) do { } while(0) |
109 | extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags); | 109 | extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags); |
110 | 110 | ||
111 | /* Prepare to copy thread state - unlazy all lazy status */ | ||
112 | #define prepare_to_copy(tsk) do { } while (0) | ||
113 | |||
114 | extern unsigned long get_wchan(struct task_struct *); | 111 | extern unsigned long get_wchan(struct task_struct *); |
115 | 112 | ||
116 | #define task_pt_regs(tsk) ((tsk)->thread.kregs) | 113 | #define task_pt_regs(tsk) ((tsk)->thread.kregs) |
diff --git a/arch/sparc/include/asm/processor_64.h b/arch/sparc/include/asm/processor_64.h index e713db249931..67df5cc10011 100644 --- a/arch/sparc/include/asm/processor_64.h +++ b/arch/sparc/include/asm/processor_64.h | |||
@@ -186,9 +186,6 @@ do { \ | |||
186 | /* Free all resources held by a thread. */ | 186 | /* Free all resources held by a thread. */ |
187 | #define release_thread(tsk) do { } while (0) | 187 | #define release_thread(tsk) do { } while (0) |
188 | 188 | ||
189 | /* Prepare to copy thread state - unlazy all lazy status */ | ||
190 | #define prepare_to_copy(tsk) do { } while (0) | ||
191 | |||
192 | extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags); | 189 | extern pid_t kernel_thread(int (*fn)(void *), void * arg, unsigned long flags); |
193 | 190 | ||
194 | extern unsigned long get_wchan(struct task_struct *task); | 191 | extern unsigned long get_wchan(struct task_struct *task); |