3699 lines
118 KiB
Diff
Raw Normal View History

2016-12-21 19:30:02 -05:00
From 63caea4637e5dfa2ffaabb6d30b0aa4db9d3fe87 Mon Sep 17 00:00:00 2001
From: Tad <tad@spotco.us>
Date: Thu, 19 Nov 2015 07:14:38 -0500
Subject: [PATCH] deal with rejected PaX patch hunks
---
arch/arm/include/asm/atomic.h | 204 ++++++++++++++--
arch/arm/include/asm/atomic.h.rej | 321 -------------------------
arch/arm/include/asm/elf.h | 4 -
arch/arm/include/asm/elf.h.rej | 11 -
arch/arm/kernel/process.c | 3 +-
arch/arm/kernel/process.c.rej | 13 -
arch/x86/boot/Makefile | 3 +
arch/x86/boot/Makefile.rej | 11 -
arch/x86/ia32/ia32entry.S | 3 +-
arch/x86/ia32/ia32entry.S.rej | 16 --
arch/x86/include/asm/fpu-internal.h | 2 +-
arch/x86/include/asm/fpu-internal.h.rej | 11 -
arch/x86/include/asm/paravirt_types.h | 6 +-
arch/x86/include/asm/paravirt_types.h.rej | 26 --
arch/x86/include/asm/pgtable_64_types.h | 5 +
arch/x86/include/asm/pgtable_64_types.h.rej | 13 -
arch/x86/kernel/entry_32.S | 17 +-
arch/x86/kernel/entry_32.S.rej | 47 ----
arch/x86/kernel/entry_64.S | 2 +-
arch/x86/kernel/entry_64.S.rej | 11 -
arch/x86/kernel/irq.c | 2 +-
arch/x86/kernel/irq.c.rej | 15 --
arch/x86/kernel/relocate_kernel_64.S | 1 +
arch/x86/kernel/relocate_kernel_64.S.rej | 18 --
arch/x86/kernel/setup.c | 2 +-
arch/x86/kernel/setup.c.rej | 10 -
arch/x86/kernel/sys_x86_64.c.rej | 11 -
arch/x86/mm/fault.c | 16 ++
arch/x86/mm/fault.c.rej | 23 --
arch/x86/mm/init.c | 2 +-
arch/x86/mm/init.c.rej | 11 -
arch/x86/mm/ioremap.c.rej | 11 -
arch/x86/mm/mmap.c | 16 +-
arch/x86/mm/mmap.c.rej | 28 ---
arch/x86/xen/xen-asm_32.S | 12 +-
arch/x86/xen/xen-asm_32.S.rej | 23 --
drivers/base/power/wakeup.c | 2 +-
drivers/base/power/wakeup.c.rej | 11 -
drivers/gpu/drm/drm_fops.c | 4 +-
drivers/gpu/drm/drm_fops.c.rej | 13 -
drivers/gpu/drm/i915/i915_gem_execbuffer.c | 4 +-
drivers/gpu/drm/i915/i915_gem_execbuffer.c.rej | 14 --
drivers/gpu/drm/i915/intel_display.c | 9 +-
drivers/gpu/drm/i915/intel_display.c.rej | 32 ---
drivers/staging/speakup/speakup_soft.c.rej | 15 --
fs/binfmt_elf.c | 14 ++
fs/binfmt_elf.c.rej | 22 --
fs/compat_ioctl.c | 8 +-
fs/compat_ioctl.c.rej | 40 ---
fs/libfs.c | 3 +
fs/libfs.c.rej | 12 -
fs/nfs/inode.c.rej | 11 -
fs/proc/nommu.c | 2 +-
fs/proc/nommu.c.rej | 11 -
fs/proc/task_mmu.c | 16 +-
fs/proc/task_mmu.c.rej | 39 ---
fs/proc/task_nommu.c | 2 +-
fs/proc/task_nommu.c.rej | 10 -
include/linux/efi.h | 2 +-
include/linux/efi.h.rej | 11 -
include/linux/gfp.h.rej | 10 -
include/linux/if_team.h | 2 +-
include/linux/if_team.h.rej | 10 -
include/linux/sysctl.h | 6 +-
include/linux/sysctl.h.rej | 14 --
include/linux/vmalloc.h | 7 +-
include/linux/vmalloc.h.rej | 23 --
include/net/inetpeer.h | 4 +-
include/net/inetpeer.h.rej | 26 --
include/sound/soc.h | 2 +-
include/sound/soc.h.rej | 11 -
kernel/audit.c | 2 +-
kernel/audit.c.rej | 11 -
kernel/module.c | 16 +-
kernel/module.c.rej | 26 --
kernel/power/process.c | 3 +-
kernel/power/process.c.rej | 19 --
kernel/rcutree.h | 2 +-
kernel/rcutree.h.rej | 11 -
kernel/smp.c | 8 +-
kernel/smp.c.rej | 28 ---
kernel/trace/trace_stack.c | 2 +-
kernel/trace/trace_stack.c.rej | 11 -
lib/bitmap.c | 2 +-
lib/bitmap.c.rej | 10 -
mm/hugetlb.c | 4 +
mm/hugetlb.c.rej | 12 -
mm/memory-failure.c | 5 +-
mm/memory-failure.c.rej | 20 --
mm/memory.c | 93 +++----
mm/memory.c.rej | 149 ------------
mm/mmap.c | 49 +++-
mm/mmap.c.rej | 103 --------
mm/swap.c | 2 +
mm/swap.c.rej | 18 --
net/bluetooth/hci_conn.c.rej | 10 -
net/bluetooth/l2cap_core.c.rej | 15 --
net/compat.c | 6 +-
net/compat.c.rej | 14 --
net/ipv4/inetpeer.c | 4 +-
net/ipv4/inetpeer.c.rej | 13 -
net/ipv4/ping.c | 2 +-
net/ipv4/ping.c.rej | 11 -
net/ipv4/route.c | 2 +-
net/ipv4/route.c.rej | 11 -
net/ipv4/udp.c | 2 +-
net/ipv4/udp.c.rej | 11 -
net/phonet/socket.c | 2 +-
net/phonet/socket.c.rej | 11 -
net/socket.c | 2 +-
net/socket.c.rej | 11 -
security/keys/compat.c | 2 +-
security/keys/compat.c.rej | 11 -
security/keys/keyctl.c | 2 +-
security/keys/keyctl.c.rej | 11 -
security/selinux/hooks.c | 2 +-
security/selinux/hooks.c.rej | 10 -
sound/soc/soc-pcm.c.rej | 11 -
sound/usb/card.h.rej | 18 --
usr/gen_init_cpio.c | 10 +-
usr/gen_init_cpio.c.rej | 24 --
121 files changed, 455 insertions(+), 1731 deletions(-)
delete mode 100644 arch/arm/include/asm/atomic.h.rej
delete mode 100644 arch/arm/include/asm/elf.h.rej
delete mode 100644 arch/arm/kernel/process.c.rej
delete mode 100644 arch/x86/boot/Makefile.rej
delete mode 100644 arch/x86/ia32/ia32entry.S.rej
delete mode 100644 arch/x86/include/asm/fpu-internal.h.rej
delete mode 100644 arch/x86/include/asm/paravirt_types.h.rej
delete mode 100644 arch/x86/include/asm/pgtable_64_types.h.rej
delete mode 100644 arch/x86/kernel/entry_32.S.rej
delete mode 100644 arch/x86/kernel/entry_64.S.rej
delete mode 100644 arch/x86/kernel/irq.c.rej
delete mode 100644 arch/x86/kernel/relocate_kernel_64.S.rej
delete mode 100644 arch/x86/kernel/setup.c.rej
delete mode 100644 arch/x86/kernel/sys_x86_64.c.rej
delete mode 100644 arch/x86/mm/fault.c.rej
delete mode 100644 arch/x86/mm/init.c.rej
delete mode 100644 arch/x86/mm/ioremap.c.rej
delete mode 100644 arch/x86/mm/mmap.c.rej
delete mode 100644 arch/x86/xen/xen-asm_32.S.rej
delete mode 100644 drivers/base/power/wakeup.c.rej
delete mode 100644 drivers/gpu/drm/drm_fops.c.rej
delete mode 100644 drivers/gpu/drm/i915/i915_gem_execbuffer.c.rej
delete mode 100644 drivers/gpu/drm/i915/intel_display.c.rej
delete mode 100644 drivers/staging/speakup/speakup_soft.c.rej
delete mode 100644 fs/binfmt_elf.c.rej
delete mode 100644 fs/compat_ioctl.c.rej
delete mode 100644 fs/libfs.c.rej
delete mode 100644 fs/nfs/inode.c.rej
delete mode 100644 fs/proc/nommu.c.rej
delete mode 100644 fs/proc/task_mmu.c.rej
delete mode 100644 fs/proc/task_nommu.c.rej
delete mode 100644 include/linux/efi.h.rej
delete mode 100644 include/linux/gfp.h.rej
delete mode 100644 include/linux/if_team.h.rej
delete mode 100644 include/linux/sysctl.h.rej
delete mode 100644 include/linux/vmalloc.h.rej
delete mode 100644 include/net/inetpeer.h.rej
delete mode 100644 include/sound/soc.h.rej
delete mode 100644 kernel/audit.c.rej
delete mode 100644 kernel/module.c.rej
delete mode 100644 kernel/power/process.c.rej
delete mode 100644 kernel/rcutree.h.rej
delete mode 100644 kernel/smp.c.rej
delete mode 100644 kernel/trace/trace_stack.c.rej
delete mode 100644 lib/bitmap.c.rej
delete mode 100644 mm/hugetlb.c.rej
delete mode 100644 mm/memory-failure.c.rej
delete mode 100644 mm/memory.c.rej
delete mode 100644 mm/mmap.c.rej
delete mode 100644 mm/swap.c.rej
delete mode 100644 net/bluetooth/hci_conn.c.rej
delete mode 100644 net/bluetooth/l2cap_core.c.rej
delete mode 100644 net/compat.c.rej
delete mode 100644 net/ipv4/inetpeer.c.rej
delete mode 100644 net/ipv4/ping.c.rej
delete mode 100644 net/ipv4/route.c.rej
delete mode 100644 net/ipv4/udp.c.rej
delete mode 100644 net/phonet/socket.c.rej
delete mode 100644 net/socket.c.rej
delete mode 100644 security/keys/compat.c.rej
delete mode 100644 security/keys/keyctl.c.rej
delete mode 100644 security/selinux/hooks.c.rej
delete mode 100644 sound/soc/soc-pcm.c.rej
delete mode 100644 sound/usb/card.h.rej
delete mode 100644 usr/gen_init_cpio.c.rej
diff --git a/arch/arm/include/asm/atomic.h b/arch/arm/include/asm/atomic.h
index 621d737..8cc89ab 100644
--- a/arch/arm/include/asm/atomic.h
+++ b/arch/arm/include/asm/atomic.h
@@ -108,6 +108,42 @@ static inline int atomic_add_return(int i, atomic_t *v)
prefetchw(&v->counter);
__asm__ __volatile__("@ atomic_add_return\n"
+"1: ldrex %1, [%3]\n"
+" adds %0, %1, %4\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+" bvc 3f\n"
+" mov %0, %1\n"
+"2: bkpt 0xf103\n"
+"3:\n"
+#endif
+
+" strex %1, %0, [%3]\n"
+" teq %1, #0\n"
+" bne 1b"
+
+#ifdef CONFIG_PAX_REFCOUNT
+"\n4:\n"
+ _ASM_EXTABLE(2b, 4b)
+#endif
+
+ : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
+ : "r" (&v->counter), "Ir" (i)
+ : "cc");
+
+ smp_mb();
+
+ return result;
+}
+
+static inline int atomic_add_return_unchecked(int i, atomic_unchecked_t *v)
+{
+ unsigned long tmp;
+ int result;
+
+ smp_mb();
+
+ __asm__ __volatile__("@ atomic_add_return_unchecked\n"
"1: ldrex %0, [%3]\n"
" add %0, %0, %4\n"
" strex %1, %0, [%3]\n"
@@ -176,11 +212,25 @@ static inline int atomic_sub_return(int i, atomic_t *v)
prefetchw(&v->counter);
__asm__ __volatile__("@ atomic_sub_return\n"
-"1: ldrex %0, [%3]\n"
-" sub %0, %0, %4\n"
+"1: ldrex %1, [%3]\n"
+" subs %0, %1, %4\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+" bvc 3f\n"
+" mov %0, %1\n"
+"2: bkpt 0xf103\n"
+"3:\n"
+#endif
+
" strex %1, %0, [%3]\n"
" teq %1, #0\n"
" bne 1b"
+
+#ifdef CONFIG_PAX_REFCOUNT
+"\n4:\n"
+ _ASM_EXTABLE(2b, 4b)
+#endif
+
: "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
: "r" (&v->counter), "Ir" (i)
: "cc");
@@ -213,6 +263,28 @@ static inline int atomic_cmpxchg(atomic_t *ptr, int old, int new)
return oldval;
}
+static inline int atomic_cmpxchg_unchecked(atomic_unchecked_t *ptr, int old, int new)
+{
+ unsigned long oldval, res;
+
+ smp_mb();
+
+ do {
+ __asm__ __volatile__("@ atomic_cmpxchg_unchecked\n"
+ "ldrex %1, [%3]\n"
+ "mov %0, #0\n"
+ "teq %1, %4\n"
+ "strexeq %0, %5, [%3]\n"
+ : "=&r" (res), "=&r" (oldval), "+Qo" (ptr->counter)
+ : "r" (&ptr->counter), "Ir" (old), "r" (new)
+ : "cc");
+ } while (res);
+
+ smp_mb();
+
+ return oldval;
+}
+
static inline int __atomic_add_unless(atomic_t *v, int a, int u)
{
int oldval, newval;
@@ -302,6 +374,11 @@ static inline int atomic_cmpxchg(atomic_t *v, int old, int new)
return ret;
}
+static inline int atomic_cmpxchg_unchecked(atomic_unchecked_t *v, int old, int new)
+{
+ return atomic_cmpxchg(v, old, new);
+}
+
static inline int __atomic_add_unless(atomic_t *v, int a, int u)
{
int c, old;
@@ -316,12 +393,33 @@ static inline int __atomic_add_unless(atomic_t *v, int a, int u)
#define atomic_xchg(v, new) (xchg(&((v)->counter), new))
+static inline int atomic_xchg_unchecked(atomic_unchecked_t *v, int new)
+{
+ return xchg(&v->counter, new);
+}
+
#define atomic_inc(v) atomic_add(1, v)
+static inline void atomic_inc_unchecked(atomic_unchecked_t *v)
+{
+ atomic_add_unchecked(1, v);
+}
#define atomic_dec(v) atomic_sub(1, v)
+static inline void atomic_dec_unchecked(atomic_unchecked_t *v)
+{
+ atomic_sub_unchecked(1, v);
+}
#define atomic_inc_and_test(v) (atomic_add_return(1, v) == 0)
+static inline int atomic_inc_and_test_unchecked(atomic_unchecked_t *v)
+{
+ return atomic_add_return_unchecked(1, v) == 0;
+}
#define atomic_dec_and_test(v) (atomic_sub_return(1, v) == 0)
#define atomic_inc_return(v) (atomic_add_return(1, v))
+static inline int atomic_inc_return_unchecked(atomic_unchecked_t *v)
+{
+ return atomic_add_return_unchecked(1, v);
+}
#define atomic_dec_return(v) (atomic_sub_return(1, v))
#define atomic_sub_and_test(i, v) (atomic_sub_return(i, v) == 0)
@@ -337,6 +435,14 @@ typedef struct {
u64 __aligned(8) counter;
} atomic64_t;
+#ifdef CONFIG_PAX_REFCOUNT
+typedef struct {
+ u64 __aligned(8) counter;
+} atomic64_unchecked_t;
+#else
+typedef atomic64_t atomic64_unchecked_t;
+#endif
+
#define ATOMIC64_INIT(i) { (i) }
#ifdef CONFIG_ARM_LPAE
@@ -401,6 +507,20 @@ static inline void atomic64_set(atomic64_t *v, u64 i)
: "r" (&v->counter), "r" (i)
: "cc");
}
+
+static inline void atomic64_set_unchecked(atomic64_unchecked_t *v, u64 i)
+{
+ u64 tmp;
+
+ __asm__ __volatile__("@ atomic64_set_unchecked\n"
+"1: ldrexd %0, %H0, [%2]\n"
+" strexd %0, %3, %H3, [%2]\n"
+" teq %0, #0\n"
+" bne 1b"
+ : "=&r" (tmp), "=Qo" (v->counter)
+ : "r" (&v->counter), "r" (i)
+ : "cc");
+}
#endif
static inline void atomic64_add(u64 i, atomic64_t *v)
@@ -452,13 +572,50 @@ static inline void atomic64_add_unchecked(u64 i, atomic64_unchecked_t *v)
static inline u64 atomic64_add_return(u64 i, atomic64_t *v)
{
+ u64 result, tmp;
+
+ smp_mb();
+
+ __asm__ __volatile__("@ atomic64_add_return\n"
+"1: ldrexd %1, %H1, [%3]\n"
+" adds %0, %1, %4\n"
+" adcs %H0, %H1, %H4\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+" bvc 3f\n"
+" mov %0, %1\n"
+" mov %H0, %H1\n"
+"2: bkpt 0xf103\n"
+"3:\n"
+#endif
+
+" strexd %1, %0, %H0, [%3]\n"
+" teq %1, #0\n"
+" bne 1b"
+
+#ifdef CONFIG_PAX_REFCOUNT
+"\n4:\n"
+ _ASM_EXTABLE(2b, 4b)
+#endif
+
+ : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
+ : "r" (&v->counter), "r" (i)
+ : "cc");
+
+ smp_mb();
+
+ return result;
+}
+
+static inline u64 atomic64_add_return_unchecked(u64 i, atomic64_unchecked_t *v)
+{
u64 result;
unsigned long tmp;
smp_mb();
prefetchw(&v->counter);
- __asm__ __volatile__("@ atomic64_add_return\n"
+ __asm__ __volatile__("@ atomic64_add_return_unchecked\n"
"1: ldrexd %0, %H0, [%3]\n"
" adds %0, %0, %4\n"
" adc %H0, %H0, %H4\n"
@@ -482,7 +639,14 @@ static inline void atomic64_sub(u64 i, atomic64_t *v)
__asm__ __volatile__("@ atomic64_sub\n"
"1: ldrexd %0, %H0, [%3]\n"
" subs %0, %0, %4\n"
-" sbc %H0, %H0, %H4\n"
+" sbcs %H0, %H0, %H4\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+" bvc 3f\n"
+"2: bkpt 0xf103\n"
+"3:\n"
+#endif
+
" strexd %1, %0, %H0, [%3]\n"
" teq %1, #0\n"
" bne 1b"
@@ -491,15 +655,14 @@ static inline void atomic64_sub(u64 i, atomic64_t *v)
: "cc");
}
-static inline u64 atomic64_sub_return(u64 i, atomic64_t *v)
+static inline void atomic64_sub_unchecked(u64 i, atomic64_unchecked_t *v)
{
u64 result;
unsigned long tmp;
- smp_mb();
prefetchw(&v->counter);
- __asm__ __volatile__("@ atomic64_sub_return\n"
+ __asm__ __volatile__("@ atomic64_sub_unchecked\n"
"1: ldrexd %0, %H0, [%3]\n"
" subs %0, %0, %4\n"
" sbc %H0, %H0, %H4\n"
@@ -621,22 +784,35 @@ static inline u64 atomic64_xchg(atomic64_t *ptr, u64 new)
static inline u64 atomic64_dec_if_positive(atomic64_t *v)
{
- u64 result;
- unsigned long tmp;
+ u64 result, tmp;
smp_mb();
prefetchw(&v->counter);
__asm__ __volatile__("@ atomic64_dec_if_positive\n"
-"1: ldrexd %0, %H0, [%3]\n"
-" subs %0, %0, #1\n"
-" sbc %H0, %H0, #0\n"
+"1: ldrexd %1, %H1, [%3]\n"
+" subs %0, %1, #1\n"
+" sbcs %H0, %H1, #0\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+" bvc 3f\n"
+" mov %0, %1\n"
+" mov %H0, %H1\n"
+"2: bkpt 0xf103\n"
+"3:\n"
+#endif
+
" teq %H0, #0\n"
-" bmi 2f\n"
+" bmi 4f\n"
" strexd %1, %0, %H0, [%3]\n"
" teq %1, #0\n"
" bne 1b\n"
-"2:"
+"4:\n"
+
+#ifdef CONFIG_PAX_REFCOUNT
+ _ASM_EXTABLE(2b, 4b)
+#endif
+
: "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
: "r" (&v->counter)
: "cc");
diff --git a/arch/arm/include/asm/atomic.h.rej b/arch/arm/include/asm/atomic.h.rej
deleted file mode 100644
index 635cf3d..0000000
--- a/arch/arm/include/asm/atomic.h.rej
+++ /dev/null
@@ -1,321 +0,0 @@
-diff a/arch/arm/include/asm/atomic.h b/arch/arm/include/asm/atomic.h (rejected hunks)
-@@ -60,6 +107,42 @@ static inline int atomic_add_return(int i, atomic_t *v)
- smp_mb();
-
- __asm__ __volatile__("@ atomic_add_return\n"
-+"1: ldrex %1, [%3]\n"
-+" adds %0, %1, %4\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+" bvc 3f\n"
-+" mov %0, %1\n"
-+"2: bkpt 0xf103\n"
-+"3:\n"
-+#endif
-+
-+" strex %1, %0, [%3]\n"
-+" teq %1, #0\n"
-+" bne 1b"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+"\n4:\n"
-+ _ASM_EXTABLE(2b, 4b)
-+#endif
-+
-+ : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
-+ : "r" (&v->counter), "Ir" (i)
-+ : "cc");
-+
-+ smp_mb();
-+
-+ return result;
-+}
-+
-+static inline int atomic_add_return_unchecked(int i, atomic_unchecked_t *v)
-+{
-+ unsigned long tmp;
-+ int result;
-+
-+ smp_mb();
-+
-+ __asm__ __volatile__("@ atomic_add_return_unchecked\n"
- "1: ldrex %0, [%3]\n"
- " add %0, %0, %4\n"
- " strex %1, %0, [%3]\n"
-@@ -98,11 +210,25 @@ static inline int atomic_sub_return(int i, atomic_t *v)
- smp_mb();
-
- __asm__ __volatile__("@ atomic_sub_return\n"
--"1: ldrex %0, [%3]\n"
--" sub %0, %0, %4\n"
-+"1: ldrex %1, [%3]\n"
-+" subs %0, %1, %4\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+" bvc 3f\n"
-+" mov %0, %1\n"
-+"2: bkpt 0xf103\n"
-+"3:\n"
-+#endif
-+
- " strex %1, %0, [%3]\n"
- " teq %1, #0\n"
- " bne 1b"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+"\n4:\n"
-+ _ASM_EXTABLE(2b, 4b)
-+#endif
-+
- : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
- : "r" (&v->counter), "Ir" (i)
- : "cc");
-@@ -134,6 +260,28 @@ static inline int atomic_cmpxchg(atomic_t *ptr, int old, int new)
- return oldval;
- }
-
-+static inline int atomic_cmpxchg_unchecked(atomic_unchecked_t *ptr, int old, int new)
-+{
-+ unsigned long oldval, res;
-+
-+ smp_mb();
-+
-+ do {
-+ __asm__ __volatile__("@ atomic_cmpxchg_unchecked\n"
-+ "ldrex %1, [%3]\n"
-+ "mov %0, #0\n"
-+ "teq %1, %4\n"
-+ "strexeq %0, %5, [%3]\n"
-+ : "=&r" (res), "=&r" (oldval), "+Qo" (ptr->counter)
-+ : "r" (&ptr->counter), "Ir" (old), "r" (new)
-+ : "cc");
-+ } while (res);
-+
-+ smp_mb();
-+
-+ return oldval;
-+}
-+
- static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr)
- {
- unsigned long tmp, tmp2;
-@@ -197,6 +359,11 @@ static inline int atomic_cmpxchg(atomic_t *v, int old, int new)
- return ret;
- }
-
-+static inline int atomic_cmpxchg_unchecked(atomic_unchecked_t *v, int old, int new)
-+{
-+ return atomic_cmpxchg(v, old, new);
-+}
-+
- static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr)
- {
- unsigned long flags;
-@@ -209,6 +376,10 @@ static inline void atomic_clear_mask(unsigned long mask, unsigned long *addr)
- #endif /* __LINUX_ARM_ARCH__ */
-
- #define atomic_xchg(v, new) (xchg(&((v)->counter), new))
-+static inline int atomic_xchg_unchecked(atomic_unchecked_t *v, int new)
-+{
-+ return xchg(&v->counter, new);
-+}
-
- static inline int __atomic_add_unless(atomic_t *v, int a, int u)
- {
-@@ -221,11 +392,27 @@ static inline int __atomic_add_unless(atomic_t *v, int a, int u)
- }
-
- #define atomic_inc(v) atomic_add(1, v)
-+static inline void atomic_inc_unchecked(atomic_unchecked_t *v)
-+{
-+ atomic_add_unchecked(1, v);
-+}
- #define atomic_dec(v) atomic_sub(1, v)
-+static inline void atomic_dec_unchecked(atomic_unchecked_t *v)
-+{
-+ atomic_sub_unchecked(1, v);
-+}
-
- #define atomic_inc_and_test(v) (atomic_add_return(1, v) == 0)
-+static inline int atomic_inc_and_test_unchecked(atomic_unchecked_t *v)
-+{
-+ return atomic_add_return_unchecked(1, v) == 0;
-+}
- #define atomic_dec_and_test(v) (atomic_sub_return(1, v) == 0)
- #define atomic_inc_return(v) (atomic_add_return(1, v))
-+static inline int atomic_inc_return_unchecked(atomic_unchecked_t *v)
-+{
-+ return atomic_add_return_unchecked(1, v);
-+}
- #define atomic_dec_return(v) (atomic_sub_return(1, v))
- #define atomic_sub_and_test(i, v) (atomic_sub_return(i, v) == 0)
-
-@@ -241,6 +428,14 @@ typedef struct {
- u64 __aligned(8) counter;
- } atomic64_t;
-
-+#ifdef CONFIG_PAX_REFCOUNT
-+typedef struct {
-+ u64 __aligned(8) counter;
-+} atomic64_unchecked_t;
-+#else
-+typedef atomic64_t atomic64_unchecked_t;
-+#endif
-+
- #define ATOMIC64_INIT(i) { (i) }
-
- static inline u64 atomic64_read(atomic64_t *v)
-@@ -270,6 +478,20 @@ static inline void atomic64_set(atomic64_t *v, u64 i)
- : "cc");
- }
-
-+static inline void atomic64_set_unchecked(atomic64_unchecked_t *v, u64 i)
-+{
-+ u64 tmp;
-+
-+ __asm__ __volatile__("@ atomic64_set_unchecked\n"
-+"1: ldrexd %0, %H0, [%2]\n"
-+" strexd %0, %3, %H3, [%2]\n"
-+" teq %0, #0\n"
-+" bne 1b"
-+ : "=&r" (tmp), "=Qo" (v->counter)
-+ : "r" (&v->counter), "r" (i)
-+ : "cc");
-+}
-+
- static inline void atomic64_add(u64 i, atomic64_t *v)
- {
- u64 result;
-@@ -289,12 +541,49 @@ static inline void atomic64_add(u64 i, atomic64_t *v)
-
- static inline u64 atomic64_add_return(u64 i, atomic64_t *v)
- {
-+ u64 result, tmp;
-+
-+ smp_mb();
-+
-+ __asm__ __volatile__("@ atomic64_add_return\n"
-+"1: ldrexd %1, %H1, [%3]\n"
-+" adds %0, %1, %4\n"
-+" adcs %H0, %H1, %H4\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+" bvc 3f\n"
-+" mov %0, %1\n"
-+" mov %H0, %H1\n"
-+"2: bkpt 0xf103\n"
-+"3:\n"
-+#endif
-+
-+" strexd %1, %0, %H0, [%3]\n"
-+" teq %1, #0\n"
-+" bne 1b"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+"\n4:\n"
-+ _ASM_EXTABLE(2b, 4b)
-+#endif
-+
-+ : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
-+ : "r" (&v->counter), "r" (i)
-+ : "cc");
-+
-+ smp_mb();
-+
-+ return result;
-+}
-+
-+static inline u64 atomic64_add_return_unchecked(u64 i, atomic64_unchecked_t *v)
-+{
- u64 result;
- unsigned long tmp;
-
- smp_mb();
-
-- __asm__ __volatile__("@ atomic64_add_return\n"
-+ __asm__ __volatile__("@ atomic64_add_return_unchecked\n"
- "1: ldrexd %0, %H0, [%3]\n"
- " adds %0, %0, %4\n"
- " adc %H0, %H0, %H4\n"
-@@ -318,23 +607,34 @@ static inline void atomic64_sub(u64 i, atomic64_t *v)
- __asm__ __volatile__("@ atomic64_sub\n"
- "1: ldrexd %0, %H0, [%3]\n"
- " subs %0, %0, %4\n"
--" sbc %H0, %H0, %H4\n"
-+" sbcs %H0, %H0, %H4\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+" bvc 3f\n"
-+"2: bkpt 0xf103\n"
-+"3:\n"
-+#endif
-+
- " strexd %1, %0, %H0, [%3]\n"
- " teq %1, #0\n"
- " bne 1b"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+"\n4:\n"
-+ _ASM_EXTABLE(2b, 4b)
-+#endif
-+
- : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
- : "r" (&v->counter), "r" (i)
- : "cc");
- }
-
--static inline u64 atomic64_sub_return(u64 i, atomic64_t *v)
-+static inline void atomic64_sub_unchecked(u64 i, atomic64_unchecked_t *v)
- {
- u64 result;
- unsigned long tmp;
-
-- smp_mb();
--
-- __asm__ __volatile__("@ atomic64_sub_return\n"
-+ __asm__ __volatile__("@ atomic64_sub_unchecked\n"
- "1: ldrexd %0, %H0, [%3]\n"
- " subs %0, %0, %4\n"
- " sbc %H0, %H0, %H4\n"
-@@ -397,21 +754,34 @@ static inline u64 atomic64_xchg(atomic64_t *ptr, u64 new)
-
- static inline u64 atomic64_dec_if_positive(atomic64_t *v)
- {
-- u64 result;
-- unsigned long tmp;
-+ u64 result, tmp;
-
- smp_mb();
-
- __asm__ __volatile__("@ atomic64_dec_if_positive\n"
--"1: ldrexd %0, %H0, [%3]\n"
--" subs %0, %0, #1\n"
--" sbc %H0, %H0, #0\n"
-+"1: ldrexd %1, %H1, [%3]\n"
-+" subs %0, %1, #1\n"
-+" sbcs %H0, %H1, #0\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+" bvc 3f\n"
-+" mov %0, %1\n"
-+" mov %H0, %H1\n"
-+"2: bkpt 0xf103\n"
-+"3:\n"
-+#endif
-+
- " teq %H0, #0\n"
--" bmi 2f\n"
-+" bmi 4f\n"
- " strexd %1, %0, %H0, [%3]\n"
- " teq %1, #0\n"
- " bne 1b\n"
--"2:"
-+"4:\n"
-+
-+#ifdef CONFIG_PAX_REFCOUNT
-+ _ASM_EXTABLE(2b, 4b)
-+#endif
-+
- : "=&r" (result), "=&r" (tmp), "+Qo" (v->counter)
- : "r" (&v->counter)
- : "cc");
diff --git a/arch/arm/include/asm/elf.h b/arch/arm/include/asm/elf.h
index ce6e306..5c9b3a1 100644
--- a/arch/arm/include/asm/elf.h
+++ b/arch/arm/include/asm/elf.h
@@ -126,10 +126,6 @@ int dump_task_regs(struct task_struct *t, elf_gregset_t *elfregs);
extern void elf_set_personality(const struct elf32_hdr *);
#define SET_PERSONALITY(ex) elf_set_personality(&(ex))
-struct mm_struct;
-extern unsigned long arch_randomize_brk(struct mm_struct *mm);
-#define arch_randomize_brk arch_randomize_brk
-
#ifdef CONFIG_MMU
#define ARCH_HAS_SETUP_ADDITIONAL_PAGES 1
struct linux_binprm;
diff --git a/arch/arm/include/asm/elf.h.rej b/arch/arm/include/asm/elf.h.rej
deleted file mode 100644
index 732816df6..0000000
--- a/arch/arm/include/asm/elf.h.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/arm/include/asm/elf.h 2012-05-21 11:32:31.723926261 +0200
-+++ arch/arm/include/asm/elf.h 2012-05-21 12:10:08.424048829 +0200
-@@ -133,8 +140,4 @@ int dump_task_regs(struct task_struct *t
- extern void elf_set_personality(const struct elf32_hdr *);
- #define SET_PERSONALITY(ex) elf_set_personality(&(ex))
-
--struct mm_struct;
--extern unsigned long arch_randomize_brk(struct mm_struct *mm);
--#define arch_randomize_brk arch_randomize_brk
--
- #endif
diff --git a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c
index c422585..07be50c 100644
--- a/arch/arm/kernel/process.c
+++ b/arch/arm/kernel/process.c
@@ -354,6 +354,7 @@ void machine_power_off(void)
if (pm_power_off)
pm_power_off();
+ BUG();
}
/*
@@ -367,7 +368,7 @@ void machine_power_off(void)
* executing pre-reset code, and using RAM that the primary CPU's code wishes
* to use. Implementing such co-ordination would be essentially impossible.
*/
-void machine_restart(char *cmd)
+__noreturn void machine_restart(char *cmd)
{
smp_send_stop();
diff --git a/arch/arm/kernel/process.c.rej b/arch/arm/kernel/process.c.rej
deleted file mode 100644
index 0b8d034..0000000
--- a/arch/arm/kernel/process.c.rej
+++ /dev/null
@@ -1,13 +0,0 @@
-diff a/arch/arm/kernel/process.c b/arch/arm/kernel/process.c (rejected hunks)
-@@ -332,9 +331,10 @@ void machine_power_off(void)
- machine_shutdown();
- if (pm_power_off)
- pm_power_off();
-+ BUG();
- }
-
--void machine_restart(char *cmd)
-+__noreturn void machine_restart(char *cmd)
- {
- machine_shutdown();
-
diff --git a/arch/x86/boot/Makefile b/arch/x86/boot/Makefile
index 8dfb1ff..c04c68c 100644
--- a/arch/x86/boot/Makefile
+++ b/arch/x86/boot/Makefile
@@ -64,6 +64,9 @@ KBUILD_CFLAGS := $(LINUXINCLUDE) -m32 -g -Os -D_SETUP -D__KERNEL__ \
$(call cc-option, -fno-unit-at-a-time)) \
$(call cc-option, -fno-stack-protector) \
$(call cc-option, -mpreferred-stack-boundary=2)
+ifdef CONSTIFY_PLUGIN
+KBUILD_CFLAGS += $(CONSTIFY_PLUGIN) -fplugin-arg-constify_plugin-no-constify
+endif
KBUILD_AFLAGS := $(KBUILD_CFLAGS) -D__ASSEMBLY__
GCOV_PROFILE := n
diff --git a/arch/x86/boot/Makefile.rej b/arch/x86/boot/Makefile.rej
deleted file mode 100644
index f90340c..0000000
--- a/arch/x86/boot/Makefile.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/boot/Makefile 2012-05-21 11:32:56.723927619 +0200
-+++ arch/x86/boot/Makefile 2012-05-21 12:10:09.268048874 +0200
-@@ -64,6 +64,9 @@ KBUILD_CFLAGS := $(LINUXINCLUDE) -g -Os
- $(call cc-option, -fno-stack-protector) \
- $(call cc-option, -mpreferred-stack-boundary=2)
- KBUILD_CFLAGS += $(call cc-option, -m32)
-+ifdef CONSTIFY_PLUGIN
-+KBUILD_CFLAGS += $(CONSTIFY_PLUGIN) -fplugin-arg-constify_plugin-no-constify
-+endif
- KBUILD_AFLAGS := $(KBUILD_CFLAGS) -D__ASSEMBLY__
- GCOV_PROFILE := n
diff --git a/arch/x86/ia32/ia32entry.S b/arch/x86/ia32/ia32entry.S
index 6f3a5e3..3ca82b9 100644
--- a/arch/x86/ia32/ia32entry.S
+++ b/arch/x86/ia32/ia32entry.S
@@ -256,11 +256,12 @@ sysexit_from_sys_call:
1: setbe %al /* 1 if error, 0 if not */
movzbl %al,%edi /* zero-extend that into %edi */
call __audit_syscall_exit
+ GET_THREAD_INFO(%r11)
movq RAX-ARGOFFSET(%rsp),%rax /* reload syscall return value */
movl $(_TIF_ALLWORK_MASK & ~_TIF_SYSCALL_AUDIT),%edi
DISABLE_INTERRUPTS(CLBR_NONE)
TRACE_IRQS_OFF
- testl %edi,TI_flags+THREAD_INFO(%rsp,RIP-ARGOFFSET)
+ testl %edi,TI_flags(%r11)
jz \exit
CLEAR_RREGS -ARGOFFSET
jmp int_with_check
diff --git a/arch/x86/ia32/ia32entry.S.rej b/arch/x86/ia32/ia32entry.S.rej
deleted file mode 100644
index 164a807..0000000
--- a/arch/x86/ia32/ia32entry.S.rej
+++ /dev/null
@@ -1,16 +0,0 @@
---- arch/x86/ia32/ia32entry.S 2012-03-19 10:38:56.404050007 +0100
-+++ arch/x86/ia32/ia32entry.S 2012-05-21 12:10:09.300048875 +0200
-@@ -256,11 +299,12 @@ sysexit_from_sys_call:
- 1: setbe %al /* 1 if error, 0 if not */
- movzbl %al,%edi /* zero-extend that into %edi */
- call __audit_syscall_exit
-+ GET_THREAD_INFO(%r11)
- movq RAX-ARGOFFSET(%rsp),%rax /* reload syscall return value */
- movl $(_TIF_ALLWORK_MASK & ~_TIF_SYSCALL_AUDIT),%edi
- cli
- TRACE_IRQS_OFF
-- testl %edi,TI_flags+THREAD_INFO(%rsp,RIP-ARGOFFSET)
-+ testl %edi,TI_flags(%r11)
- jz \exit
- CLEAR_RREGS -ARGOFFSET
- jmp int_with_check
diff --git a/arch/x86/include/asm/fpu-internal.h b/arch/x86/include/asm/fpu-internal.h
index 1da9ad0..19caec5 100644
--- a/arch/x86/include/asm/fpu-internal.h
+++ b/arch/x86/include/asm/fpu-internal.h
@@ -281,7 +281,7 @@ static inline int restore_fpu_checking(struct task_struct *tsk)
"fnclex\n\t"
"emms\n\t"
"fildl %P[addr]" /* set F?P to defined value */
- : : [addr] "m" (tsk->thread.fpu.has_fpu));
+ : : [addr] "m" (init_tss[smp_processor_id()].x86_tss.sp0));
}
return fpu_restore_checking(&tsk->thread.fpu);
diff --git a/arch/x86/include/asm/fpu-internal.h.rej b/arch/x86/include/asm/fpu-internal.h.rej
deleted file mode 100644
index 625c8ea..0000000
--- a/arch/x86/include/asm/fpu-internal.h.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/include/asm/fpu-internal.h 2012-05-21 11:32:56.839927625 +0200
-+++ arch/x86/include/asm/fpu-internal.h 2012-05-21 12:10:09.348048879 +0200
-@@ -281,7 +291,7 @@ static inline int restore_fpu_checking(s
- "emms\n\t" /* clear stack tags */
- "fildl %P[addr]", /* set F?P to defined value */
- X86_FEATURE_FXSAVE_LEAK,
-- [addr] "m" (tsk->thread.fpu.has_fpu));
-+ [addr] "m" (init_tss[smp_processor_id()].x86_tss.sp0));
-
- return fpu_restore_checking(&tsk->thread.fpu);
- }
diff --git a/arch/x86/include/asm/paravirt_types.h b/arch/x86/include/asm/paravirt_types.h
index 8428be1..53d3344 100644
--- a/arch/x86/include/asm/paravirt_types.h
+++ b/arch/x86/include/asm/paravirt_types.h
@@ -84,7 +84,7 @@ struct pv_init_ops {
*/
unsigned (*patch)(u8 type, u16 clobber, void *insnbuf,
unsigned long addr, unsigned len);
-};
+} __no_const;
struct pv_lazy_ops {
@@ -92,13 +92,13 @@ struct pv_lazy_ops {
void (*enter)(void);
void (*leave)(void);
void (*flush)(void);
-};
+} __no_const;
struct pv_time_ops {
unsigned long long (*sched_clock)(void);
unsigned long long (*steal_clock)(int cpu);
unsigned long (*get_tsc_khz)(void);
-};
+} __no_const;
struct pv_cpu_ops {
/* hooks for various privileged instructions */
diff --git a/arch/x86/include/asm/paravirt_types.h.rej b/arch/x86/include/asm/paravirt_types.h.rej
deleted file mode 100644
index 72d0834..0000000
--- a/arch/x86/include/asm/paravirt_types.h.rej
+++ /dev/null
@@ -1,26 +0,0 @@
---- arch/x86/include/asm/paravirt_types.h 2011-10-24 12:48:26.123091780 +0200
-+++ arch/x86/include/asm/paravirt_types.h 2012-05-21 12:10:09.376048880 +0200
-@@ -84,20 +84,20 @@ struct pv_init_ops {
- */
- unsigned (*patch)(u8 type, u16 clobber, void *insnbuf,
- unsigned long addr, unsigned len);
--};
-+} __no_const;
-
-
- struct pv_lazy_ops {
- /* Set deferred update mode, used for batching operations. */
- void (*enter)(void);
- void (*leave)(void);
--};
-+} __no_const;
-
- struct pv_time_ops {
- unsigned long long (*sched_clock)(void);
- unsigned long long (*steal_clock)(int cpu);
- unsigned long (*get_tsc_khz)(void);
--};
-+} __no_const;
-
- struct pv_cpu_ops {
- /* hooks for various privileged instructions */
diff --git a/arch/x86/include/asm/pgtable_64_types.h b/arch/x86/include/asm/pgtable_64_types.h
index 51817fa..8c2c4e4 100644
--- a/arch/x86/include/asm/pgtable_64_types.h
+++ b/arch/x86/include/asm/pgtable_64_types.h
@@ -61,5 +61,10 @@ typedef struct { pteval_t pte; } pte_t;
#define MODULES_LEN (MODULES_END - MODULES_VADDR)
#define ESPFIX_PGD_ENTRY _AC(-2, UL)
#define ESPFIX_BASE_ADDR (ESPFIX_PGD_ENTRY << PGDIR_SHIFT)
+#define MODULES_EXEC_VADDR MODULES_VADDR
+#define MODULES_EXEC_END MODULES_END
+
+#define ktla_ktva(addr) (addr)
+#define ktva_ktla(addr) (addr)
#endif /* _ASM_X86_PGTABLE_64_DEFS_H */
diff --git a/arch/x86/include/asm/pgtable_64_types.h.rej b/arch/x86/include/asm/pgtable_64_types.h.rej
deleted file mode 100644
index 3bb8f29..0000000
--- a/arch/x86/include/asm/pgtable_64_types.h.rej
+++ /dev/null
@@ -1,13 +0,0 @@
---- arch/x86/include/asm/pgtable_64_types.h 2011-07-22 04:17:23.000000000 +0200
-+++ arch/x86/include/asm/pgtable_64_types.h 2012-05-21 12:10:09.388048880 +0200
-@@ -59,5 +59,10 @@ typedef struct { pteval_t pte; } pte_t;
- #define MODULES_VADDR _AC(0xffffffffa0000000, UL)
- #define MODULES_END _AC(0xffffffffff000000, UL)
- #define MODULES_LEN (MODULES_END - MODULES_VADDR)
-+#define MODULES_EXEC_VADDR MODULES_VADDR
-+#define MODULES_EXEC_END MODULES_END
-+
-+#define ktla_ktva(addr) (addr)
-+#define ktva_ktla(addr) (addr)
-
- #endif /* _ASM_X86_PGTABLE_64_DEFS_H */
diff --git a/arch/x86/kernel/entry_32.S b/arch/x86/kernel/entry_32.S
index 80cdf03..4b7eecc 100644
--- a/arch/x86/kernel/entry_32.S
+++ b/arch/x86/kernel/entry_32.S
@@ -878,25 +878,29 @@ syscall_exit_work:
movl %esp, %eax
call syscall_trace_leave
jmp resume_userspace
-END(syscall_exit_work)
+ENDPROC(syscall_exit_work)
CFI_ENDPROC
RING0_INT_FRAME # can't unwind into user space anyway
syscall_fault:
+#ifdef CONFIG_PAX_MEMORY_UDEREF
+ push %ss
+ pop %ds
+#endif
GET_THREAD_INFO(%ebp)
movl $-EFAULT,PT_EAX(%esp)
jmp resume_userspace
-END(syscall_fault)
+ENDPROC(syscall_fault)
syscall_badsys:
movl $-ENOSYS,%eax
jmp syscall_after_call
-END(syscall_badsys)
+ENDPROC(syscall_badsys)
sysenter_badsys:
movl $-ENOSYS,%eax
jmp sysenter_after_call
-END(syscall_badsys)
+ENDPROC(syscall_badsys) #This might not belong
CFI_ENDPROC
/*
* End of kprobes section
@@ -1639,13 +1643,16 @@ nmi_espfix_stack:
FIXUP_ESPFIX_STACK # %eax == %esp
xorl %edx,%edx # zero error code
call do_nmi
+
+ pax_exit_kernel
+
RESTORE_REGS
lss 12+4(%esp), %esp # back to espfix stack
CFI_ADJUST_CFA_OFFSET -24
jmp irq_return
#endif
CFI_ENDPROC
-END(nmi)
+ENDPROC(nmi)
ENTRY(int3)
RING0_INT_FRAME
diff --git a/arch/x86/kernel/entry_32.S.rej b/arch/x86/kernel/entry_32.S.rej
deleted file mode 100644
index 39bbe03..0000000
--- a/arch/x86/kernel/entry_32.S.rej
+++ /dev/null
@@ -1,47 +0,0 @@
---- arch/x86/kernel/entry_32.S 2012-05-21 11:32:57.475927660 +0200
-+++ arch/x86/kernel/entry_32.S 2012-05-21 12:10:09.520048888 +0200
-@@ -877,20 +1083,24 @@ syscall_exit_work:
- movl %esp, %eax
- call syscall_trace_leave
- jmp resume_userspace
--END(syscall_exit_work)
-+ENDPROC(syscall_exit_work)
- CFI_ENDPROC
-
- RING0_INT_FRAME # can't unwind into user space anyway
- syscall_fault:
-+#ifdef CONFIG_PAX_MEMORY_UDEREF
-+ push %ss
-+ pop %ds
-+#endif
- GET_THREAD_INFO(%ebp)
- movl $-EFAULT,PT_EAX(%esp)
- jmp resume_userspace
--END(syscall_fault)
-+ENDPROC(syscall_fault)
-
- syscall_badsys:
- movl $-ENOSYS,PT_EAX(%esp)
- jmp resume_userspace
--END(syscall_badsys)
-+ENDPROC(syscall_badsys)
- CFI_ENDPROC
- /*
- * End of kprobes section
-@@ -1625,12 +1878,15 @@ nmi_espfix_stack:
- FIXUP_ESPFIX_STACK # %eax == %esp
- xorl %edx,%edx # zero error code
- call do_nmi
-+
-+ pax_exit_kernel
-+
- RESTORE_REGS
- lss 12+4(%esp), %esp # back to espfix stack
- CFI_ADJUST_CFA_OFFSET -24
- jmp irq_return
- CFI_ENDPROC
--END(nmi)
-+ENDPROC(nmi)
-
- ENTRY(int3)
- RING0_INT_FRAME
diff --git a/arch/x86/kernel/entry_64.S b/arch/x86/kernel/entry_64.S
index d5e04292..3781f9d 100644
--- a/arch/x86/kernel/entry_64.S
+++ b/arch/x86/kernel/entry_64.S
@@ -1310,7 +1310,7 @@ ENTRY(retint_kernel)
jmp exit_intr
#endif
CFI_ENDPROC
-END(common_interrupt)
+ENDPROC(common_interrupt)
/*
* End of kprobes section
diff --git a/arch/x86/kernel/entry_64.S.rej b/arch/x86/kernel/entry_64.S.rej
deleted file mode 100644
index 9d787a754..0000000
--- a/arch/x86/kernel/entry_64.S.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/kernel/entry_64.S 2012-05-21 11:32:57.479927660 +0200
-+++ arch/x86/kernel/entry_64.S 2012-05-21 12:10:09.524048888 +0200
-@@ -1293,7 +1607,7 @@ ENTRY(retint_kernel)
- #endif
-
- CFI_ENDPROC
--END(common_interrupt)
-+ENDPROC(common_interrupt)
- /*
- * End of kprobes section
- */
diff --git a/arch/x86/kernel/irq.c b/arch/x86/kernel/irq.c
index 145b03af..3e707a2 100644
--- a/arch/x86/kernel/irq.c
+++ b/arch/x86/kernel/irq.c
@@ -164,7 +164,7 @@ u64 arch_irq_stat_cpu(unsigned int cpu)
u64 arch_irq_stat(void)
{
- u64 sum = atomic_read(&irq_err_count);
+ u64 sum = atomic_read_unchecked(&irq_err_count);
return sum;
}
diff --git a/arch/x86/kernel/irq.c.rej b/arch/x86/kernel/irq.c.rej
deleted file mode 100644
index a8779b5..0000000
--- a/arch/x86/kernel/irq.c.rej
+++ /dev/null
@@ -1,15 +0,0 @@
---- arch/x86/kernel/irq.c 2012-05-21 11:32:57.491927661 +0200
-+++ arch/x86/kernel/irq.c 2012-05-21 12:10:09.552048890 +0200
-@@ -164,10 +164,10 @@ u64 arch_irq_stat_cpu(unsigned int cpu)
-
- u64 arch_irq_stat(void)
- {
-- u64 sum = atomic_read(&irq_err_count);
-+ u64 sum = atomic_read_unchecked(&irq_err_count);
-
- #ifdef CONFIG_X86_IO_APIC
-- sum += atomic_read(&irq_mis_count);
-+ sum += atomic_read_unchecked(&irq_mis_count);
- #endif
- return sum;
- }
diff --git a/arch/x86/kernel/relocate_kernel_64.S b/arch/x86/kernel/relocate_kernel_64.S
index b5a911a..bed145d7 100644
--- a/arch/x86/kernel/relocate_kernel_64.S
+++ b/arch/x86/kernel/relocate_kernel_64.S
@@ -168,6 +168,7 @@ identity_mapped:
xorq %r14, %r14
xorq %r15, %r15
+ pax_force_retaddr 0, 1
ret
1:
diff --git a/arch/x86/kernel/relocate_kernel_64.S.rej b/arch/x86/kernel/relocate_kernel_64.S.rej
deleted file mode 100644
index 2ff6a6df..0000000
--- a/arch/x86/kernel/relocate_kernel_64.S.rej
+++ /dev/null
@@ -1,18 +0,0 @@
---- arch/x86/kernel/relocate_kernel_64.S 2011-10-24 12:48:26.271091772 +0200
-+++ arch/x86/kernel/relocate_kernel_64.S 2012-05-21 12:10:09.608048893 +0200
-@@ -161,13 +162,14 @@ identity_mapped:
- xorq %rbp, %rbp
- xorq %r8, %r8
- xorq %r9, %r9
-- xorq %r10, %r9
-+ xorq %r10, %r10
- xorq %r11, %r11
- xorq %r12, %r12
- xorq %r13, %r13
- xorq %r14, %r14
- xorq %r15, %r15
-
-+ pax_force_retaddr 0, 1
- ret
-
- 1:
diff --git a/arch/x86/kernel/setup.c b/arch/x86/kernel/setup.c
index e0723df..95fa25a 100644
--- a/arch/x86/kernel/setup.c
+++ b/arch/x86/kernel/setup.c
@@ -717,7 +717,7 @@ static void __init trim_bios_range(void)
* area (640->1Mb) as ram even though it is not.
* take them out.
*/
- e820_remove_range(BIOS_BEGIN, BIOS_END - BIOS_BEGIN, E820_RAM, 1);
+ e820_remove_range(ISA_START_ADDRESS, ISA_END_ADDRESS - ISA_START_ADDRESS, E820_RAM, 1);
sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map);
}
diff --git a/arch/x86/kernel/setup.c.rej b/arch/x86/kernel/setup.c.rej
deleted file mode 100644
index 27c0bc0..0000000
--- a/arch/x86/kernel/setup.c.rej
+++ /dev/null
@@ -1,10 +0,0 @@
---- arch/x86/kernel/setup.c 2012-05-21 11:32:57.635927669 +0200
-+++ arch/x86/kernel/setup.c 2012-05-21 12:10:09.608048893 +0200
-@@ -639,7 +639,7 @@ static void __init trim_bios_range(void)
- * area (640->1Mb) as ram even though it is not.
- * take them out.
- */
-- e820_remove_range(BIOS_BEGIN, BIOS_END - BIOS_BEGIN, E820_RAM, 1);
-+ e820_remove_range(ISA_START_ADDRESS, ISA_END_ADDRESS - ISA_START_ADDRESS, E820_RAM, 1);
- sanitize_e820_map(e820.map, ARRAY_SIZE(e820.map), &e820.nr_map);
- }
diff --git a/arch/x86/kernel/sys_x86_64.c.rej b/arch/x86/kernel/sys_x86_64.c.rej
deleted file mode 100644
index d74c3f9..0000000
--- a/arch/x86/kernel/sys_x86_64.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/kernel/sys_x86_64.c 2012-05-21 11:32:57.659927670 +0200
-+++ arch/x86/kernel/sys_x86_64.c 2012-05-21 12:10:09.624048894 +0200
-@@ -115,7 +115,7 @@ static void find_start_end(unsigned long
- *begin = new_begin;
- }
- } else {
-- *begin = TASK_UNMAPPED_BASE;
-+ *begin = mm->mmap_base;
- *end = TASK_SIZE;
- }
- }
diff --git a/arch/x86/mm/fault.c b/arch/x86/mm/fault.c
index e16e973..2d0f632 100644
--- a/arch/x86/mm/fault.c
+++ b/arch/x86/mm/fault.c
@@ -825,6 +825,22 @@ __bad_area_nosemaphore(struct pt_regs *regs, unsigned long error_code,
return;
}
#endif
+
+#if defined(CONFIG_PAX_PAGEEXEC) || defined(CONFIG_PAX_SEGMEXEC)
+ if (pax_is_fetch_fault(regs, error_code, address)) {
+
+#ifdef CONFIG_PAX_EMUTRAMP
+ switch (pax_handle_fetch_fault(regs)) {
+ case 2:
+ return;
+ }
+#endif
+
+ pax_report_fault(regs, (void *)regs->ip, (void *)regs->sp);
+ do_group_exit(SIGKILL);
+ }
+#endif
+
/* Kernel addresses are always protection faults: */
if (address >= TASK_SIZE)
error_code |= PF_PROT;
diff --git a/arch/x86/mm/fault.c.rej b/arch/x86/mm/fault.c.rej
deleted file mode 100644
index 51b534c..0000000
--- a/arch/x86/mm/fault.c.rej
+++ /dev/null
@@ -1,23 +0,0 @@
---- arch/x86/mm/fault.c 2012-05-21 11:32:57.831927679 +0200
-+++ arch/x86/mm/fault.c 2012-05-26 01:07:07.428801082 +0200
-@@ -824,6 +900,21 @@ __bad_area_nosemaphore(struct pt_regs *r
- }
- #endif
-
-+#if defined(CONFIG_PAX_PAGEEXEC) || defined(CONFIG_PAX_SEGMEXEC)
-+ if (pax_is_fetch_fault(regs, error_code, address)) {
-+
-+#ifdef CONFIG_PAX_EMUTRAMP
-+ switch (pax_handle_fetch_fault(regs)) {
-+ case 2:
-+ return;
-+ }
-+#endif
-+
-+ pax_report_fault(regs, (void *)regs->ip, (void *)regs->sp);
-+ do_group_exit(SIGKILL);
-+ }
-+#endif
-+
- if (unlikely(show_unhandled_signals))
- show_signal_msg(regs, error_code, address, tsk);
diff --git a/arch/x86/mm/init.c b/arch/x86/mm/init.c
index 250a08c..01bfdea 100644
--- a/arch/x86/mm/init.c
+++ b/arch/x86/mm/init.c
@@ -44,7 +44,7 @@ struct map_range {
static void __init find_early_table_space(struct map_range *mr, int nr_range)
{
int i;
- unsigned long puds = 0, pmds = 0, ptes = 0, tables;
+ unsigned long puds = 0, pmds = 0, ptes = 0, tables, start = 0x100000, good_end = end;
unsigned long start = 0, good_end;
unsigned long pgd_extra = 0;
phys_addr_t base;
diff --git a/arch/x86/mm/init.c.rej b/arch/x86/mm/init.c.rej
deleted file mode 100644
index 24e81e8..0000000
--- a/arch/x86/mm/init.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/mm/init.c 2012-05-21 11:32:57.855927681 +0200
-+++ arch/x86/mm/init.c 2012-05-21 12:10:09.756048901 +0200
-@@ -33,7 +34,7 @@ int direct_gbpages
- static void __init find_early_table_space(unsigned long end, int use_pse,
- int use_gbpages)
- {
-- unsigned long puds, pmds, ptes, tables, start = 0, good_end = end;
-+ unsigned long puds, pmds, ptes, tables, start = 0x100000, good_end = end;
- phys_addr_t base;
-
- puds = (end + PUD_SIZE - 1) >> PUD_SHIFT;
diff --git a/arch/x86/mm/ioremap.c.rej b/arch/x86/mm/ioremap.c.rej
deleted file mode 100644
index 08d957c..0000000
--- a/arch/x86/mm/ioremap.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- arch/x86/mm/ioremap.c 2011-07-22 04:17:23.000000000 +0200
-+++ arch/x86/mm/ioremap.c 2012-05-21 12:10:09.760048901 +0200
-@@ -97,7 +97,7 @@ static void __iomem *__ioremap_caller(re
- for (pfn = phys_addr >> PAGE_SHIFT; pfn <= last_pfn; pfn++) {
- int is_ram = page_is_ram(pfn);
-
-- if (is_ram && pfn_valid(pfn) && !PageReserved(pfn_to_page(pfn)))
-+ if (is_ram && pfn_valid(pfn) && (pfn >= 0x100 || !PageReserved(pfn_to_page(pfn))))
- return NULL;
- WARN_ON_ONCE(is_ram);
- }
diff --git a/arch/x86/mm/mmap.c b/arch/x86/mm/mmap.c
index f8b50a1..6153cc6 100644
--- a/arch/x86/mm/mmap.c
+++ b/arch/x86/mm/mmap.c
@@ -126,10 +126,22 @@ static unsigned long mmap_legacy_base(struct mm_struct *mm)
void arch_pick_mmap_layout(struct mm_struct *mm)
{
mm->mmap_legacy_base = mmap_legacy_base();
- mm->mmap_base = mmap_base();
+ mm->mmap_base = mmap_base(mm);
+
+#ifdef CONFIG_PAX_RANDMMAP
+ if (mm->pax_flags & MF_PAX_RANDMMAP)
+ mm->mmap_base -= mm->delta_mmap + mm->delta_stack;
+#endif
+
if (mmap_is_legacy()) {
- mm->mmap_base = mm->mmap_legacy_base;
+ mm->mmap_base = mmap_legacy_base(mm);
+
+#ifdef CONFIG_PAX_RANDMMAP
+ if (mm->pax_flags & MF_PAX_RANDMMAP)
+ mm->mmap_base += mm->delta_mmap;
+#endif
+
mm->get_unmapped_area = arch_get_unmapped_area;
mm->unmap_area = arch_unmap_area;
} else {
diff --git a/arch/x86/mm/mmap.c.rej b/arch/x86/mm/mmap.c.rej
deleted file mode 100644
index 1a9121a..0000000
--- a/arch/x86/mm/mmap.c.rej
+++ /dev/null
@@ -1,28 +0,0 @@
---- arch/x86/mm/mmap.c 2012-03-19 10:38:56.692049991 +0100
-+++ arch/x86/mm/mmap.c 2012-05-21 12:10:09.764048901 +0200
-@@ -126,11 +139,23 @@ static unsigned long mmap_legacy_base(vo
- void arch_pick_mmap_layout(struct mm_struct *mm)
- {
- if (mmap_is_legacy()) {
-- mm->mmap_base = mmap_legacy_base();
-+ mm->mmap_base = mmap_legacy_base(mm);
-+
-+#ifdef CONFIG_PAX_RANDMMAP
-+ if (mm->pax_flags & MF_PAX_RANDMMAP)
-+ mm->mmap_base += mm->delta_mmap;
-+#endif
-+
- mm->get_unmapped_area = arch_get_unmapped_area;
- mm->unmap_area = arch_unmap_area;
- } else {
-- mm->mmap_base = mmap_base();
-+ mm->mmap_base = mmap_base(mm);
-+
-+#ifdef CONFIG_PAX_RANDMMAP
-+ if (mm->pax_flags & MF_PAX_RANDMMAP)
-+ mm->mmap_base -= mm->delta_mmap + mm->delta_stack;
-+#endif
-+
- mm->get_unmapped_area = arch_get_unmapped_area_topdown;
- mm->unmap_area = arch_unmap_area_topdown;
- }
diff --git a/arch/x86/xen/xen-asm_32.S b/arch/x86/xen/xen-asm_32.S
index 7328f71..c457aa7 100644
--- a/arch/x86/xen/xen-asm_32.S
+++ b/arch/x86/xen/xen-asm_32.S
@@ -83,14 +83,14 @@ ENTRY(xen_iret)
ESP_OFFSET=4 # bytes pushed onto stack
/*
- * Store vcpu_info pointer for easy access. Do it this way to
- * avoid having to reload %fs
+ * Store vcpu_info pointer for easy access.
*/
#ifdef CONFIG_SMP
- GET_THREAD_INFO(%eax)
- movl %ss:TI_cpu(%eax), %eax
- movl %ss:__per_cpu_offset(,%eax,4), %eax
- mov %ss:xen_vcpu(%eax), %eax
+ push %fs
+ mov $(__KERNEL_PERCPU), %eax
+ mov %eax, %fs
+ mov PER_CPU_VAR(xen_vcpu), %eax
+ pop %fs
#else
movl %ss:xen_vcpu, %eax
#endif
diff --git a/arch/x86/xen/xen-asm_32.S.rej b/arch/x86/xen/xen-asm_32.S.rej
deleted file mode 100644
index b3a8af9..0000000
--- a/arch/x86/xen/xen-asm_32.S.rej
+++ /dev/null
@@ -1,23 +0,0 @@
---- arch/x86/xen/xen-asm_32.S 2011-10-24 12:48:26.419091764 +0200
-+++ arch/x86/xen/xen-asm_32.S 2012-05-21 12:10:09.824048905 +0200
-@@ -83,14 +83,14 @@ ENTRY(xen_iret)
- ESP_OFFSET=4 # bytes pushed onto stack
-
- /*
-- * Store vcpu_info pointer for easy access. Do it this way to
-- * avoid having to reload %fs
-+ * Store vcpu_info pointer for easy access.
- */
- #ifdef CONFIG_SMP
-- GET_THREAD_INFO(%eax)
-- movl TI_cpu(%eax), %eax
-- movl __per_cpu_offset(,%eax,4), %eax
-- mov xen_vcpu(%eax), %eax
-+ push %fs
-+ mov $(__KERNEL_PERCPU), %eax
-+ mov %eax, %fs
-+ mov PER_CPU_VAR(xen_vcpu), %eax
-+ pop %fs
- #else
- movl xen_vcpu, %eax
- #endif
diff --git a/drivers/base/power/wakeup.c b/drivers/base/power/wakeup.c
index d87d93e..cdfcdbc 100644
--- a/drivers/base/power/wakeup.c
+++ b/drivers/base/power/wakeup.c
@@ -516,7 +516,7 @@ static void wakeup_source_deactivate(struct wakeup_source *ws)
* Increment the counter of registered wakeup events and decrement the
* couter of wakeup events in progress simultaneously.
*/
- cec = atomic_add_return(MAX_IN_PROGRESS, &combined_event_count);
+ cec = atomic_add_return_unchecked(MAX_IN_PROGRESS, &combined_event_count);
trace_wakeup_source_deactivate(ws->name, cec);
split_counters(&cnt, &inpr);
diff --git a/drivers/base/power/wakeup.c.rej b/drivers/base/power/wakeup.c.rej
deleted file mode 100644
index f0caa9b..0000000
--- a/drivers/base/power/wakeup.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- drivers/base/power/wakeup.c 2012-05-21 11:32:59.075927747 +0200
-+++ drivers/base/power/wakeup.c 2012-05-21 12:10:09.948048911 +0200
-@@ -475,7 +475,7 @@ static void wakeup_source_deactivate(str
- * Increment the counter of registered wakeup events and decrement the
- * couter of wakeup events in progress simultaneously.
- */
-- atomic_add(MAX_IN_PROGRESS, &combined_event_count);
-+ atomic_add_unchecked(MAX_IN_PROGRESS, &combined_event_count);
- }
-
- /**
diff --git a/drivers/gpu/drm/drm_fops.c b/drivers/gpu/drm/drm_fops.c
index b09cbb5..d597f0b 100644
--- a/drivers/gpu/drm/drm_fops.c
+++ b/drivers/gpu/drm/drm_fops.c
@@ -138,8 +138,8 @@ int drm_open(struct inode *inode, struct file *filp)
retcode = drm_open_helper(inode, filp, dev);
if (!retcode) {
- atomic_inc(&dev->counts[_DRM_STAT_OPENS]);
- if (!dev->open_count++) {
+ atomic_inc_unchecked(&dev->counts[_DRM_STAT_OPENS]);
+ if (local_inc_return(&dev->open_count) == 1) {
retcode = drm_setup(dev);
if (retcode)
dev->open_count--;
diff --git a/drivers/gpu/drm/drm_fops.c.rej b/drivers/gpu/drm/drm_fops.c.rej
deleted file mode 100644
index c38ea83..0000000
--- a/drivers/gpu/drm/drm_fops.c.rej
+++ /dev/null
@@ -1,13 +0,0 @@
---- drivers/gpu/drm/drm_fops.c 2012-05-21 11:33:00.935927848 +0200
-+++ drivers/gpu/drm/drm_fops.c 2012-05-21 12:10:10.048048917 +0200
-@@ -138,8 +138,8 @@ int drm_open(struct inode *inode, struct
-
- retcode = drm_open_helper(inode, filp, dev);
- if (!retcode) {
-- atomic_inc(&dev->counts[_DRM_STAT_OPENS]);
-- if (!dev->open_count++)
-+ atomic_inc_unchecked(&dev->counts[_DRM_STAT_OPENS]);
-+ if (local_inc_return(&dev->open_count) == 1)
- retcode = drm_setup(dev);
- }
- if (!retcode) {
diff --git a/drivers/gpu/drm/i915/i915_gem_execbuffer.c b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
index de46c99..90f7e4c 100644
--- a/drivers/gpu/drm/i915/i915_gem_execbuffer.c
+++ b/drivers/gpu/drm/i915/i915_gem_execbuffer.c
@@ -954,9 +954,9 @@ i915_gem_check_execbuffer(struct drm_i915_gem_execbuffer2 *exec)
static int
validate_exec_list(struct drm_i915_gem_exec_object2 *exec,
- int count)
+ unsigned int count)
{
- int i;
+ unsigned int i;
int relocs_total = 0;
int relocs_max = INT_MAX / sizeof(struct drm_i915_gem_relocation_entry);
diff --git a/drivers/gpu/drm/i915/i915_gem_execbuffer.c.rej b/drivers/gpu/drm/i915/i915_gem_execbuffer.c.rej
deleted file mode 100644
index b147b40..0000000
--- a/drivers/gpu/drm/i915/i915_gem_execbuffer.c.rej
+++ /dev/null
@@ -1,14 +0,0 @@
---- drivers/gpu/drm/i915/i915_gem_execbuffer.c 2012-05-21 11:33:01.339927870 +0200
-+++ drivers/gpu/drm/i915/i915_gem_execbuffer.c 2012-05-21 12:10:10.076048918 +0200
-@@ -933,9 +933,9 @@ i915_gem_check_execbuffer(struct drm_i91
-
- static int
- validate_exec_list(struct drm_i915_gem_exec_object2 *exec,
-- int count)
-+ unsigned int count)
- {
-- int i;
-+ unsigned int i;
-
- for (i = 0; i < count; i++) {
- char __user *ptr = (char __user *)(uintptr_t)exec[i].relocs_ptr;
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c
index 915b222..852cbf7 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -7297,10 +7297,9 @@ static void do_intel_finish_page_flip(struct drm_device *dev,
obj = work->old_fb_obj;
- atomic_clear_mask(1 << intel_crtc->plane,
- &obj->pending_flip.counter);
-
- wake_up(&dev_priv->pending_flip_queue);
+ atomic_clear_mask_unchecked(1 << intel_crtc->plane, &obj->pending_flip);
+ if (atomic_read_unchecked(&obj->pending_flip) == 0)
+ wake_up(&dev_priv->pending_flip_queue);
schedule_work(&work->work);
trace_i915_flip_complete(intel_crtc->plane, work->pending_flip_obj);
@@ -7659,7 +7658,7 @@ static int intel_crtc_page_flip(struct drm_crtc *crtc,
return 0;
cleanup_pending:
- atomic_sub(1 << intel_crtc->plane, &work->old_fb_obj->pending_flip);
+ atomic_sub_unchecked(1 << intel_crtc->plane, &work->old_fb_obj->pending_flip);
crtc->fb = old_fb;
drm_gem_object_unreference(&work->old_fb_obj->base);
drm_gem_object_unreference(&obj->base);
diff --git a/drivers/gpu/drm/i915/intel_display.c.rej b/drivers/gpu/drm/i915/intel_display.c.rej
deleted file mode 100644
index 8b5bc41..0000000
--- a/drivers/gpu/drm/i915/intel_display.c.rej
+++ /dev/null
@@ -1,32 +0,0 @@
---- drivers/gpu/drm/i915/intel_display.c 2012-06-11 19:12:28.596366966 +0200
-+++ drivers/gpu/drm/i915/intel_display.c 2012-07-04 19:33:49.496065642 +0200
-@@ -2919,7 +2919,7 @@ static void intel_crtc_wait_for_pending_
- obj = to_intel_framebuffer(crtc->fb)->obj;
- dev_priv = crtc->dev->dev_private;
- wait_event(dev_priv->pending_flip_queue,
-- atomic_read(&obj->pending_flip) == 0);
-+ atomic_read_unchecked(&obj->pending_flip) == 0);
- }
-
- static bool intel_crtc_driving_pch(struct drm_crtc *crtc)
-@@ -7284,9 +7284,8 @@ static void do_intel_finish_page_flip(st
-
- obj = work->old_fb_obj;
-
-- atomic_clear_mask(1 << intel_crtc->plane,
-- &obj->pending_flip.counter);
-- if (atomic_read(&obj->pending_flip) == 0)
-+ atomic_clear_mask_unchecked(1 << intel_crtc->plane, &obj->pending_flip);
-+ if (atomic_read_unchecked(&obj->pending_flip) == 0)
- wake_up(&dev_priv->pending_flip_queue);
-
- schedule_work(&work->work);
-@@ -7596,7 +7595,7 @@ static int intel_crtc_page_flip(struct d
- return 0;
-
- cleanup_pending:
-- atomic_sub(1 << intel_crtc->plane, &work->old_fb_obj->pending_flip);
-+ atomic_sub_unchecked(1 << intel_crtc->plane, &work->old_fb_obj->pending_flip);
- drm_gem_object_unreference(&work->old_fb_obj->base);
- drm_gem_object_unreference(&obj->base);
- mutex_unlock(&dev->struct_mutex);
diff --git a/drivers/staging/speakup/speakup_soft.c.rej b/drivers/staging/speakup/speakup_soft.c.rej
deleted file mode 100644
index 296a85f..0000000
--- a/drivers/staging/speakup/speakup_soft.c.rej
+++ /dev/null
@@ -1,15 +0,0 @@
---- drivers/staging/speakup/speakup_soft.c 2011-10-24 12:48:37.219091188 +0200
-+++ drivers/staging/speakup/speakup_soft.c 2012-05-21 12:10:10.868048961 +0200
-@@ -241,11 +241,11 @@ static ssize_t softsynth_read(struct fil
- break;
- } else if (!initialized) {
- if (*init) {
-- ch = *init;
- init++;
- } else {
- initialized = 1;
- }
-+ ch = *init;
- } else {
- ch = synth_buffer_getc();
- }
diff --git a/fs/binfmt_elf.c b/fs/binfmt_elf.c
index 46af0db..5432fe8 100644
--- a/fs/binfmt_elf.c
+++ b/fs/binfmt_elf.c
@@ -1210,6 +1210,20 @@ static int load_elf_binary(struct linux_binprm *bprm, struct pt_regs *regs)
#else
load_bias = ELF_PAGESTART(ELF_ET_DYN_BASE - vaddr);
#endif
+
+#ifdef CONFIG_PAX_RANDMMAP
+ /* PaX: randomize base address at the default exe base if requested */
+ if ((current->mm->pax_flags & MF_PAX_RANDMMAP) && elf_interpreter) {
+#ifdef CONFIG_SPARC64
+ load_bias = (pax_get_random_long() & ((1UL << PAX_DELTA_MMAP_LEN) - 1)) << (PAGE_SHIFT+1);
+#else
+ load_bias = (pax_get_random_long() & ((1UL << PAX_DELTA_MMAP_LEN) - 1)) << PAGE_SHIFT;
+#endif
+ load_bias = ELF_PAGESTART(PAX_ELF_ET_DYN_BASE - vaddr + load_bias);
+ elf_flags |= MAP_FIXED;
+ }
+#endif
+
total_size = total_mapping_size(elf_phdata,
loc->elf_ex.e_phnum);
if (!total_size) {
diff --git a/fs/binfmt_elf.c.rej b/fs/binfmt_elf.c.rej
deleted file mode 100644
index f60f6971..0000000
--- a/fs/binfmt_elf.c.rej
+++ /dev/null
@@ -1,22 +0,0 @@
-diff a/fs/binfmt_elf.c b/fs/binfmt_elf.c (rejected hunks)
-@@ -805,6 +1209,20 @@ static int load_elf_binary(struct linux_binprm *bprm, struct pt_regs *regs)
- #else
- load_bias = ELF_PAGESTART(ELF_ET_DYN_BASE - vaddr);
- #endif
-+
-+#ifdef CONFIG_PAX_RANDMMAP
-+ /* PaX: randomize base address at the default exe base if requested */
-+ if ((current->mm->pax_flags & MF_PAX_RANDMMAP) && elf_interpreter) {
-+#ifdef CONFIG_SPARC64
-+ load_bias = (pax_get_random_long() & ((1UL << PAX_DELTA_MMAP_LEN) - 1)) << (PAGE_SHIFT+1);
-+#else
-+ load_bias = (pax_get_random_long() & ((1UL << PAX_DELTA_MMAP_LEN) - 1)) << PAGE_SHIFT;
-+#endif
-+ load_bias = ELF_PAGESTART(PAX_ELF_ET_DYN_BASE - vaddr + load_bias);
-+ elf_flags |= MAP_FIXED;
-+ }
-+#endif
-+
- }
-
- error = elf_map(bprm->file, load_bias + vaddr, elf_ppnt,
diff --git a/fs/compat_ioctl.c b/fs/compat_ioctl.c
index bf3be45..ef639f8 100644
--- a/fs/compat_ioctl.c
+++ b/fs/compat_ioctl.c
@@ -623,7 +623,7 @@ static int serial_struct_ioctl(unsigned fd, unsigned cmd,
return -EFAULT;
if (__get_user(udata, &ss32->iomem_base))
return -EFAULT;
- ss.iomem_base = compat_ptr(udata);
+ ss.iomem_base = (unsigned char __force_kernel *)compat_ptr(udata);
if (__get_user(ss.iomem_reg_shift, &ss32->iomem_reg_shift) ||
__get_user(ss.port_high, &ss32->port_high))
return -EFAULT;
@@ -798,7 +798,7 @@ static int compat_ioctl_preallocate(struct file *file,
copy_in_user(&p->l_len, &p32->l_len, sizeof(s64)) ||
copy_in_user(&p->l_sysid, &p32->l_sysid, sizeof(s32)) ||
copy_in_user(&p->l_pid, &p32->l_pid, sizeof(u32)) ||
- copy_in_user(&p->l_pad, &p32->l_pad, 4*sizeof(u32)))
+ copy_in_user(p->l_pad, &p32->l_pad, 4*sizeof(u32)))
return -EFAULT;
return ioctl_preallocate(file, p);
@@ -1613,8 +1613,8 @@ asmlinkage long compat_sys_ioctl(unsigned int fd, unsigned int cmd,
static int __init init_sys32_ioctl_cmp(const void *p, const void *q)
{
unsigned int a, b;
- a = *(unsigned int *)p;
- b = *(unsigned int *)q;
+ a = *(const unsigned int *)p;
+ b = *(const unsigned int *)q;
if (a > b)
return 1;
if (a < b)
diff --git a/fs/compat_ioctl.c.rej b/fs/compat_ioctl.c.rej
deleted file mode 100644
index 6ac40a2..0000000
--- a/fs/compat_ioctl.c.rej
+++ /dev/null
@@ -1,40 +0,0 @@
---- fs/compat_ioctl.c 2012-05-21 11:33:34.635929678 +0200
-+++ fs/compat_ioctl.c 2012-05-21 12:10:11.084048973 +0200
-@@ -210,6 +210,8 @@ static int do_video_set_spu_palette(unsi
-
- err = get_user(palp, &up->palette);
- err |= get_user(length, &up->length);
-+ if (err)
-+ return -EFAULT;
-
- up_native = compat_alloc_user_space(sizeof(struct video_spu_palette));
- err = put_user(compat_ptr(palp), &up_native->palette);
-@@ -621,7 +623,7 @@ static int serial_struct_ioctl(unsigned
- return -EFAULT;
- if (__get_user(udata, &ss32->iomem_base))
- return -EFAULT;
-- ss.iomem_base = compat_ptr(udata);
-+ ss.iomem_base = (unsigned char __force_kernel *)compat_ptr(udata);
- if (__get_user(ss.iomem_reg_shift, &ss32->iomem_reg_shift) ||
- __get_user(ss.port_high, &ss32->port_high))
- return -EFAULT;
-@@ -796,7 +798,7 @@ static int compat_ioctl_preallocate(stru
- copy_in_user(&p->l_len, &p32->l_len, sizeof(s64)) ||
- copy_in_user(&p->l_sysid, &p32->l_sysid, sizeof(s32)) ||
- copy_in_user(&p->l_pid, &p32->l_pid, sizeof(u32)) ||
-- copy_in_user(&p->l_pad, &p32->l_pad, 4*sizeof(u32)))
-+ copy_in_user(p->l_pad, &p32->l_pad, 4*sizeof(u32)))
- return -EFAULT;
-
- return ioctl_preallocate(file, p);
-@@ -1610,8 +1612,8 @@ asmlinkage long compat_sys_ioctl(unsigne
- static int __init init_sys32_ioctl_cmp(const void *p, const void *q)
- {
- unsigned int a, b;
-- a = *(unsigned int *)p;
-- b = *(unsigned int *)q;
-+ a = *(const unsigned int *)p;
-+ b = *(const unsigned int *)q;
- if (a > b)
- return 1;
- if (a < b)
diff --git a/fs/libfs.c b/fs/libfs.c
index 83cee1c..abc00d3 100644
--- a/fs/libfs.c
+++ b/fs/libfs.c
@@ -165,6 +165,9 @@ int dcache_readdir(struct file * filp, void * dirent, filldir_t filldir)
for (p=q->next; p != &dentry->d_subdirs; p=p->next) {
struct dentry *next;
+ char d_name[sizeof(next->d_iname)];
+ const unsigned char *name;
+
next = list_entry(p, struct dentry, d_u.d_child);
spin_lock_nested(&next->d_lock, DENTRY_D_LOCK_NESTED);
if (!simple_positive(next)) {
diff --git a/fs/libfs.c.rej b/fs/libfs.c.rej
deleted file mode 100644
index 8470aa1..0000000
--- a/fs/libfs.c.rej
+++ /dev/null
@@ -1,12 +0,0 @@
---- fs/libfs.c 2012-05-21 11:33:35.695929736 +0200
-+++ fs/libfs.c 2012-05-21 12:10:11.168048978 +0200
-@@ -165,6 +165,9 @@ int dcache_readdir(struct file * filp, v
-
- for (p=q->next; p != &dentry->d_subdirs; p=p->next) {
- struct dentry *next;
-+ char d_name[sizeof(next->d_iname)];
-+ const unsigned char *name;
-+
- next = list_entry(p, struct dentry, d_u.d_child);
- spin_lock_nested(&next->d_lock, DENTRY_D_LOCK_NESTED);
- if (!simple_positive(next)) {
diff --git a/fs/nfs/inode.c.rej b/fs/nfs/inode.c.rej
deleted file mode 100644
index 3928e5c..0000000
--- a/fs/nfs/inode.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- fs/nfs/inode.c 2012-05-21 11:33:35.907929747 +0200
-+++ fs/nfs/inode.c 2012-05-21 12:10:11.184048978 +0200
-@@ -152,7 +152,7 @@ static void nfs_zap_caches_locked(struct
- nfsi->attrtimeo = NFS_MINATTRTIMEO(inode);
- nfsi->attrtimeo_timestamp = jiffies;
-
-- memset(NFS_COOKIEVERF(inode), 0, sizeof(NFS_COOKIEVERF(inode)));
-+ memset(NFS_COOKIEVERF(inode), 0, sizeof(NFS_I(inode)->cookieverf));
- if (S_ISREG(mode) || S_ISDIR(mode) || S_ISLNK(mode))
- nfsi->cache_validity |= NFS_INO_INVALID_ATTR|NFS_INO_INVALID_DATA|NFS_INO_INVALID_ACCESS|NFS_INO_INVALID_ACL|NFS_INO_REVAL_PAGECACHE;
- else
diff --git a/fs/proc/nommu.c b/fs/proc/nommu.c
index 501ae3a..c7a5528 100644
--- a/fs/proc/nommu.c
+++ b/fs/proc/nommu.c
@@ -64,7 +64,7 @@ static int nommu_region_show(struct seq_file *m, struct vm_region *region)
if (file) {
seq_pad(m, ' ');
- seq_path(m, &file->f_path, "");
+ seq_path(m, &file->f_path, "\n\\");
}
seq_putc(m, '\n');
diff --git a/fs/proc/nommu.c.rej b/fs/proc/nommu.c.rej
deleted file mode 100644
index 186828f..0000000
--- a/fs/proc/nommu.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- fs/proc/nommu.c 2011-07-22 04:17:23.000000000 +0200
-+++ fs/proc/nommu.c 2012-05-21 12:10:11.232048981 +0200
-@@ -66,7 +66,7 @@ static int nommu_region_show(struct seq_
- if (len < 1)
- len = 1;
- seq_printf(m, "%*c", len, ' ');
-- seq_path(m, &file->f_path, "");
-+ seq_path(m, &file->f_path, "\n\\");
- }
-
- seq_putc(m, '\n');
diff --git a/fs/proc/task_mmu.c b/fs/proc/task_mmu.c
index d44f967..6f08b99 100644
--- a/fs/proc/task_mmu.c
+++ b/fs/proc/task_mmu.c
@@ -283,21 +283,25 @@ show_map_vma(struct seq_file *m, struct vm_area_struct *vma, int is_pid)
pgoff = ((loff_t)vma->vm_pgoff) << PAGE_SHIFT;
}
- /* We don't show the stack guard page in /proc/maps */
+
start = vma->vm_start;
- if (stack_guard_page_start(vma, start))
- start += PAGE_SIZE;
end = vma->vm_end;
- if (stack_guard_page_end(vma, end))
- end -= PAGE_SIZE;
seq_setwidth(m, 25 + sizeof(void *) * 6 - 1);
seq_printf(m, "%08lx-%08lx %c%c%c%c %08llx %02x:%02x %lu ",
start,
end,
+
+#if 0
+ flags & VM_MAYREAD ? flags & VM_READ ? 'R' : '+' : flags & VM_READ ? 'r' : '-',
+ flags & VM_MAYWRITE ? flags & VM_WRITE ? 'W' : '+' : flags & VM_WRITE ? 'w' : '-',
+ flags & VM_MAYEXEC ? flags & VM_EXEC ? 'X' : '+' : flags & VM_EXEC ? 'x' : '-',
+#else
flags & VM_READ ? 'r' : '-',
flags & VM_WRITE ? 'w' : '-',
flags & VM_EXEC ? 'x' : '-',
+#endif
+
flags & VM_MAYSHARE ? 's' : 'p',
pgoff,
MAJOR(dev), MINOR(dev), ino);
@@ -308,7 +312,7 @@ show_map_vma(struct seq_file *m, struct vm_area_struct *vma, int is_pid)
*/
if (file) {
seq_pad(m, ' ');
- seq_path(m, &file->f_path, "\n");
+ seq_path(m, &file->f_path, "\n\\");
goto done;
}
diff --git a/fs/proc/task_mmu.c.rej b/fs/proc/task_mmu.c.rej
deleted file mode 100644
index 0a6886b..0000000
--- a/fs/proc/task_mmu.c.rej
+++ /dev/null
@@ -1,39 +0,0 @@
---- fs/proc/task_mmu.c 2012-06-11 19:12:31.104367105 +0200
-+++ fs/proc/task_mmu.c 2012-06-11 19:17:09.188382567 +0200
-@@ -242,20 +253,23 @@ show_map_vma(struct seq_file *m, struct
- pgoff = ((loff_t)vma->vm_pgoff) << PAGE_SHIFT;
- }
-
-- /* We don't show the stack guard page in /proc/maps */
- start = vma->vm_start;
-- if (stack_guard_page_start(vma, start))
-- start += PAGE_SIZE;
- end = vma->vm_end;
-- if (stack_guard_page_end(vma, end))
-- end -= PAGE_SIZE;
-
- seq_printf(m, "%08lx-%08lx %c%c%c%c %08llx %02x:%02x %lu %n",
- start,
- end,
-+
-+#if 0
-+ flags & VM_MAYREAD ? flags & VM_READ ? 'R' : '+' : flags & VM_READ ? 'r' : '-',
-+ flags & VM_MAYWRITE ? flags & VM_WRITE ? 'W' : '+' : flags & VM_WRITE ? 'w' : '-',
-+ flags & VM_MAYEXEC ? flags & VM_EXEC ? 'X' : '+' : flags & VM_EXEC ? 'x' : '-',
-+#else
- flags & VM_READ ? 'r' : '-',
- flags & VM_WRITE ? 'w' : '-',
- flags & VM_EXEC ? 'x' : '-',
-+#endif
-+
- flags & VM_MAYSHARE ? 's' : 'p',
- pgoff,
- MAJOR(dev), MINOR(dev), ino, &len);
-@@ -266,7 +280,7 @@ show_map_vma(struct seq_file *m, struct
- */
- if (file) {
- pad_len_spaces(m, len);
-- seq_path(m, &file->f_path, "\n");
-+ seq_path(m, &file->f_path, "\n\\");
- goto done;
- }
diff --git a/fs/proc/task_nommu.c b/fs/proc/task_nommu.c
index 473f497..52cc71a 100644
--- a/fs/proc/task_nommu.c
+++ b/fs/proc/task_nommu.c
@@ -161,7 +161,7 @@ static int nommu_vma_show(struct seq_file *m, struct vm_area_struct *vma,
if (file) {
seq_pad(m, ' ');
- seq_path(m, &file->f_path, "");
+ seq_path(m, &file->f_path, "\n\\");
} else if (mm) {
pid_t tid = vm_is_stack(priv->task, vma, is_pid);
diff --git a/fs/proc/task_nommu.c.rej b/fs/proc/task_nommu.c.rej
deleted file mode 100644
index 4757380..0000000
--- a/fs/proc/task_nommu.c.rej
+++ /dev/null
@@ -1,10 +0,0 @@
---- fs/proc/task_nommu.c 2012-05-21 11:33:36.239929765 +0200
-+++ fs/proc/task_nommu.c 2012-05-21 12:10:11.236048981 +0200
-@@ -168,7 +168,7 @@ static int nommu_vma_show(struct seq_fil
-
- if (file) {
- pad_len_spaces(m, len);
-- seq_path(m, &file->f_path, "");
-+ seq_path(m, &file->f_path, "\n\\");
- } else if (mm) {
- pid_t tid = vm_is_stack(priv->task, vma, is_pid);
diff --git a/include/linux/efi.h b/include/linux/efi.h
index 6bf8394..9f64717 100644
--- a/include/linux/efi.h
+++ b/include/linux/efi.h
@@ -665,7 +665,7 @@ struct efivar_operations {
efi_get_next_variable_t *get_next_variable;
efi_set_variable_t *set_variable;
efi_query_variable_store_t *query_variable_store;
-};
+} __no_const;
struct efivars {
/*
diff --git a/include/linux/efi.h.rej b/include/linux/efi.h.rej
deleted file mode 100644
index e4f1b70..0000000
--- a/include/linux/efi.h.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- include/linux/efi.h 2012-05-21 11:33:37.395929829 +0200
-+++ include/linux/efi.h 2012-05-21 12:10:11.384048989 +0200
-@@ -635,7 +635,7 @@ struct efivar_operations {
- efi_get_variable_t *get_variable;
- efi_get_next_variable_t *get_next_variable;
- efi_set_variable_t *set_variable;
--};
-+} __no_const;
-
- struct efivars {
- /*
diff --git a/include/linux/gfp.h.rej b/include/linux/gfp.h.rej
deleted file mode 100644
index 46a5762..0000000
--- a/include/linux/gfp.h.rej
+++ /dev/null
@@ -1,10 +0,0 @@
-diff a/include/linux/gfp.h b/include/linux/gfp.h (rejected hunks)
-@@ -97,7 +104,7 @@ struct vm_area_struct;
- */
- #define __GFP_NOTRACK_FALSE_POSITIVE (__GFP_NOTRACK)
-
--#define __GFP_BITS_SHIFT 25 /* Room for N __GFP_FOO bits */
-+#define __GFP_BITS_SHIFT 26 /* Room for N __GFP_FOO bits */
- #define __GFP_BITS_MASK ((__force gfp_t)((1 << __GFP_BITS_SHIFT) - 1))
-
- /* This equals 0, but use constants in case they ever change */
diff --git a/include/linux/if_team.h b/include/linux/if_team.h
index 458a073..d89036e 100644
--- a/include/linux/if_team.h
+++ b/include/linux/if_team.h
@@ -113,7 +113,7 @@ struct team {
struct list_head option_list;
const struct team_mode *mode;
- struct team_mode_ops ops;
+ team_mode_ops_no_const ops;
bool port_mtu_change_allowed;
long mode_priv[TEAM_MODE_PRIV_LONGS];
};
diff --git a/include/linux/if_team.h.rej b/include/linux/if_team.h.rej
deleted file mode 100644
index 1641669..0000000
--- a/include/linux/if_team.h.rej
+++ /dev/null
@@ -1,10 +0,0 @@
---- include/linux/if_team.h 2012-03-19 10:39:10.972049232 +0100
-+++ include/linux/if_team.h 2012-05-21 12:10:11.452048993 +0200
-@@ -113,7 +114,7 @@ struct team {
- struct list_head option_list;
-
- const struct team_mode *mode;
-- struct team_mode_ops ops;
-+ team_mode_ops_no_const ops;
- long mode_priv[TEAM_MODE_PRIV_LONGS];
- };
diff --git a/include/linux/sysctl.h b/include/linux/sysctl.h
index d950b5c..3b79441 100644
--- a/include/linux/sysctl.h
+++ b/include/linux/sysctl.h
@@ -157,7 +157,11 @@ enum
KERN_COLD_BOOT = 78, /* int: identify if system cold booted */
};
-
+#ifdef CONFIG_PAX_SOFTMODE
+enum {
+ PAX_SOFTMODE=1 /* PaX: disable/enable soft mode */
+};
+#endif
/* CTL_VM names: */
enum
diff --git a/include/linux/sysctl.h.rej b/include/linux/sysctl.h.rej
deleted file mode 100644
index 910abfd..0000000
--- a/include/linux/sysctl.h.rej
+++ /dev/null
@@ -1,14 +0,0 @@
-diff a/include/linux/sysctl.h b/include/linux/sysctl.h (rejected hunks)
-@@ -156,7 +156,11 @@ enum
- KERN_BOOT_REASON = 77, /* int: identify reason system was booted */
- };
-
--
-+#ifdef CONFIG_PAX_SOFTMODE
-+enum {
-+ PAX_SOFTMODE=1 /* PaX: disable/enable soft mode */
-+};
-+#endif
-
- /* CTL_VM names: */
- enum
diff --git a/include/linux/vmalloc.h b/include/linux/vmalloc.h
index 2553845..36fbb63 100644
--- a/include/linux/vmalloc.h
+++ b/include/linux/vmalloc.h
@@ -14,6 +14,11 @@ struct vm_area_struct; /* vma defining user mapping in mm_types.h */
#define VM_USERMAP 0x00000008 /* suitable for remap_vmalloc_range */
#define VM_VPAGES 0x00000010 /* buffer for pages was vmalloc'ed */
#define VM_UNLIST 0x00000020 /* vm_struct is not listed in vmlist */
+
+#if defined(CONFIG_MODULES) && defined(CONFIG_X86) && defined(CONFIG_PAX_KERNEXEC)
+#define VM_KERNEXEC 0x00000040 /* allocate from executable kernel memory range */
+#endif
+
#define VM_LOWMEM 0x00000040 /* Tracking of direct mapped lowmem */
/* bits [20..32] reserved for arch specific ioremap internals */
@@ -63,7 +68,7 @@ extern void *vmalloc_32_user(unsigned long size);
extern void *__vmalloc(unsigned long size, gfp_t gfp_mask, pgprot_t prot);
extern void *__vmalloc_node_range(unsigned long size, unsigned long align,
unsigned long start, unsigned long end, gfp_t gfp_mask,
- pgprot_t prot, int node, const void *caller);
+ pgprot_t prot, int node, const void *caller) __size_overflow(1);
extern void vfree(const void *addr);
extern void *vmap(struct page **pages, unsigned int count,
diff --git a/include/linux/vmalloc.h.rej b/include/linux/vmalloc.h.rej
deleted file mode 100644
index 0e3c8fa..0000000
--- a/include/linux/vmalloc.h.rej
+++ /dev/null
@@ -1,23 +0,0 @@
---- include/linux/vmalloc.h 2012-03-19 10:39:11.388049209 +0100
-+++ include/linux/vmalloc.h 2012-05-22 15:28:31.531384607 +0200
-@@ -14,6 +14,11 @@ struct vm_area_struct; /* vma defining
- #define VM_USERMAP 0x00000008 /* suitable for remap_vmalloc_range */
- #define VM_VPAGES 0x00000010 /* buffer for pages was vmalloc'ed */
- #define VM_UNLIST 0x00000020 /* vm_struct is not listed in vmlist */
-+
-+#if defined(CONFIG_MODULES) && defined(CONFIG_X86) && defined(CONFIG_PAX_KERNEXEC)
-+#define VM_KERNEXEC 0x00000040 /* allocate from executable kernel memory range */
-+#endif
-+
- /* bits [20..32] reserved for arch specific ioremap internals */
-
- /*
-@@ -62,7 +67,7 @@ extern void *vmalloc_32_user(unsigned lo
- extern void *__vmalloc(unsigned long size, gfp_t gfp_mask, pgprot_t prot);
- extern void *__vmalloc_node_range(unsigned long size, unsigned long align,
- unsigned long start, unsigned long end, gfp_t gfp_mask,
-- pgprot_t prot, int node, void *caller);
-+ pgprot_t prot, int node, void *caller) __size_overflow(1);
- extern void vfree(const void *addr);
-
- extern void *vmap(struct page **pages, unsigned int count,
diff --git a/include/net/inetpeer.h b/include/net/inetpeer.h
index 2d64364..e617e3e 100644
--- a/include/net/inetpeer.h
+++ b/include/net/inetpeer.h
@@ -51,8 +51,8 @@ struct inet_peer {
*/
union {
struct {
- atomic_t rid; /* Frag reception counter */
- atomic_t ip_id_count; /* IP ID for the next packet */
+ atomic_unchecked_t rid; /* Frag reception counter */
+ atomic_unchecked_t ip_id_count; /* IP ID for the next packet */
__u32 tcp_ts;
__u32 tcp_ts_stamp;
};
diff --git a/include/net/inetpeer.h.rej b/include/net/inetpeer.h.rej
deleted file mode 100644
index 7a07598..0000000
--- a/include/net/inetpeer.h.rej
+++ /dev/null
@@ -1,26 +0,0 @@
---- include/net/inetpeer.h 2012-07-21 01:28:45.278708106 +0200
-+++ include/net/inetpeer.h 2012-07-21 01:28:56.938708446 +0200
-@@ -51,8 +51,8 @@ struct inet_peer {
- */
- union {
- struct {
-- atomic_t rid; /* Frag reception counter */
-- atomic_t ip_id_count; /* IP ID for the next packet */
-+ atomic_unchecked_t rid; /* Frag reception counter */
-+ atomic_unchecked_t ip_id_count; /* IP ID for the next packet */
- __u32 tcp_ts;
- __u32 tcp_ts_stamp;
- };
-@@ -118,11 +118,11 @@ static inline int inet_getid(struct inet
- more++;
- inet_peer_refcheck(p);
- do {
-- old = atomic_read(&p->ip_id_count);
-+ old = atomic_read_unchecked(&p->ip_id_count);
- new = old + more;
- if (!new)
- new = 1;
-- } while (atomic_cmpxchg(&p->ip_id_count, old, new) != old);
-+ } while (atomic_cmpxchg_unchecked(&p->ip_id_count, old, new) != old);
- return new;
- }
diff --git a/include/sound/soc.h b/include/sound/soc.h
index 59b176f..5bb3fdd 100644
--- a/include/sound/soc.h
+++ b/include/sound/soc.h
@@ -779,7 +779,7 @@ struct snd_soc_platform_driver {
int (*write)(struct snd_soc_platform *, unsigned int, unsigned int);
int (*bespoke_trigger)(struct snd_pcm_substream *, int);
-};
+} __do_const;
struct snd_soc_platform {
const char *name;
diff --git a/include/sound/soc.h.rej b/include/sound/soc.h.rej
deleted file mode 100644
index b207cdf..0000000
--- a/include/sound/soc.h.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- include/sound/soc.h 2012-05-21 11:33:39.179929925 +0200
-+++ include/sound/soc.h 2012-05-21 12:10:11.664049005 +0200
-@@ -711,7 +711,7 @@ struct snd_soc_platform_driver {
- /* platform IO - used for platform DAPM */
- unsigned int (*read)(struct snd_soc_platform *, unsigned int);
- int (*write)(struct snd_soc_platform *, unsigned int, unsigned int);
--};
-+} __do_const;
-
- struct snd_soc_platform {
- const char *name;
diff --git a/kernel/audit.c b/kernel/audit.c
index a80d715..9762e8a 100644
--- a/kernel/audit.c
+++ b/kernel/audit.c
@@ -256,7 +256,7 @@ void audit_log_lost(const char *message)
printk(KERN_WARNING
"audit: audit_lost=%d audit_rate_limit=%d "
"audit_backlog_limit=%d\n",
- atomic_read(&audit_lost),
+ atomic_read_unchecked(&audit_lost),
audit_rate_limit,
audit_backlog_limit);
audit_panic(message);
diff --git a/kernel/audit.c.rej b/kernel/audit.c.rej
deleted file mode 100644
index 7a429c2..0000000
--- a/kernel/audit.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- kernel/audit.c 2012-05-21 11:33:39.347929934 +0200
-+++ kernel/audit.c 2012-05-21 12:10:11.704049007 +0200
-@@ -256,7 +256,7 @@ void audit_log_lost(const char *message)
- printk(KERN_WARNING
- "audit: audit_lost=%d audit_rate_limit=%d "
- "audit_backlog_limit=%d\n",
-- atomic_read(&audit_lost),
-+ atomic_read_unchecked(&audit_lost),
- audit_rate_limit,
- audit_backlog_limit);
- audit_panic(message);
diff --git a/kernel/module.c b/kernel/module.c
index 4199198..1e2ed11 100644
--- a/kernel/module.c
+++ b/kernel/module.c
@@ -3109,16 +3109,16 @@ SYSCALL_DEFINE3(init_module, void __user *, umod,
MODULE_STATE_COMING, mod);
/* Set RO and NX regions for core */
- set_section_ro_nx(mod->module_core,
- mod->core_text_size,
- mod->core_ro_size,
- mod->core_size);
+ set_section_ro_nx(mod->module_core_rx,
+ mod->core_size_rx,
+ mod->core_size_rx,
+ mod->core_size_rx);
/* Set RO and NX regions for init */
- set_section_ro_nx(mod->module_init,
- mod->init_text_size,
- mod->init_ro_size,
- mod->init_size);
+ set_section_ro_nx(mod->module_init_rx,
+ mod->init_size_rx,
+ mod->init_size_rx,
+ mod->init_size_rx);
do_mod_ctors(mod);
/* Start the module */
diff --git a/kernel/module.c.rej b/kernel/module.c.rej
deleted file mode 100644
index d5a4f7d..0000000
--- a/kernel/module.c.rej
+++ /dev/null
@@ -1,26 +0,0 @@
-diff a/kernel/module.c b/kernel/module.c (rejected hunks)
-@@ -3320,16 +3392,16 @@ SYSCALL_DEFINE3(init_module, void __user *, umod,
- #endif
-
- /* Set RO and NX regions for core */
-- set_section_ro_nx(mod->module_core,
-- mod->core_text_size,
-- mod->core_ro_size,
-- mod->core_size);
-+ set_section_ro_nx(mod->module_core_rx,
-+ mod->core_size_rx,
-+ mod->core_size_rx,
-+ mod->core_size_rx);
-
- /* Set RO and NX regions for init */
-- set_section_ro_nx(mod->module_init,
-- mod->init_text_size,
-- mod->init_ro_size,
-- mod->init_size);
-+ set_section_ro_nx(mod->module_init_rx,
-+ mod->init_size_rx,
-+ mod->init_size_rx,
-+ mod->init_size_rx);
-
- do_mod_ctors(mod);
- /* Start the module */
diff --git a/kernel/power/process.c b/kernel/power/process.c
index 8ec05f5..fed362a 100644
--- a/kernel/power/process.c
+++ b/kernel/power/process.c
@@ -36,6 +36,7 @@ static int try_to_freeze_tasks(bool user_only)
u64 elapsed_msecs64;
unsigned int elapsed_msecs;
bool wakeup = false;
+ bool timedout = false;
int sleep_usecs = USEC_PER_MSEC;
char suspend_abort[MAX_SUSPEND_ABORT_LEN];
@@ -80,7 +81,7 @@ static int try_to_freeze_tasks(bool user_only)
todo += wq_busy;
}
- if (!todo || time_after(jiffies, end_time))
+ if (!todo || timedout)
break;
if (pm_wakeup_pending()) {
diff --git a/kernel/power/process.c.rej b/kernel/power/process.c.rej
deleted file mode 100644
index d110847..0000000
--- a/kernel/power/process.c.rej
+++ /dev/null
@@ -1,19 +0,0 @@
---- kernel/power/process.c 2012-05-21 11:33:39.551929945 +0200
-+++ kernel/power/process.c 2012-05-21 12:10:11.796049012 +0200
-@@ -33,6 +33,7 @@ static int try_to_freeze_tasks(bool user
- u64 elapsed_csecs64;
- unsigned int elapsed_csecs;
- bool wakeup = false;
-+ bool timedout = false;
-
- do_gettimeofday(&start);
-
-@@ -75,7 +82,7 @@ static int try_to_freeze_tasks(bool user
- todo += wq_busy;
- }
-
-- if (!todo || time_after(jiffies, end_time))
-+ if (!todo || timedout)
- break;
-
- if (pm_wakeup_pending()) {
diff --git a/kernel/rcutree.h b/kernel/rcutree.h
index a178ac1..94beb76 100644
--- a/kernel/rcutree.h
+++ b/kernel/rcutree.h
@@ -87,7 +87,7 @@ struct rcu_dynticks {
long long dynticks_nesting; /* Track irq/process nesting level. */
/* Process level is worth LLONG_MAX/2. */
int dynticks_nmi_nesting; /* Track NMI nesting level. */
- atomic_t dynticks; /* Even value for idle, else odd. */
+ atomic_unchecked_t dynticks; /* Even value for idle, else odd. */
#ifdef CONFIG_RCU_FAST_NO_HZ
int dyntick_drain; /* Prepare-for-idle state variable. */
unsigned long dyntick_holdoff;
diff --git a/kernel/rcutree.h.rej b/kernel/rcutree.h.rej
deleted file mode 100644
index a05a1d5..0000000
--- a/kernel/rcutree.h.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- kernel/rcutree.h 2012-05-21 11:33:39.615929950 +0200
-+++ kernel/rcutree.h 2012-05-21 12:10:11.820049014 +0200
-@@ -87,7 +87,7 @@ struct rcu_dynticks {
- long long dynticks_nesting; /* Track irq/process nesting level. */
- /* Process level is worth LLONG_MAX/2. */
- int dynticks_nmi_nesting; /* Track NMI nesting level. */
-- atomic_t dynticks; /* Even value for idle, else odd. */
-+ atomic_unchecked_t dynticks;/* Even value for idle, else odd. */
- };
-
- /* RCU's kthread states for tracing. */
diff --git a/kernel/smp.c b/kernel/smp.c
index fcaaa42..6848980 100644
--- a/kernel/smp.c
+++ b/kernel/smp.c
@@ -471,22 +471,22 @@ int smp_call_function(smp_call_func_t func, void *info, int wait)
EXPORT_SYMBOL(smp_call_function);
#ifndef CONFIG_USE_GENERIC_SMP_HELPERS
-void ipi_call_lock(void)
+void ipi_call_lock(void) __acquires(call_function.lock)
{
raw_spin_lock(&call_function.lock);
}
-void ipi_call_unlock(void)
+void ipi_call_unlock(void) __releases(call_function.lock)
{
raw_spin_unlock(&call_function.lock);
}
-void ipi_call_lock_irq(void)
+void ipi_call_lock_irq(void) __acquires(call_function.lock)
{
raw_spin_lock_irq(&call_function.lock);
}
-void ipi_call_unlock_irq(void)
+void ipi_call_unlock_irq(void) __releases(call_function.lock)
{
raw_spin_unlock_irq(&call_function.lock);
}
diff --git a/kernel/smp.c.rej b/kernel/smp.c.rej
deleted file mode 100644
index 0067c8c..0000000
--- a/kernel/smp.c.rej
+++ /dev/null
@@ -1,28 +0,0 @@
-diff a/kernel/smp.c b/kernel/smp.c (rejected hunks)
-@@ -594,22 +594,22 @@ int smp_call_function(smp_call_func_t func, void *info, int wait)
- }
- EXPORT_SYMBOL(smp_call_function);
-
--void ipi_call_lock(void)
-+void ipi_call_lock(void) __acquires(call_function.lock)
- {
- raw_spin_lock(&call_function.lock);
- }
-
--void ipi_call_unlock(void)
-+void ipi_call_unlock(void) __releases(call_function.lock)
- {
- raw_spin_unlock(&call_function.lock);
- }
-
--void ipi_call_lock_irq(void)
-+void ipi_call_lock_irq(void) __acquires(call_function.lock)
- {
- raw_spin_lock_irq(&call_function.lock);
- }
-
--void ipi_call_unlock_irq(void)
-+void ipi_call_unlock_irq(void) __releases(call_function.lock)
- {
- raw_spin_unlock_irq(&call_function.lock);
- }
diff --git a/kernel/trace/trace_stack.c b/kernel/trace/trace_stack.c
index 8298997..88c977e 100644
--- a/kernel/trace/trace_stack.c
+++ b/kernel/trace/trace_stack.c
@@ -69,7 +69,7 @@ check_stack(unsigned long ip, unsigned long *stack)
return;
/* we do not handle interrupt stacks yet */
- if (!object_is_on_stack(stack))
+ if (!object_starts_on_stack(stack))
return;
local_irq_save(flags);
diff --git a/kernel/trace/trace_stack.c.rej b/kernel/trace/trace_stack.c.rej
deleted file mode 100644
index a6ab037..0000000
--- a/kernel/trace/trace_stack.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- kernel/trace/trace_stack.c 2012-03-19 10:39:11.988049175 +0100
-+++ kernel/trace/trace_stack.c 2012-05-21 12:10:11.900049018 +0200
-@@ -53,7 +53,7 @@ static inline void check_stack(void)
- return;
-
- /* we do not handle interrupt stacks yet */
-- if (!object_is_on_stack(&this_size))
-+ if (!object_starts_on_stack(&this_size))
- return;
-
- local_irq_save(flags);
diff --git a/lib/bitmap.c b/lib/bitmap.c
index 757b69e..088d207 100644
--- a/lib/bitmap.c
+++ b/lib/bitmap.c
@@ -604,7 +604,7 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen,
{
unsigned a, b;
int c, old_c, totaldigits;
- const char __user __force *ubuf = (const char __user __force *)buf;
+ const char __user *ubuf = (const char __force_user *)buf;
int at_start, in_range;
totaldigits = c = 0;
diff --git a/lib/bitmap.c.rej b/lib/bitmap.c.rej
deleted file mode 100644
index 750189f..0000000
--- a/lib/bitmap.c.rej
+++ /dev/null
@@ -1,10 +0,0 @@
-diff a/lib/bitmap.c b/lib/bitmap.c (rejected hunks)
-@@ -604,7 +604,7 @@ static int __bitmap_parselist(const char *buf, unsigned int buflen,
- {
- unsigned a, b;
- int c, old_c, totaldigits;
-- const char __user __force *ubuf = (const char __user __force *)buf;
-+ const char __user *ubuf = (const char __force_user *)buf;
- int exp_digit, in_range;
-
- totaldigits = c = 0;
diff --git a/mm/hugetlb.c b/mm/hugetlb.c
index 6ad964d..ca2adb8 100644
--- a/mm/hugetlb.c
+++ b/mm/hugetlb.c
@@ -2829,6 +2829,10 @@ int hugetlb_fault(struct mm_struct *mm, struct vm_area_struct *vma,
struct hstate *h = hstate_vma(vma);
int need_wait_lock = 0;
+#ifdef CONFIG_PAX_SEGMEXEC
+ struct vm_area_struct *vma_m;
+#endif
+
address &= huge_page_mask(h);
ptep = huge_pte_offset(mm, address);
diff --git a/mm/hugetlb.c.rej b/mm/hugetlb.c.rej
deleted file mode 100644
index fb998d0..0000000
--- a/mm/hugetlb.c.rej
+++ /dev/null
@@ -1,12 +0,0 @@
-diff a/mm/hugetlb.c b/mm/hugetlb.c (rejected hunks)
-@@ -2814,6 +2844,10 @@ int hugetlb_fault(struct mm_struct *mm, struct vm_area_struct *vma,
- static DEFINE_MUTEX(hugetlb_instantiation_mutex);
- struct hstate *h = hstate_vma(vma);
-
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ struct vm_area_struct *vma_m;
-+#endif
-+
- address &= huge_page_mask(h);
-
- ptep = huge_pte_offset(mm, address);
diff --git a/mm/memory-failure.c b/mm/memory-failure.c
index 5727a5b..3c1349b 100644
--- a/mm/memory-failure.c
+++ b/mm/memory-failure.c
@@ -1070,7 +1070,7 @@ int memory_failure(unsigned long pfn, int trapno, int flags)
if (PageHWPoison(hpage)) {
if ((hwpoison_filter(p) && TestClearPageHWPoison(p))
|| (p != hpage && TestSetPageHWPoison(hpage))) {
- atomic_long_sub(nr_pages, &mce_bad_pages);
+ atomic_long_sub_unchecked(nr_pages, &mce_bad_pages);
unlock_page(hpage);
return 0;
}
@@ -1456,8 +1456,7 @@ static int soft_offline_huge_page(struct page *page, int flags)
/* overcommit hugetlb page will be freed to buddy */
if (PageHuge(hpage)) {
if (!PageHWPoison(hpage))
- atomic_long_add(1 << compound_trans_order(hpage),
- &mce_bad_pages);
+ atomic_long_add_unchecked(1 << compound_trans_order(hpage), &mce_bad_pages);
set_page_hwpoison_huge_page(hpage);
dequeue_hwpoisoned_huge_page(hpage);
} else {
diff --git a/mm/memory-failure.c.rej b/mm/memory-failure.c.rej
deleted file mode 100644
index 10a09a0..0000000
--- a/mm/memory-failure.c.rej
+++ /dev/null
@@ -1,20 +0,0 @@
---- mm/memory-failure.c 2012-08-09 20:18:52.153847491 +0200
-+++ mm/memory-failure.c 2012-08-09 20:19:06.153846744 +0200
-@@ -1068,7 +1068,7 @@ int memory_failure(unsigned long pfn, in
- if (!PageHWPoison(hpage)
- || (hwpoison_filter(p) && TestClearPageHWPoison(p))
- || (p != hpage && TestSetPageHWPoison(hpage))) {
-- atomic_long_sub(nr_pages, &mce_bad_pages);
-+ atomic_long_sub_unchecked(nr_pages, &mce_bad_pages);
- return 0;
- }
- set_page_hwpoison_huge_page(hpage);
-@@ -1448,7 +1448,7 @@ static int soft_offline_huge_page(struct
- }
- done:
- if (!PageHWPoison(hpage))
-- atomic_long_add(1 << compound_trans_order(hpage), &mce_bad_pages);
-+ atomic_long_add_unchecked(1 << compound_trans_order(hpage), &mce_bad_pages);
- set_page_hwpoison_huge_page(hpage);
- dequeue_hwpoisoned_huge_page(hpage);
- /* keep elevated page count for bad page */
diff --git a/mm/memory.c b/mm/memory.c
index 50a6c25..b5d8d5f 100644
--- a/mm/memory.c
+++ b/mm/memory.c
@@ -3370,40 +3370,6 @@ static int do_swap_page(struct mm_struct *mm, struct vm_area_struct *vma,
}
/*
- * This is like a special single-page "expand_{down|up}wards()",
- * except we must first make sure that 'address{-|+}PAGE_SIZE'
- * doesn't hit another vma.
- */
-static inline int check_stack_guard_page(struct vm_area_struct *vma, unsigned long address)
-{
- address &= PAGE_MASK;
- if ((vma->vm_flags & VM_GROWSDOWN) && address == vma->vm_start) {
- struct vm_area_struct *prev = vma->vm_prev;
-
- /*
- * Is there a mapping abutting this one below?
- *
- * That's only ok if it's the same stack mapping
- * that has gotten split..
- */
- if (prev && prev->vm_end == address)
- return prev->vm_flags & VM_GROWSDOWN ? 0 : -ENOMEM;
-
- return expand_downwards(vma, address - PAGE_SIZE);
- }
- if ((vma->vm_flags & VM_GROWSUP) && address + PAGE_SIZE == vma->vm_end) {
- struct vm_area_struct *next = vma->vm_next;
-
- /* As VM_GROWSDOWN but s/below/above/ */
- if (next && next->vm_start == address + PAGE_SIZE)
- return next->vm_flags & VM_GROWSUP ? 0 : -ENOMEM;
-
- return expand_upwards(vma, address + PAGE_SIZE);
- }
- return 0;
-}
-
-/*
* We enter with non-exclusive mmap_sem (to exclude vma changes,
* but allow concurrent faults), and pte mapped but not yet locked.
* We return with mmap_sem still held, but pte unmapped and unlocked.
@@ -3412,27 +3378,23 @@ static int do_anonymous_page(struct mm_struct *mm, struct vm_area_struct *vma,
unsigned long address, pte_t *page_table, pmd_t *pmd,
unsigned int flags)
{
- struct page *page;
+ struct page *page = NULL;
spinlock_t *ptl;
pte_t entry;
- pte_unmap(page_table);
-
- /* Check if we need to add a guard page to the stack */
- if (check_stack_guard_page(vma, address) < 0)
- return VM_FAULT_SIGSEGV;
-
- /* Use the zero-page for reads */
if (!(flags & FAULT_FLAG_WRITE)) {
entry = pte_mkspecial(pfn_pte(my_zero_pfn(address),
vma->vm_page_prot));
- page_table = pte_offset_map_lock(mm, pmd, address, &ptl);
+ ptl = pte_lockptr(mm, pmd);
+ spin_lock(ptl);
if (!pte_none(*page_table))
goto unlock;
goto setpte;
}
/* Allocate our own private page. */
+ pte_unmap(page_table);
+
if (unlikely(anon_vma_prepare(vma)))
goto oom;
page = alloc_zeroed_user_highpage_movable(vma, address);
@@ -3876,7 +3838,7 @@ int handle_mm_fault(struct mm_struct *mm, struct vm_area_struct *vma,
* run pte_offset_map on the pmd, if an huge pmd could
* materialize from under us from a different thread.
*/
- if (unlikely(pmd_none(*pmd)) && __pte_alloc(mm, vma, pmd, address))
+ if (unlikely(pmd_none(*pmd) && __pte_alloc(mm, vma, pmd, address)))
return VM_FAULT_OOM;
/* if an huge pmd materialized from under us just retry later */
if (unlikely(pmd_trans_huge(*pmd)))
@@ -3913,6 +3875,23 @@ int __pud_alloc(struct mm_struct *mm, pgd_t *pgd, unsigned long address)
spin_unlock(&mm->page_table_lock);
return 0;
}
+
+int __pud_alloc_kernel(struct mm_struct *mm, pgd_t *pgd, unsigned long address)
+{
+ pud_t *new = pud_alloc_one(mm, address);
+ if (!new)
+ return -ENOMEM;
+
+ smp_wmb(); /* See comment in __pte_alloc */
+
+ spin_lock(&mm->page_table_lock);
+ if (pgd_present(*pgd)) /* Another has populated it */
+ pud_free(mm, new);
+ else
+ pgd_populate_kernel(mm, pgd, new);
+ spin_unlock(&mm->page_table_lock);
+ return 0;
+}
#endif /* __PAGETABLE_PUD_FOLDED */
#ifndef __PAGETABLE_PMD_FOLDED
@@ -3943,6 +3922,30 @@ int __pmd_alloc(struct mm_struct *mm, pud_t *pud, unsigned long address)
spin_unlock(&mm->page_table_lock);
return 0;
}
+
+int __pmd_alloc_kernel(struct mm_struct *mm, pud_t *pud, unsigned long address)
+{
+ pmd_t *new = pmd_alloc_one(mm, address);
+ if (!new)
+ return -ENOMEM;
+
+ smp_wmb(); /* See comment in __pte_alloc */
+
+ spin_lock(&mm->page_table_lock);
+#ifndef __ARCH_HAS_4LEVEL_HACK
+ if (pud_present(*pud)) /* Another has populated it */
+ pmd_free(mm, new);
+ else
+ pud_populate_kernel(mm, pud, new);
+#else
+ if (pgd_present(*pud)) /* Another has populated it */
+ pmd_free(mm, new);
+ else
+ pgd_populate_kernel(mm, pud, new);
+#endif /* __ARCH_HAS_4LEVEL_HACK */
+ spin_unlock(&mm->page_table_lock);
+ return 0;
+}
#endif /* __PAGETABLE_PMD_FOLDED */
int make_pages_present(unsigned long addr, unsigned long end)
@@ -3980,7 +3983,7 @@ static int __init gate_vma_init(void)
gate_vma.vm_start = FIXADDR_USER_START;
gate_vma.vm_end = FIXADDR_USER_END;
gate_vma.vm_flags = VM_READ | VM_MAYREAD | VM_EXEC | VM_MAYEXEC;
- gate_vma.vm_page_prot = __P101;
+ gate_vma.vm_page_prot = vm_get_page_prot(gate_vma.vm_flags);
return 0;
}
diff --git a/mm/memory.c.rej b/mm/memory.c.rej
deleted file mode 100644
index b18c29f..0000000
--- a/mm/memory.c.rej
+++ /dev/null
@@ -1,149 +0,0 @@
---- mm/memory.c 2012-05-21 11:33:40.095929975 +0200
-+++ mm/memory.c 2012-05-21 12:10:11.964049021 +0200
-@@ -3276,40 +3493,6 @@ out_release:
- }
-
- /*
-- * This is like a special single-page "expand_{down|up}wards()",
-- * except we must first make sure that 'address{-|+}PAGE_SIZE'
-- * doesn't hit another vma.
-- */
--static inline int check_stack_guard_page(struct vm_area_struct *vma, unsigned long address)
--{
-- address &= PAGE_MASK;
-- if ((vma->vm_flags & VM_GROWSDOWN) && address == vma->vm_start) {
-- struct vm_area_struct *prev = vma->vm_prev;
--
-- /*
-- * Is there a mapping abutting this one below?
-- *
-- * That's only ok if it's the same stack mapping
-- * that has gotten split..
-- */
-- if (prev && prev->vm_end == address)
-- return prev->vm_flags & VM_GROWSDOWN ? 0 : -ENOMEM;
--
-- expand_downwards(vma, address - PAGE_SIZE);
-- }
-- if ((vma->vm_flags & VM_GROWSUP) && address + PAGE_SIZE == vma->vm_end) {
-- struct vm_area_struct *next = vma->vm_next;
--
-- /* As VM_GROWSDOWN but s/below/above/ */
-- if (next && next->vm_start == address + PAGE_SIZE)
-- return next->vm_flags & VM_GROWSUP ? 0 : -ENOMEM;
--
-- expand_upwards(vma, address + PAGE_SIZE);
-- }
-- return 0;
--}
--
--/*
- * We enter with non-exclusive mmap_sem (to exclude vma changes,
- * but allow concurrent faults), and pte mapped but not yet locked.
- * We return with mmap_sem still held, but pte unmapped and unlocked.
-@@ -3318,27 +3501,23 @@ static int do_anonymous_page(struct mm_s
- unsigned long address, pte_t *page_table, pmd_t *pmd,
- unsigned int flags)
- {
-- struct page *page;
-+ struct page *page = NULL;
- spinlock_t *ptl;
- pte_t entry;
-
-- pte_unmap(page_table);
--
-- /* Check if we need to add a guard page to the stack */
-- if (check_stack_guard_page(vma, address) < 0)
-- return VM_FAULT_SIGBUS;
--
-- /* Use the zero-page for reads */
- if (!(flags & FAULT_FLAG_WRITE)) {
- entry = pte_mkspecial(pfn_pte(my_zero_pfn(address),
- vma->vm_page_prot));
-- page_table = pte_offset_map_lock(mm, pmd, address, &ptl);
-+ ptl = pte_lockptr(mm, pmd);
-+ spin_lock(ptl);
- if (!pte_none(*page_table))
- goto unlock;
- goto setpte;
- }
-
- /* Allocate our own private page. */
-+ pte_unmap(page_table);
-+
- if (unlikely(anon_vma_prepare(vma)))
- goto oom;
- page = alloc_zeroed_user_highpage_movable(vma, address);
-@@ -3798,7 +4040,7 @@ int handle_mm_fault(struct mm_struct *mm
- * run pte_offset_map on the pmd, if an huge pmd could
- * materialize from under us from a different thread.
- */
-- if (unlikely(pmd_none(*pmd)) && __pte_alloc(mm, vma, pmd, address))
-+ if (unlikely(pmd_none(*pmd) && __pte_alloc(mm, vma, pmd, address)))
- return VM_FAULT_OOM;
- /* if an huge pmd materialized from under us just retry later */
- if (unlikely(pmd_trans_huge(*pmd)))
-@@ -3835,6 +4077,23 @@ int __pud_alloc(struct mm_struct *mm, pg
- spin_unlock(&mm->page_table_lock);
- return 0;
- }
-+
-+int __pud_alloc_kernel(struct mm_struct *mm, pgd_t *pgd, unsigned long address)
-+{
-+ pud_t *new = pud_alloc_one(mm, address);
-+ if (!new)
-+ return -ENOMEM;
-+
-+ smp_wmb(); /* See comment in __pte_alloc */
-+
-+ spin_lock(&mm->page_table_lock);
-+ if (pgd_present(*pgd)) /* Another has populated it */
-+ pud_free(mm, new);
-+ else
-+ pgd_populate_kernel(mm, pgd, new);
-+ spin_unlock(&mm->page_table_lock);
-+ return 0;
-+}
- #endif /* __PAGETABLE_PUD_FOLDED */
-
- #ifndef __PAGETABLE_PMD_FOLDED
-@@ -3865,6 +4124,30 @@ int __pmd_alloc(struct mm_struct *mm, pu
- spin_unlock(&mm->page_table_lock);
- return 0;
- }
-+
-+int __pmd_alloc_kernel(struct mm_struct *mm, pud_t *pud, unsigned long address)
-+{
-+ pmd_t *new = pmd_alloc_one(mm, address);
-+ if (!new)
-+ return -ENOMEM;
-+
-+ smp_wmb(); /* See comment in __pte_alloc */
-+
-+ spin_lock(&mm->page_table_lock);
-+#ifndef __ARCH_HAS_4LEVEL_HACK
-+ if (pud_present(*pud)) /* Another has populated it */
-+ pmd_free(mm, new);
-+ else
-+ pud_populate_kernel(mm, pud, new);
-+#else
-+ if (pgd_present(*pud)) /* Another has populated it */
-+ pmd_free(mm, new);
-+ else
-+ pgd_populate_kernel(mm, pud, new);
-+#endif /* __ARCH_HAS_4LEVEL_HACK */
-+ spin_unlock(&mm->page_table_lock);
-+ return 0;
-+}
- #endif /* __PAGETABLE_PMD_FOLDED */
-
- int make_pages_present(unsigned long addr, unsigned long end)
-@@ -3902,7 +4185,7 @@ static int __init gate_vma_init(void)
- gate_vma.vm_start = FIXADDR_USER_START;
- gate_vma.vm_end = FIXADDR_USER_END;
- gate_vma.vm_flags = VM_READ | VM_MAYREAD | VM_EXEC | VM_MAYEXEC;
-- gate_vma.vm_page_prot = __P101;
-+ gate_vma.vm_page_prot = vm_get_page_prot(gate_vma.vm_flags);
-
- return 0;
- }
diff --git a/mm/mmap.c b/mm/mmap.c
index c2eb66c..acccaf4 100644
--- a/mm/mmap.c
+++ b/mm/mmap.c
@@ -747,6 +747,12 @@ can_vma_merge_before(struct vm_area_struct *vma, unsigned long vm_flags,
struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff,
const char __user *anon_name)
{
+
+#ifdef CONFIG_PAX_SEGMEXEC
+ if ((vma->vm_mm->pax_flags & MF_PAX_SEGMEXEC) && vma->vm_start == SEGMEXEC_TASK_SIZE)
+ return 0;
+#endif
+
if (is_mergeable_vma(vma, file, vm_flags, anon_name) &&
is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
if (vma->vm_pgoff == vm_pgoff)
@@ -767,6 +773,12 @@ can_vma_merge_after(struct vm_area_struct *vma, unsigned long vm_flags,
struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff,
const char __user *anon_name)
{
+
+#ifdef CONFIG_PAX_SEGMEXEC
+ if ((vma->vm_mm->pax_flags & MF_PAX_SEGMEXEC) && vma->vm_end == SEGMEXEC_TASK_SIZE)
+ return 0;
+#endif
+
if (is_mergeable_vma(vma, file, vm_flags, anon_name) &&
is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
pgoff_t vm_pglen;
@@ -817,6 +829,13 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
struct vm_area_struct *area, *next;
int err;
+#ifdef CONFIG_PAX_SEGMEXEC
+ unsigned long addr_m = addr + SEGMEXEC_TASK_SIZE, end_m = end + SEGMEXEC_TASK_SIZE;
+ struct vm_area_struct *area_m = NULL, *next_m = NULL, *prev_m = NULL;
+
+ BUG_ON((mm->pax_flags & MF_PAX_SEGMEXEC) && SEGMEXEC_TASK_SIZE < end);
+#endif
+
/*
* We later require that vma->vm_flags == vm_flags,
* so this tests vma->vm_flags & VM_SPECIAL, too.
@@ -891,12 +910,27 @@ struct vm_area_struct *vma_merge(struct mm_struct *mm,
mpol_equal(policy, vma_policy(next)) &&
can_vma_merge_before(next, vm_flags, anon_vma,
file, pgoff+pglen, anon_name)) {
- if (prev && addr < prev->vm_end) /* case 4 */
+ if (prev && addr < prev->vm_end) { /* case 4 */
err = vma_adjust(prev, prev->vm_start,
addr, prev->vm_pgoff, NULL);
- else /* cases 3, 8 */
+
+#ifdef CONFIG_PAX_SEGMEXEC
+ if (!err && prev_m)
+ err = vma_adjust(prev_m, prev_m->vm_start,
+ addr_m, prev_m->vm_pgoff, NULL);
+#endif
+
+ } else { /* cases 3, 8 */
err = vma_adjust(area, addr, next->vm_end,
next->vm_pgoff - pglen, NULL);
+
+#ifdef CONFIG_PAX_SEGMEXEC
+ if (!err && area_m)
+ err = vma_adjust(area_m, addr_m, next_m->vm_end,
+ next_m->vm_pgoff - pglen, NULL);
+#endif
+
+ }
if (err)
return NULL;
khugepaged_enter_vma_merge(area, vm_flags);
@@ -2109,11 +2143,22 @@ int expand_downwards(struct vm_area_struct *vma,
if (!error) {
vma->vm_start = address;
vma->vm_pgoff -= grow;
+ track_exec_limit(vma->vm_mm, vma->vm_start, vma->vm_end, vma->vm_flags);
+
+#ifdef CONFIG_PAX_SEGMEXEC
+ if (vma_m) {
+ vma_m->vm_start -= grow << PAGE_SHIFT;
+ vma_m->vm_pgoff -= grow;
+ }
+#endif
+
perf_event_mmap(vma);
}
}
}
vma_unlock_anon_vma(vma);
+ if (lockprev)
+ vma_unlock_anon_vma(prev);
khugepaged_enter_vma_merge(vma, vma->vm_flags);
return error;
}
diff --git a/mm/mmap.c.rej b/mm/mmap.c.rej
deleted file mode 100644
index 3979d2d..0000000
--- a/mm/mmap.c.rej
+++ /dev/null
@@ -1,103 +0,0 @@
---- mm/mmap.c 2012-05-21 11:33:40.107929975 +0200
-+++ mm/mmap.c 2012-05-22 16:53:56.195111150 +0200
-@@ -711,6 +732,12 @@ static int
- can_vma_merge_before(struct vm_area_struct *vma, unsigned long vm_flags,
- struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff)
- {
-+
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ if ((vma->vm_mm->pax_flags & MF_PAX_SEGMEXEC) && vma->vm_start == SEGMEXEC_TASK_SIZE)
-+ return 0;
-+#endif
-+
- if (is_mergeable_vma(vma, file, vm_flags) &&
- is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
- if (vma->vm_pgoff == vm_pgoff)
-@@ -730,6 +757,12 @@ static int
- can_vma_merge_after(struct vm_area_struct *vma, unsigned long vm_flags,
- struct anon_vma *anon_vma, struct file *file, pgoff_t vm_pgoff)
- {
-+
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ if ((vma->vm_mm->pax_flags & MF_PAX_SEGMEXEC) && vma->vm_end == SEGMEXEC_TASK_SIZE)
-+ return 0;
-+#endif
-+
- if (is_mergeable_vma(vma, file, vm_flags) &&
- is_mergeable_anon_vma(anon_vma, vma->anon_vma, vma)) {
- pgoff_t vm_pglen;
-@@ -772,13 +805,20 @@ can_vma_merge_after(struct vm_area_struc
- struct vm_area_struct *vma_merge(struct mm_struct *mm,
- struct vm_area_struct *prev, unsigned long addr,
- unsigned long end, unsigned long vm_flags,
-- struct anon_vma *anon_vma, struct file *file,
-+ struct anon_vma *anon_vma, struct file *file,
- pgoff_t pgoff, struct mempolicy *policy)
- {
- pgoff_t pglen = (end - addr) >> PAGE_SHIFT;
- struct vm_area_struct *area, *next;
- int err;
-
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ unsigned long addr_m = addr + SEGMEXEC_TASK_SIZE, end_m = end + SEGMEXEC_TASK_SIZE;
-+ struct vm_area_struct *area_m = NULL, *next_m = NULL, *prev_m = NULL;
-+
-+ BUG_ON((mm->pax_flags & MF_PAX_SEGMEXEC) && SEGMEXEC_TASK_SIZE < end);
-+#endif
-+
- /*
- * We later require that vma->vm_flags == vm_flags,
- * so this tests vma->vm_flags & VM_SPECIAL, too.
-@@ -853,12 +917,27 @@ struct vm_area_struct *vma_merge(struct
- mpol_equal(policy, vma_policy(next)) &&
- can_vma_merge_before(next, vm_flags,
- anon_vma, file, pgoff+pglen)) {
-- if (prev && addr < prev->vm_end) /* case 4 */
-+ if (prev && addr < prev->vm_end) { /* case 4 */
- err = vma_adjust(prev, prev->vm_start,
- addr, prev->vm_pgoff, NULL);
-- else /* cases 3, 8 */
-+
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ if (!err && prev_m)
-+ err = vma_adjust(prev_m, prev_m->vm_start,
-+ addr_m, prev_m->vm_pgoff, NULL);
-+#endif
-+
-+ } else { /* cases 3, 8 */
- err = vma_adjust(area, addr, next->vm_end,
- next->vm_pgoff - pglen, NULL);
-+
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ if (!err && area_m)
-+ err = vma_adjust(area_m, addr_m, next_m->vm_end,
-+ next_m->vm_pgoff - pglen, NULL);
-+#endif
-+
-+ }
- if (err)
- return NULL;
- khugepaged_enter_vma_merge(area);
-@@ -2050,11 +2314,22 @@ int expand_downwards(struct vm_area_stru
- if (!error) {
- vma->vm_start = address;
- vma->vm_pgoff -= grow;
-+ track_exec_limit(vma->vm_mm, vma->vm_start, vma->vm_end, vma->vm_flags);
-+
-+#ifdef CONFIG_PAX_SEGMEXEC
-+ if (vma_m) {
-+ vma_m->vm_start -= grow << PAGE_SHIFT;
-+ vma_m->vm_pgoff -= grow;
-+ }
-+#endif
-+
- perf_event_mmap(vma);
- }
- }
- }
- vma_unlock_anon_vma(vma);
-+ if (lockprev)
-+ vma_unlock_anon_vma(prev);
- khugepaged_enter_vma_merge(vma);
- return error;
- }
diff --git a/mm/swap.c b/mm/swap.c
index f689e9a..4a937cf 100644
--- a/mm/swap.c
+++ b/mm/swap.c
@@ -72,6 +72,8 @@ static void __put_compound_page(struct page *page)
if (!PageHuge(page))
__page_cache_release(page);
dtor = get_compound_page_dtor(page);
+ if (!PageHuge(page))
+ BUG_ON(dtor != free_compound_page);
(*dtor)(page);
}
diff --git a/mm/swap.c.rej b/mm/swap.c.rej
deleted file mode 100644
index f011efb..0000000
--- a/mm/swap.c.rej
+++ /dev/null
@@ -1,18 +0,0 @@
---- mm/swap.c 2012-05-21 11:33:40.171929979 +0200
-+++ mm/swap.c 2012-05-21 12:10:12.044049025 +0200
-@@ -30,6 +30,7 @@
- #include <linux/backing-dev.h>
- #include <linux/memcontrol.h>
- #include <linux/gfp.h>
-+#include <linux/hugetlb.h>
-
- #include "internal.h"
-
-@@ -70,6 +71,8 @@ static void __put_compound_page(struct p
-
- __page_cache_release(page);
- dtor = get_compound_page_dtor(page);
-+ if (!PageHuge(page))
-+ BUG_ON(dtor != free_compound_page);
- (*dtor)(page);
- }
diff --git a/net/bluetooth/hci_conn.c.rej b/net/bluetooth/hci_conn.c.rej
deleted file mode 100644
index bd8d5ef..0000000
--- a/net/bluetooth/hci_conn.c.rej
+++ /dev/null
@@ -1,10 +0,0 @@
-diff a/net/bluetooth/hci_conn.c b/net/bluetooth/hci_conn.c (rejected hunks)
-@@ -404,7 +404,7 @@ void hci_le_ltk_reply(struct hci_conn *conn, u8 ltk[16])
- memset(&cp, 0, sizeof(cp));
-
- cp.handle = cpu_to_le16(conn->handle);
-- memcpy(cp.ltk, ltk, sizeof(ltk));
-+ memcpy(cp.ltk, ltk, sizeof(cp.ltk));
-
- hci_send_cmd(hdev, HCI_OP_LE_LTK_REPLY, sizeof(cp), &cp);
- }
diff --git a/net/bluetooth/l2cap_core.c.rej b/net/bluetooth/l2cap_core.c.rej
deleted file mode 100644
index 2ab9548..0000000
--- a/net/bluetooth/l2cap_core.c.rej
+++ /dev/null
@@ -1,15 +0,0 @@
---- net/bluetooth/l2cap_core.c 2012-05-21 11:33:40.879930017 +0200
-+++ net/bluetooth/l2cap_core.c 2012-05-21 12:10:12.092049029 +0200
-@@ -2587,8 +2589,10 @@ static void l2cap_conf_rfc_get(struct l2
-
- switch (type) {
- case L2CAP_CONF_RFC:
-- if (olen == sizeof(rfc))
-- memcpy(&rfc, (void *)val, olen);
-+ if (olen != sizeof(rfc))
-+ break;
-+
-+ memcpy(&rfc, (void *)val, olen);
- goto done;
- }
- }
diff --git a/net/compat.c b/net/compat.c
index e7353fc..abb5f2e 100644
--- a/net/compat.c
+++ b/net/compat.c
@@ -80,9 +80,9 @@ int get_compat_msghdr(struct msghdr *kmsg, struct compat_msghdr __user *umsg)
if (kmsg->msg_namelen > sizeof(struct sockaddr_storage))
kmsg->msg_namelen = sizeof(struct sockaddr_storage);
- kmsg->msg_name = compat_ptr(tmp1);
- kmsg->msg_iov = compat_ptr(tmp2);
- kmsg->msg_control = compat_ptr(tmp3);
+ kmsg->msg_name = (void __force_kernel *)compat_ptr(tmp1);
+ kmsg->msg_iov = (void __force_kernel *)compat_ptr(tmp2);
+ kmsg->msg_control = (void __force_kernel *)compat_ptr(tmp3);
return 0;
}
diff --git a/net/compat.c.rej b/net/compat.c.rej
deleted file mode 100644
index 79fee55..0000000
--- a/net/compat.c.rej
+++ /dev/null
@@ -1,14 +0,0 @@
---- net/compat.c 2012-08-09 20:18:52.173847490 +0200
-+++ net/compat.c 2012-08-09 20:19:41.993844830 +0200
-@@ -71,9 +71,9 @@ int get_compat_msghdr(struct msghdr *kms
- __get_user(kmsg->msg_controllen, &umsg->msg_controllen) ||
- __get_user(kmsg->msg_flags, &umsg->msg_flags))
- return -EFAULT;
-- kmsg->msg_name = compat_ptr(tmp1);
-- kmsg->msg_iov = compat_ptr(tmp2);
-- kmsg->msg_control = compat_ptr(tmp3);
-+ kmsg->msg_name = (void __force_kernel *)compat_ptr(tmp1);
-+ kmsg->msg_iov = (void __force_kernel *)compat_ptr(tmp2);
-+ kmsg->msg_control = (void __force_kernel *)compat_ptr(tmp3);
- return 0;
- }
diff --git a/net/ipv4/inetpeer.c b/net/ipv4/inetpeer.c
index d63a926..013947b 100644
--- a/net/ipv4/inetpeer.c
+++ b/net/ipv4/inetpeer.c
@@ -487,8 +487,8 @@ struct inet_peer *inet_getpeer(const struct inetpeer_addr *daddr, int create)
if (p) {
p->daddr = *daddr;
atomic_set(&p->refcnt, 1);
- atomic_set(&p->rid, 0);
- atomic_set(&p->ip_id_count,
+ atomic_set_unchecked(&p->rid, 0);
+ atomic_set_unchecked(&p->ip_id_count,
(daddr->family == AF_INET) ?
secure_ip_id(daddr->addr.a4) :
secure_ipv6_id(daddr->addr.a6));
diff --git a/net/ipv4/inetpeer.c.rej b/net/ipv4/inetpeer.c.rej
deleted file mode 100644
index d0bed373..0000000
--- a/net/ipv4/inetpeer.c.rej
+++ /dev/null
@@ -1,13 +0,0 @@
---- net/ipv4/inetpeer.c 2012-07-21 01:28:45.442708108 +0200
-+++ net/ipv4/inetpeer.c 2012-07-21 01:28:57.122708454 +0200
-@@ -487,8 +487,8 @@ relookup:
- if (p) {
- p->daddr = *daddr;
- atomic_set(&p->refcnt, 1);
-- atomic_set(&p->rid, 0);
-- atomic_set(&p->ip_id_count,
-+ atomic_set_unchecked(&p->rid, 0);
-+ atomic_set_unchecked(&p->ip_id_count,
- (daddr->family == AF_INET) ?
- secure_ip_id(daddr->addr.a4) :
- secure_ipv6_id(daddr->addr.a6));
diff --git a/net/ipv4/ping.c b/net/ipv4/ping.c
index bc374ad..55ea376 100644
--- a/net/ipv4/ping.c
+++ b/net/ipv4/ping.c
@@ -1108,7 +1108,7 @@ static void ping_format_sock(struct sock *sp, struct seq_file *f,
sk_rmem_alloc_get(sp),
0, 0L, 0, sock_i_uid(sp), 0, sock_i_ino(sp),
atomic_read(&sp->sk_refcnt), sp,
- atomic_read(&sp->sk_drops), len);
+ atomic_read_unchecked(&sp->sk_drops), len);
}
static int ping_seq_show(struct seq_file *seq, void *v)
diff --git a/net/ipv4/ping.c.rej b/net/ipv4/ping.c.rej
deleted file mode 100644
index 0f3a592..0000000
--- a/net/ipv4/ping.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- net/ipv4/ping.c 2012-05-21 11:33:41.183930034 +0200
-+++ net/ipv4/ping.c 2012-05-21 12:10:12.164049032 +0200
-@@ -838,7 +838,7 @@ static void ping_format_sock(struct sock
- sk_rmem_alloc_get(sp),
- 0, 0L, 0, sock_i_uid(sp), 0, sock_i_ino(sp),
- atomic_read(&sp->sk_refcnt), sp,
-- atomic_read(&sp->sk_drops), len);
-+ atomic_read_unchecked(&sp->sk_drops), len);
- }
-
- static int ping_seq_show(struct seq_file *seq, void *v)
diff --git a/net/ipv4/route.c b/net/ipv4/route.c
index b65d0c6..1ff48d3 100644
--- a/net/ipv4/route.c
+++ b/net/ipv4/route.c
@@ -3050,7 +3050,7 @@ static int rt_fill_info(struct net *net,
error = rt->dst.error;
if (peer) {
inet_peer_refcheck(rt->peer);
- id = atomic_read(&peer->ip_id_count) & 0xffff;
+ id = atomic_read_unchecked(&peer->ip_id_count) & 0xffff;
if (peer->tcp_ts_stamp) {
ts = peer->tcp_ts;
tsage = get_seconds() - peer->tcp_ts_stamp;
diff --git a/net/ipv4/route.c.rej b/net/ipv4/route.c.rej
deleted file mode 100644
index fe8448d..0000000
--- a/net/ipv4/route.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- net/ipv4/route.c 2012-05-21 11:33:41.191930034 +0200
-+++ net/ipv4/route.c 2012-05-21 12:10:12.176049032 +0200
-@@ -3009,7 +3009,7 @@ static int rt_fill_info(struct net *net,
- error = rt->dst.error;
- if (peer) {
- inet_peer_refcheck(rt->peer);
-- id = atomic_read(&peer->ip_id_count) & 0xffff;
-+ id = atomic_read_unchecked(&peer->ip_id_count) & 0xffff;
- if (peer->tcp_ts_stamp) {
- ts = peer->tcp_ts;
- tsage = get_seconds() - peer->tcp_ts_stamp;
diff --git a/net/ipv4/udp.c b/net/ipv4/udp.c
index 2c19509..80b32cd 100644
--- a/net/ipv4/udp.c
+++ b/net/ipv4/udp.c
@@ -2098,7 +2098,7 @@ static void udp4_format_sock(struct sock *sp, struct seq_file *f,
sk_rmem_alloc_get(sp),
0, 0L, 0, sock_i_uid(sp), 0, sock_i_ino(sp),
atomic_read(&sp->sk_refcnt), sp,
- atomic_read(&sp->sk_drops));
+ atomic_read_unchecked(&sp->sk_drops));
}
int udp4_seq_show(struct seq_file *seq, void *v)
diff --git a/net/ipv4/udp.c.rej b/net/ipv4/udp.c.rej
deleted file mode 100644
index 7f49fc5..0000000
--- a/net/ipv4/udp.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- net/ipv4/udp.c 2012-05-21 11:33:41.259930038 +0200
-+++ net/ipv4/udp.c 2012-05-21 12:10:12.180049033 +0200
-@@ -2095,7 +2095,7 @@ static void udp4_format_sock(struct sock
- sk_rmem_alloc_get(sp),
- 0, 0L, 0, sock_i_uid(sp), 0, sock_i_ino(sp),
- atomic_read(&sp->sk_refcnt), sp,
-- atomic_read(&sp->sk_drops), len);
-+ atomic_read_unchecked(&sp->sk_drops), len);
- }
-
- int udp4_seq_show(struct seq_file *seq, void *v)
diff --git a/net/phonet/socket.c b/net/phonet/socket.c
index 0e3c6ec..6626a58 100644
--- a/net/phonet/socket.c
+++ b/net/phonet/socket.c
@@ -613,7 +613,7 @@ static int pn_sock_seq_show(struct seq_file *seq, void *v)
sk_wmem_alloc_get(sk), sk_rmem_alloc_get(sk),
sock_i_uid(sk), sock_i_ino(sk),
atomic_read(&sk->sk_refcnt), sk,
- atomic_read(&sk->sk_drops));
+ atomic_read_unchecked(&sk->sk_drops));
}
seq_pad(seq, '\n');
return 0;
diff --git a/net/phonet/socket.c.rej b/net/phonet/socket.c.rej
deleted file mode 100644
index 36ff5fd..0000000
--- a/net/phonet/socket.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- net/phonet/socket.c 2012-03-19 10:39:14.136049059 +0100
-+++ net/phonet/socket.c 2012-05-21 12:10:12.268049037 +0200
-@@ -614,7 +614,7 @@ static int pn_sock_seq_show(struct seq_f
- sk_wmem_alloc_get(sk), sk_rmem_alloc_get(sk),
- sock_i_uid(sk), sock_i_ino(sk),
- atomic_read(&sk->sk_refcnt), sk,
-- atomic_read(&sk->sk_drops), &len);
-+ atomic_read_unchecked(&sk->sk_drops), &len);
- }
- seq_printf(seq, "%*s\n", 127 - len, "");
- return 0;
diff --git a/net/socket.c b/net/socket.c
index aff24ac..ed7a698 100644
--- a/net/socket.c
+++ b/net/socket.c
@@ -2191,7 +2191,7 @@ static int ___sys_recvmsg(struct socket *sock, struct msghdr __user *msg,
/* Save the user-mode address (verify_iovec will change the
* kernel msghdr to use the kernel address space)
*/
- uaddr = (__force void __user *)msg_sys->msg_name;
+ uaddr = (void __force_user *)msg_sys->msg_name;
uaddr_len = COMPAT_NAMELEN(msg);
if (MSG_CMSG_COMPAT & flags)
err = verify_compat_iovec(msg_sys, iov, &addr, VERIFY_WRITE);
diff --git a/net/socket.c.rej b/net/socket.c.rej
deleted file mode 100644
index a137006..0000000
--- a/net/socket.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- net/socket.c 2012-08-09 20:18:52.313847482 +0200
-+++ net/socket.c 2012-08-09 20:19:06.321846735 +0200
-@@ -2139,7 +2139,7 @@ static int __sys_recvmsg(struct socket *
- * kernel msghdr to use the kernel address space)
- */
-
-- uaddr = (__force void __user *)msg_sys->msg_name;
-+ uaddr = (void __force_user *)msg_sys->msg_name;
- uaddr_len = COMPAT_NAMELEN(msg);
- if (MSG_CMSG_COMPAT & flags) {
- err = verify_compat_iovec(msg_sys, iov, &addr, VERIFY_WRITE);
diff --git a/security/keys/compat.c b/security/keys/compat.c
index 1b0b7bf..9476b92 100644
--- a/security/keys/compat.c
+++ b/security/keys/compat.c
@@ -44,7 +44,7 @@ long compat_keyctl_instantiate_key_iov(
if (ret == 0)
goto no_payload_free;
- ret = keyctl_instantiate_key_common(id, iov, ioc, ret, ringid);
+ ret = keyctl_instantiate_key_common(id, (const struct iovec __force_user *)iov, ioc, ret, ringid);
err:
if (iov != iovstack)
kfree(iov);
diff --git a/security/keys/compat.c.rej b/security/keys/compat.c.rej
deleted file mode 100644
index 7a74d9d..0000000
--- a/security/keys/compat.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- security/keys/compat.c 2012-01-08 19:48:31.735470731 +0100
-+++ security/keys/compat.c 2012-05-21 12:10:12.400049045 +0200
-@@ -44,7 +44,7 @@ long compat_keyctl_instantiate_key_iov(
- if (ret == 0)
- goto no_payload_free;
-
-- ret = keyctl_instantiate_key_common(id, iov, ioc, ret, ringid);
-+ ret = keyctl_instantiate_key_common(id, (const struct iovec __force_user *)iov, ioc, ret, ringid);
-
- if (iov != iovstack)
- kfree(iov);
diff --git a/security/keys/keyctl.c b/security/keys/keyctl.c
index dc57d2b..07bb546 100644
--- a/security/keys/keyctl.c
+++ b/security/keys/keyctl.c
@@ -1085,7 +1085,7 @@ long keyctl_instantiate_key_iov(key_serial_t id,
if (ret == 0)
goto no_payload_free;
- ret = keyctl_instantiate_key_common(id, iov, ioc, ret, ringid);
+ ret = keyctl_instantiate_key_common(id, (const struct iovec __force_user *)iov, ioc, ret, ringid);
err:
if (iov != iovstack)
kfree(iov);
diff --git a/security/keys/keyctl.c.rej b/security/keys/keyctl.c.rej
deleted file mode 100644
index 60237fb..0000000
--- a/security/keys/keyctl.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- security/keys/keyctl.c 2012-05-21 11:33:42.531930107 +0200
-+++ security/keys/keyctl.c 2012-05-21 12:10:12.404049045 +0200
-@@ -1085,7 +1085,7 @@ long keyctl_instantiate_key_iov(key_seri
- if (ret == 0)
- goto no_payload_free;
-
-- ret = keyctl_instantiate_key_common(id, iov, ioc, ret, ringid);
-+ ret = keyctl_instantiate_key_common(id, (const struct iovec __force_user *)iov, ioc, ret, ringid);
-
- if (iov != iovstack)
- kfree(iov);
diff --git a/security/selinux/hooks.c b/security/selinux/hooks.c
index 8ca7b07..6cb5d78 100644
--- a/security/selinux/hooks.c
+++ b/security/selinux/hooks.c
@@ -5780,7 +5780,7 @@ static int selinux_key_getsecurity(struct key *key, char **_buffer)
#endif
-static struct security_operations selinux_ops = {
+static struct security_operations selinux_ops __read_only = {
.name = "selinux",
.binder_set_context_mgr = selinux_binder_set_context_mgr,
diff --git a/security/selinux/hooks.c.rej b/security/selinux/hooks.c.rej
deleted file mode 100644
index 1e2910c..0000000
--- a/security/selinux/hooks.c.rej
+++ /dev/null
@@ -1,10 +0,0 @@
-diff a/security/selinux/hooks.c b/security/selinux/hooks.c (rejected hunks)
-@@ -5801,7 +5801,7 @@ static int selinux_bprm_check_security (struct linux_binprm *bprm)
- #endif
- /* TmmSecure end */
-
--static struct security_operations selinux_ops = {
-+static struct security_operations selinux_ops __read_only = {
- .name = "selinux",
-
- .binder_set_context_mgr = selinux_binder_set_context_mgr,
diff --git a/sound/soc/soc-pcm.c.rej b/sound/soc/soc-pcm.c.rej
deleted file mode 100644
index 9673a52..0000000
--- a/sound/soc/soc-pcm.c.rej
+++ /dev/null
@@ -1,11 +0,0 @@
---- sound/soc/soc-pcm.c 2012-05-21 11:33:44.919930237 +0200
-+++ sound/soc/soc-pcm.c 2012-05-21 12:10:12.480049049 +0200
-@@ -641,7 +641,7 @@ int soc_new_pcm(struct snd_soc_pcm_runti
- struct snd_soc_platform *platform = rtd->platform;
- struct snd_soc_dai *codec_dai = rtd->codec_dai;
- struct snd_soc_dai *cpu_dai = rtd->cpu_dai;
-- struct snd_pcm_ops *soc_pcm_ops = &rtd->ops;
-+ snd_pcm_ops_no_const *soc_pcm_ops = &rtd->ops;
- struct snd_pcm *pcm;
- char new_name[64];
- int ret = 0, playback = 0, capture = 0;
diff --git a/sound/usb/card.h.rej b/sound/usb/card.h.rej
deleted file mode 100644
index eae6a2b..0000000
--- a/sound/usb/card.h.rej
+++ /dev/null
@@ -1,18 +0,0 @@
-diff a/sound/usb/card.h b/sound/usb/card.h (rejected hunks)
-@@ -45,6 +45,7 @@ struct snd_urb_ops {
- int (*prepare_sync)(struct snd_usb_substream *subs, struct snd_pcm_runtime *runtime, struct urb *u);
- int (*retire_sync)(struct snd_usb_substream *subs, struct snd_pcm_runtime *runtime, struct urb *u);
- };
-+typedef struct snd_urb_ops __no_const snd_urb_ops_no_const;
-
- struct snd_usb_substream {
- struct snd_usb_stream *stream;
-@@ -96,7 +97,7 @@ struct snd_usb_substream {
- struct snd_pcm_hw_constraint_list rate_list; /* limited rates */
- spinlock_t lock;
-
-- struct snd_urb_ops ops; /* callbacks (must be filled at init) */
-+ snd_urb_ops_no_const ops; /* callbacks (must be filled at init) */
- int last_frame_number; /* stored frame number */
- int last_delay; /* stored delay */
- };
diff --git a/usr/gen_init_cpio.c b/usr/gen_init_cpio.c
index aca6edc..86cd399 100644
--- a/usr/gen_init_cpio.c
+++ b/usr/gen_init_cpio.c
@@ -392,12 +392,10 @@ static char *cpio_replace_env(char *new_location)
*env_var = *expanded = '\0';
strncat(env_var, start + 2, end - start - 2);
strncat(expanded, new_location, start - new_location);
- strncat(expanded, getenv(env_var),
- PATH_MAX - strlen(expanded));
- strncat(expanded, end + 1,
- PATH_MAX - strlen(expanded));
- strncpy(new_location, expanded, PATH_MAX);
- new_location[PATH_MAX] = 0;
+ strncat(expanded, getenv(env_var), PATH_MAX - strlen(expanded));
+ strncat(expanded, end + 1, PATH_MAX - strlen(expanded));
+ strncpy(new_location, expanded, PATH_MAX);
+ new_location[PATH_MAX] = 0;
} else
break;
}
diff --git a/usr/gen_init_cpio.c.rej b/usr/gen_init_cpio.c.rej
deleted file mode 100644
index 3e1b7ce..0000000
--- a/usr/gen_init_cpio.c.rej
+++ /dev/null
@@ -1,24 +0,0 @@
---- usr/gen_init_cpio.c 2011-07-22 04:17:23.000000000 +0200
-+++ usr/gen_init_cpio.c 2012-05-21 12:10:12.504049050 +0200
-@@ -303,7 +303,7 @@ static int cpio_mkfile(const char *name,
- int retval;
- int rc = -1;
- int namesize;
-- int i;
-+ unsigned int i;
-
- mode |= S_IFREG;
-
-@@ -392,9 +392,10 @@ static char *cpio_replace_env(char *new_
- *env_var = *expanded = '\0';
- strncat(env_var, start + 2, end - start - 2);
- strncat(expanded, new_location, start - new_location);
-- strncat(expanded, getenv(env_var), PATH_MAX);
-- strncat(expanded, end + 1, PATH_MAX);
-+ strncat(expanded, getenv(env_var), PATH_MAX - strlen(expanded));
-+ strncat(expanded, end + 1, PATH_MAX - strlen(expanded));
- strncpy(new_location, expanded, PATH_MAX);
-+ new_location[PATH_MAX] = 0;
- } else
- break;
- }