public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] x32: make sure TS_COMPAT is cleared for x32 tasks
@ 2012-02-26  4:25 Bobby Powers
  2012-02-26  5:50 ` [tip:x86/x32] x32: Make " tip-bot for Bobby Powers
  2012-02-26  5:54 ` [PATCH] x32: make " H. Peter Anvin
  0 siblings, 2 replies; 3+ messages in thread
From: Bobby Powers @ 2012-02-26  4:25 UTC (permalink / raw)
  To: linux-kernel; +Cc: hpa, mingo, tglx, x86, hjl.tools, Bobby Powers

If a process has a non-x32 ia32 personality and changes to x32, the
process would keep its TS_COMPAT flag. x32 uses the presence of the
x32 flag on a syscall to determine compat status, so make sure
TS_COMPAT is cleared.

Signed-off-by: Bobby Powers <bobbypowers@gmail.com>
---
 arch/x86/kernel/process_64.c |    3 +++
 1 files changed, 3 insertions(+), 0 deletions(-)

diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c
index e9ec8f1..a465973 100644
--- a/arch/x86/kernel/process_64.c
+++ b/arch/x86/kernel/process_64.c
@@ -539,6 +539,9 @@ void set_personality_ia32(bool x32)
 		clear_thread_flag(TIF_IA32);
 		set_thread_flag(TIF_X32);
 		current->personality &= ~READ_IMPLIES_EXEC;
+		/* is_compat_task() uses the presence of the x32
+		   syscall bit flag to determine compat status */
+		current_thread_info()->status &= ~TS_COMPAT;
 	} else {
 		set_thread_flag(TIF_IA32);
 		clear_thread_flag(TIF_X32);
-- 
1.7.7.6


^ permalink raw reply related	[flat|nested] 3+ messages in thread

end of thread, other threads:[~2012-02-26  5:55 UTC | newest]

Thread overview: 3+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2012-02-26  4:25 [PATCH] x32: make sure TS_COMPAT is cleared for x32 tasks Bobby Powers
2012-02-26  5:50 ` [tip:x86/x32] x32: Make " tip-bot for Bobby Powers
2012-02-26  5:54 ` [PATCH] x32: make " H. Peter Anvin

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox