+ cross-arch-dont-corrupt-personality-flags-upon-exec.patch added to -mm tree

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



The patch titled
     Subject: cross-arch: don't corrupt personality flags upon exec()
has been added to the -mm tree.  Its filename is
     cross-arch-dont-corrupt-personality-flags-upon-exec.patch

Before you just go and hit "reply", please:
   a) Consider who else should be cc'ed
   b) Prefer to cc a suitable mailing list as well
   c) Ideally: find the original patch on the mailing list and do a
      reply-to-all to that, adding suitable additional cc's

*** Remember to use Documentation/SubmitChecklist when testing your code ***

The -mm tree is included into linux-next and is updated
there every 3-4 working days

------------------------------------------------------
From: Jiri Kosina <jkosina@xxxxxxx>
Subject: cross-arch: don't corrupt personality flags upon exec()

Historically, the top three bytes of personality have been used for things
such as ADDR_NO_RANDOMIZE, which made sense only for specific
architectures.

We now however have a flag there that is general no matter the
architecture (UNAME26); generally we have to be careful to preserve the
personality flags across exec().

This patch tries to fix all architectures that forcefully overwrite
personality flags during exec() (ppc32 and s390 have been fixed recently
by commits f9783ec86 and 59e4c3a2f in a similar way already).

Signed-off-by: Jiri Kosina <jkosina@xxxxxxx>
Cc: Haavard Skinnemoen <hskinnemoen@xxxxxxxxx>
Cc: Hans-Christian Egtvedt <egtvedt@xxxxxxxxxxxx>
Cc: Mike Frysinger <vapier@xxxxxxxxxx>
Cc: Mark Salter <msalter@xxxxxxxxxx>
Cc: Mikael Starvik <starvik@xxxxxxxx>
Cc: Jesper Nilsson <jesper.nilsson@xxxxxxxx>
Cc: David Howells <dhowells@xxxxxxxxxx>
Cc: Yoshinori Sato <ysato@xxxxxxxxxxxxxxxxxxxx>
Cc: Richard Kuo <rkuo@xxxxxxxxxxxxxx>
Cc: Hirokazu Takata <takata@xxxxxxxxxxxxxx>
Cc: Geert Uytterhoeven <geert@xxxxxxxxxxxxxx>
Cc: Michal Simek <monstr@xxxxxxxxx>
Cc: Koichi Yasutake <yasutake.koichi@xxxxxxxxxxxxxxxx>
Cc: Jonas Bonn <jonas@xxxxxxxxxxxx>
Cc: Chen Liqin <liqin.chen@xxxxxxxxxxxxx>
Cc: Lennox Wu <lennox.wu@xxxxxxxxx>
Cc: Paul Mundt <lethal@xxxxxxxxxxxx>
Cc: "David S. Miller" <davem@xxxxxxxxxxxxx>
Cc: Chris Zankel <chris@xxxxxxxxxx>
Signed-off-by: Andrew Morton <akpm@xxxxxxxxxxxxxxxxxxxx>
---

 arch/avr32/include/asm/elf.h      |    3 ++-
 arch/blackfin/include/asm/elf.h   |    3 ++-
 arch/c6x/include/asm/elf.h        |    3 ++-
 arch/cris/include/asm/elf.h       |    3 ++-
 arch/frv/include/asm/elf.h        |    3 ++-
 arch/h8300/include/asm/elf.h      |    3 ++-
 arch/hexagon/include/asm/elf.h    |    3 ++-
 arch/m32r/include/asm/elf.h       |    3 ++-
 arch/m68k/include/asm/elf.h       |    3 ++-
 arch/microblaze/include/asm/elf.h |    3 ++-
 arch/mn10300/include/asm/elf.h    |    3 ++-
 arch/openrisc/include/asm/elf.h   |    3 ++-
 arch/score/include/asm/elf.h      |    2 +-
 arch/sh/include/asm/elf.h         |    3 ++-
 arch/sparc/include/asm/elf_32.h   |    3 ++-
 arch/xtensa/include/asm/elf.h     |    3 ++-
 16 files changed, 31 insertions(+), 16 deletions(-)

diff -puN arch/avr32/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/avr32/include/asm/elf.h
--- a/arch/avr32/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/avr32/include/asm/elf.h
@@ -102,6 +102,7 @@ typedef struct user_fpu_struct elf_fpreg
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX_32BIT)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX_32BIT | (current->personality & (~PER_MASK)))
 
 #endif /* __ASM_AVR32_ELF_H */
