diff options
author | Ingo Molnar <mingo@elte.hu> | 2009-06-17 06:52:15 -0400 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2009-06-17 06:56:49 -0400 |
commit | eadb8a091b27a840de7450f84ecff5ef13476424 (patch) | |
tree | 58c3782d40def63baa8167f3d31e3048cb4c7660 /arch/x86/kernel/process.c | |
parent | 73874005cd8800440be4299bd095387fff4b90ac (diff) | |
parent | 65795efbd380a832ae508b04dba8f8e53f0b84d9 (diff) |
Merge branch 'linus' into tracing/hw-breakpoints
Conflicts:
arch/x86/Kconfig
arch/x86/kernel/traps.c
arch/x86/power/cpu.c
arch/x86/power/cpu_32.c
kernel/Makefile
Semantic conflict:
arch/x86/kernel/hw_breakpoint.c
Merge reason: Resolve the conflicts, move from put_cpu_no_sched() to
put_cpu() in arch/x86/kernel/hw_breakpoint.c.
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Diffstat (limited to 'arch/x86/kernel/process.c')
-rw-r--r-- | arch/x86/kernel/process.c | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/arch/x86/kernel/process.c b/arch/x86/kernel/process.c index 19a686c401b5..fc6e4b773fc4 100644 --- a/arch/x86/kernel/process.c +++ b/arch/x86/kernel/process.c | |||
@@ -8,9 +8,11 @@ | |||
8 | #include <linux/module.h> | 8 | #include <linux/module.h> |
9 | #include <linux/pm.h> | 9 | #include <linux/pm.h> |
10 | #include <linux/clockchips.h> | 10 | #include <linux/clockchips.h> |
11 | #include <linux/random.h> | ||
11 | #include <trace/power.h> | 12 | #include <trace/power.h> |
12 | #include <asm/system.h> | 13 | #include <asm/system.h> |
13 | #include <asm/apic.h> | 14 | #include <asm/apic.h> |
15 | #include <asm/syscalls.h> | ||
14 | #include <asm/idle.h> | 16 | #include <asm/idle.h> |
15 | #include <asm/uaccess.h> | 17 | #include <asm/uaccess.h> |
16 | #include <asm/i387.h> | 18 | #include <asm/i387.h> |
@@ -65,7 +67,7 @@ void arch_task_cache_init(void) | |||
65 | task_xstate_cachep = | 67 | task_xstate_cachep = |
66 | kmem_cache_create("task_xstate", xstate_size, | 68 | kmem_cache_create("task_xstate", xstate_size, |
67 | __alignof__(union thread_xstate), | 69 | __alignof__(union thread_xstate), |
68 | SLAB_PANIC, NULL); | 70 | SLAB_PANIC | SLAB_NOTRACK, NULL); |
69 | } | 71 | } |
70 | 72 | ||
71 | /* | 73 | /* |
@@ -604,3 +606,16 @@ static int __init idle_setup(char *str) | |||
604 | } | 606 | } |
605 | early_param("idle", idle_setup); | 607 | early_param("idle", idle_setup); |
606 | 608 | ||
609 | unsigned long arch_align_stack(unsigned long sp) | ||
610 | { | ||
611 | if (!(current->personality & ADDR_NO_RANDOMIZE) && randomize_va_space) | ||
612 | sp -= get_random_int() % 8192; | ||
613 | return sp & ~0xf; | ||
614 | } | ||
615 | |||
616 | unsigned long arch_randomize_brk(struct mm_struct *mm) | ||
617 | { | ||
618 | unsigned long range_end = mm->brk + 0x02000000; | ||
619 | return randomize_range(mm->brk, range_end, 0) ? : mm->brk; | ||
620 | } | ||
621 | |||