summaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
authorAndi Kleen <ak@suse.de>2006-06-26 13:57:19 +0200
committerLinus Torvalds <torvalds@g5.osdl.org>2006-06-26 10:48:17 -0700
commit4d9bc79cd28b779610d9590b3a96a28a0f64a25a (patch)
tree83af4802b88318fe7951125bc663008a1adec62a /arch
parent26a3c49cec96ffb9cfcc30dfa0cd05ccc25dcb3a (diff)
downloadkernel-crypto-4d9bc79cd28b779610d9590b3a96a28a0f64a25a.tar.gz
kernel-crypto-4d9bc79cd28b779610d9590b3a96a28a0f64a25a.tar.xz
kernel-crypto-4d9bc79cd28b779610d9590b3a96a28a0f64a25a.zip
[PATCH] x86_64: Make sure is_compat_task works early
Previously it would only work in the first 32bit system call, not during early process setup. Signed-off-by: Andi Kleen <ak@suse.de> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
Diffstat (limited to 'arch')
-rw-r--r--arch/x86_64/kernel/process.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/x86_64/kernel/process.c b/arch/x86_64/kernel/process.c
index 52c03f6c773..dcb77b46234 100644
--- a/arch/x86_64/kernel/process.c
+++ b/arch/x86_64/kernel/process.c
@@ -364,8 +364,11 @@ void flush_thread(void)
struct task_struct *tsk = current;
struct thread_info *t = current_thread_info();
- if (t->flags & _TIF_ABI_PENDING)
+ if (t->flags & _TIF_ABI_PENDING) {
t->flags ^= (_TIF_ABI_PENDING | _TIF_IA32);
+ if (t->flags & _TIF_IA32)
+ current_thread_info()->status |= TS_COMPAT;
+ }
tsk->thread.debugreg0 = 0;
tsk->thread.debugreg1 = 0;