diff options
author | Vineet Gupta <Vineet.Gupta1@synopsys.com> | 2013-11-12 18:08:46 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2013-11-12 22:09:13 -0500 |
commit | c375f15a434db1867cb004bafba92aba739e4e39 (patch) | |
tree | 419ff5ddf823f9b43d95d1fc6345611989364cde /arch/x86/kernel | |
parent | 616c05d110bb4ef8203f49c9d2476874077c2f6a (diff) |
x86: move fpu_counter into ARCH specific thread_struct
Only a couple of arches (sh/x86) use fpu_counter in task_struct so it can
be moved out into ARCH specific thread_struct, reducing the size of
task_struct for other arches.
Compile tested i386_defconfig + gcc 4.7.3
Signed-off-by: Vineet Gupta <vgupta@synopsys.com>
Acked-by: Ingo Molnar <mingo@kernel.org>
Cc: Paul Mundt <paul.mundt@gmail.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'arch/x86/kernel')
-rw-r--r-- | arch/x86/kernel/i387.c | 2 | ||||
-rw-r--r-- | arch/x86/kernel/process_32.c | 4 | ||||
-rw-r--r-- | arch/x86/kernel/process_64.c | 2 | ||||
-rw-r--r-- | arch/x86/kernel/traps.c | 2 |
4 files changed, 5 insertions, 5 deletions
diff --git a/arch/x86/kernel/i387.c b/arch/x86/kernel/i387.c index 5d576ab34403..e8368c6dd2a2 100644 --- a/arch/x86/kernel/i387.c +++ b/arch/x86/kernel/i387.c | |||
@@ -100,7 +100,7 @@ void unlazy_fpu(struct task_struct *tsk) | |||
100 | __save_init_fpu(tsk); | 100 | __save_init_fpu(tsk); |
101 | __thread_fpu_end(tsk); | 101 | __thread_fpu_end(tsk); |
102 | } else | 102 | } else |
103 | tsk->fpu_counter = 0; | 103 | tsk->thread.fpu_counter = 0; |
104 | preempt_enable(); | 104 | preempt_enable(); |
105 | } | 105 | } |
106 | EXPORT_SYMBOL(unlazy_fpu); | 106 | EXPORT_SYMBOL(unlazy_fpu); |
diff --git a/arch/x86/kernel/process_32.c b/arch/x86/kernel/process_32.c index c2ec1aa6d454..6f1236c29c4b 100644 --- a/arch/x86/kernel/process_32.c +++ b/arch/x86/kernel/process_32.c | |||
@@ -153,7 +153,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp, | |||
153 | childregs->orig_ax = -1; | 153 | childregs->orig_ax = -1; |
154 | childregs->cs = __KERNEL_CS | get_kernel_rpl(); | 154 | childregs->cs = __KERNEL_CS | get_kernel_rpl(); |
155 | childregs->flags = X86_EFLAGS_IF | X86_EFLAGS_FIXED; | 155 | childregs->flags = X86_EFLAGS_IF | X86_EFLAGS_FIXED; |
156 | p->fpu_counter = 0; | 156 | p->thread.fpu_counter = 0; |
157 | p->thread.io_bitmap_ptr = NULL; | 157 | p->thread.io_bitmap_ptr = NULL; |
158 | memset(p->thread.ptrace_bps, 0, sizeof(p->thread.ptrace_bps)); | 158 | memset(p->thread.ptrace_bps, 0, sizeof(p->thread.ptrace_bps)); |
159 | return 0; | 159 | return 0; |
@@ -166,7 +166,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp, | |||
166 | p->thread.ip = (unsigned long) ret_from_fork; | 166 | p->thread.ip = (unsigned long) ret_from_fork; |
167 | task_user_gs(p) = get_user_gs(current_pt_regs()); | 167 | task_user_gs(p) = get_user_gs(current_pt_regs()); |
168 | 168 | ||
169 | p->fpu_counter = 0; | 169 | p->thread.fpu_counter = 0; |
170 | p->thread.io_bitmap_ptr = NULL; | 170 | p->thread.io_bitmap_ptr = NULL; |
171 | tsk = current; | 171 | tsk = current; |
172 | err = -ENOMEM; | 172 | err = -ENOMEM; |
diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c index 45ab4d6fc8a7..10fe4c189621 100644 --- a/arch/x86/kernel/process_64.c +++ b/arch/x86/kernel/process_64.c | |||
@@ -163,7 +163,7 @@ int copy_thread(unsigned long clone_flags, unsigned long sp, | |||
163 | p->thread.sp = (unsigned long) childregs; | 163 | p->thread.sp = (unsigned long) childregs; |
164 | p->thread.usersp = me->thread.usersp; | 164 | p->thread.usersp = me->thread.usersp; |
165 | set_tsk_thread_flag(p, TIF_FORK); | 165 | set_tsk_thread_flag(p, TIF_FORK); |
166 | p->fpu_counter = 0; | 166 | p->thread.fpu_counter = 0; |
167 | p->thread.io_bitmap_ptr = NULL; | 167 | p->thread.io_bitmap_ptr = NULL; |
168 | 168 | ||
169 | savesegment(gs, p->thread.gsindex); | 169 | savesegment(gs, p->thread.gsindex); |
diff --git a/arch/x86/kernel/traps.c b/arch/x86/kernel/traps.c index 729aa779ff75..996ce2313ce6 100644 --- a/arch/x86/kernel/traps.c +++ b/arch/x86/kernel/traps.c | |||
@@ -653,7 +653,7 @@ void math_state_restore(void) | |||
653 | return; | 653 | return; |
654 | } | 654 | } |
655 | 655 | ||
656 | tsk->fpu_counter++; | 656 | tsk->thread.fpu_counter++; |
657 | } | 657 | } |
658 | EXPORT_SYMBOL_GPL(math_state_restore); | 658 | EXPORT_SYMBOL_GPL(math_state_restore); |
659 | 659 | ||