-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
x86, fpu: split FPU state from task struct - v5
Split the FPU save area from the task struct. This allows easy migration of FPU context, and it's generally cleaner. It also allows the following two optimizations: 1) only allocate when the application actually uses FPU, so in the first lazy FPU trap. This could save memory for non-fpu using apps. Next patch does this lazy allocation. 2) allocate the right size for the actual cpu rather than 512 bytes always. Patches enabling xsave/xrstor support (coming shortly) will take advantage of this. Signed-off-by: Suresh Siddha <suresh.b.siddha@intel.com> Signed-off-by: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Ingo Molnar <mingo@elte.hu> Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
- Loading branch information
Suresh Siddha
authored and
Ingo Molnar
committed
Apr 19, 2008
1 parent
fa5c463
commit 61c4628
Showing
16 changed files
with
161 additions
and
90 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,35 @@ | ||
#include <linux/errno.h> | ||
#include <linux/kernel.h> | ||
#include <linux/mm.h> | ||
#include <linux/smp.h> | ||
#include <linux/slab.h> | ||
#include <linux/sched.h> | ||
|
||
static struct kmem_cache *task_xstate_cachep; | ||
|
||
int arch_dup_task_struct(struct task_struct *dst, struct task_struct *src) | ||
{ | ||
*dst = *src; | ||
dst->thread.xstate = kmem_cache_alloc(task_xstate_cachep, GFP_KERNEL); | ||
if (!dst->thread.xstate) | ||
return -ENOMEM; | ||
WARN_ON((unsigned long)dst->thread.xstate & 15); | ||
memcpy(dst->thread.xstate, src->thread.xstate, xstate_size); | ||
return 0; | ||
} | ||
|
||
void free_thread_info(struct thread_info *ti) | ||
{ | ||
kmem_cache_free(task_xstate_cachep, ti->task->thread.xstate); | ||
ti->task->thread.xstate = NULL; | ||
|
||
free_pages((unsigned long)(ti), get_order(THREAD_SIZE)); | ||
} | ||
|
||
void arch_task_cache_init(void) | ||
{ | ||
task_xstate_cachep = | ||
kmem_cache_create("task_xstate", xstate_size, | ||
__alignof__(union thread_xstate), | ||
SLAB_PANIC, NULL); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.