diff -puN arch/blackfin/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/blackfin/include/asm/elf.h
--- a/arch/blackfin/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/blackfin/include/asm/elf.h
@@ -132,6 +132,7 @@ do {											\
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif
diff -puN arch/c6x/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/c6x/include/asm/elf.h
--- a/arch/c6x/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/c6x/include/asm/elf.h
@@ -77,7 +77,8 @@ do {								\
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 /* C6X specific section types */
 #define SHT_C6000_UNWIND	0x70000001
diff -puN arch/cris/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/cris/include/asm/elf.h
--- a/arch/cris/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/cris/include/asm/elf.h
@@ -86,6 +86,7 @@ typedef unsigned long elf_fpregset_t;
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif
diff -puN arch/frv/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/frv/include/asm/elf.h
--- a/arch/frv/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/frv/include/asm/elf.h
@@ -137,6 +137,7 @@ do {											\
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif
diff -puN arch/h8300/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/h8300/include/asm/elf.h
--- a/arch/h8300/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/h8300/include/asm/elf.h
@@ -54,7 +54,8 @@ typedef unsigned long elf_fpregset_t;
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #define R_H8_NONE       0
 #define R_H8_DIR32      1
diff -puN arch/hexagon/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/hexagon/include/asm/elf.h
--- a/arch/hexagon/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/hexagon/include/asm/elf.h
@@ -217,7 +217,8 @@ do {					\
 #define ELF_PLATFORM  (NULL)
 
 #ifdef __KERNEL__
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 #endif
 
 #define ARCH_HAS_SETUP_ADDITIONAL_PAGES 1
diff -puN arch/m32r/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/m32r/include/asm/elf.h
--- a/arch/m32r/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/m32r/include/asm/elf.h
@@ -128,6 +128,7 @@ typedef elf_fpreg_t elf_fpregset_t;
    intent than poking at uname or /proc/cpuinfo.  */
 #define ELF_PLATFORM	(NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif  /* _ASM_M32R__ELF_H */
diff -puN arch/m68k/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/m68k/include/asm/elf.h
--- a/arch/m68k/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/m68k/include/asm/elf.h
@@ -113,6 +113,7 @@ typedef struct user_m68kfp_struct elf_fp
 
 #define ELF_PLATFORM  (NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif
diff -puN arch/microblaze/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/microblaze/include/asm/elf.h
--- a/arch/microblaze/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/microblaze/include/asm/elf.h
@@ -116,7 +116,8 @@ do {							\
 } while (0)
 
 #ifdef __KERNEL__
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX_32BIT)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX_32BIT | (current->personality & (~PER_MASK)))
 #endif
 
 #endif /* __uClinux__ */
diff -puN arch/mn10300/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/mn10300/include/asm/elf.h
--- a/arch/mn10300/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/mn10300/include/asm/elf.h
@@ -151,7 +151,8 @@ do {						\
 #define ELF_PLATFORM  (NULL)
 
 #ifdef __KERNEL__
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 #endif
 
 #endif /* _ASM_ELF_H */
diff -puN arch/openrisc/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/openrisc/include/asm/elf.h
--- a/arch/openrisc/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/openrisc/include/asm/elf.h
@@ -110,7 +110,8 @@ extern void dump_elf_thread(elf_greg_t *
 
 #define ELF_PLATFORM	(NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif /* __KERNEL__ */
 #endif
diff -puN arch/score/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/score/include/asm/elf.h
--- a/arch/score/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/score/include/asm/elf.h
@@ -54,7 +54,7 @@ typedef elf_fpreg_t	elf_fpregset_t;
 
 #define SET_PERSONALITY(ex)					\
 do {								\
-	set_personality(PER_LINUX);				\
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK))); \
 } while (0)
 
 struct task_struct;
diff -puN arch/sh/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/sh/include/asm/elf.h
--- a/arch/sh/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/sh/include/asm/elf.h
@@ -183,7 +183,8 @@ do {									\
 } while (0)
 #endif
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX_32BIT)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX_32BIT | (current->personality & (~PER_MASK)))
 
 #ifdef CONFIG_VSYSCALL
 /* vDSO has arch_setup_additional_pages */
diff -puN arch/sparc/include/asm/elf_32.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/sparc/include/asm/elf_32.h
--- a/arch/sparc/include/asm/elf_32.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/sparc/include/asm/elf_32.h
@@ -128,6 +128,7 @@ typedef struct {
 
 #define ELF_PLATFORM	(NULL)
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX | (current->personality & (~PER_MASK)))
 
 #endif /* !(__ASMSPARC_ELF_H) */
diff -puN arch/xtensa/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec arch/xtensa/include/asm/elf.h
--- a/arch/xtensa/include/asm/elf.h~cross-arch-dont-corrupt-personality-flags-upon-exec
+++ a/arch/xtensa/include/asm/elf.h
@@ -189,7 +189,8 @@ typedef struct {
 #endif
 } elf_xtregs_t;
 
-#define SET_PERSONALITY(ex) set_personality(PER_LINUX_32BIT)
+#define SET_PERSONALITY(ex) \
+	set_personality(PER_LINUX_32BIT | (current->personality & (~PER_MASK)))
 
 struct task_struct;
 
_

Patches currently in -mm which might be from jkosina@xxxxxxx are

origin.patch
linux-next.patch
cross-arch-dont-corrupt-personality-flags-upon-exec.patch

--
To unsubscribe from this list: send the line "unsubscribe mm-commits" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Kernel Newbies FAQ]     [Kernel Archive]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [Bugtraq]     [Photo]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]

  Powered by Linux