diff options
| -rw-r--r-- | arch/x86/kernel/process_64.c | 4 | ||||
| -rw-r--r-- | arch/x86/kernel/vmlinux_64.lds.S | 2 | ||||
| -rw-r--r-- | arch/x86/mm/ioremap.c | 2 |
3 files changed, 4 insertions, 4 deletions
diff --git a/arch/x86/kernel/process_64.c b/arch/x86/kernel/process_64.c index 2a8ccb9238b4..b6b508ea7110 100644 --- a/arch/x86/kernel/process_64.c +++ b/arch/x86/kernel/process_64.c | |||
| @@ -754,12 +754,12 @@ unsigned long get_wchan(struct task_struct *p) | |||
| 754 | if (!p || p == current || p->state == TASK_RUNNING) | 754 | if (!p || p == current || p->state == TASK_RUNNING) |
| 755 | return 0; | 755 | return 0; |
| 756 | stack = (unsigned long)task_stack_page(p); | 756 | stack = (unsigned long)task_stack_page(p); |
| 757 | if (p->thread.sp < stack || p->thread.sp > stack+THREAD_SIZE) | 757 | if (p->thread.sp < stack || p->thread.sp >= stack+THREAD_SIZE) |
| 758 | return 0; | 758 | return 0; |
| 759 | fp = *(u64 *)(p->thread.sp); | 759 | fp = *(u64 *)(p->thread.sp); |
| 760 | do { | 760 | do { |
| 761 | if (fp < (unsigned long)stack || | 761 | if (fp < (unsigned long)stack || |
| 762 | fp > (unsigned long)stack+THREAD_SIZE) | 762 | fp >= (unsigned long)stack+THREAD_SIZE) |
| 763 | return 0; | 763 | return 0; |
| 764 | ip = *(u64 *)(fp+8); | 764 | ip = *(u64 *)(fp+8); |
| 765 | if (!in_sched_functions(ip)) | 765 | if (!in_sched_functions(ip)) |
diff --git a/arch/x86/kernel/vmlinux_64.lds.S b/arch/x86/kernel/vmlinux_64.lds.S index 201e81a91a95..46e05447405b 100644 --- a/arch/x86/kernel/vmlinux_64.lds.S +++ b/arch/x86/kernel/vmlinux_64.lds.S | |||
| @@ -172,8 +172,8 @@ SECTIONS | |||
| 172 | .x86_cpu_dev.init : AT(ADDR(.x86_cpu_dev.init) - LOAD_OFFSET) { | 172 | .x86_cpu_dev.init : AT(ADDR(.x86_cpu_dev.init) - LOAD_OFFSET) { |
| 173 | *(.x86_cpu_dev.init) | 173 | *(.x86_cpu_dev.init) |
| 174 | } | 174 | } |
| 175 | SECURITY_INIT | ||
| 176 | __x86_cpu_dev_end = .; | 175 | __x86_cpu_dev_end = .; |
| 176 | SECURITY_INIT | ||
| 177 | 177 | ||
| 178 | . = ALIGN(8); | 178 | . = ALIGN(8); |
| 179 | .parainstructions : AT(ADDR(.parainstructions) - LOAD_OFFSET) { | 179 | .parainstructions : AT(ADDR(.parainstructions) - LOAD_OFFSET) { |
diff --git a/arch/x86/mm/ioremap.c b/arch/x86/mm/ioremap.c index 6ab3196d12b4..10b52309aefd 100644 --- a/arch/x86/mm/ioremap.c +++ b/arch/x86/mm/ioremap.c | |||
| @@ -614,7 +614,7 @@ void __init *early_ioremap(unsigned long phys_addr, unsigned long size) | |||
| 614 | */ | 614 | */ |
| 615 | offset = phys_addr & ~PAGE_MASK; | 615 | offset = phys_addr & ~PAGE_MASK; |
| 616 | phys_addr &= PAGE_MASK; | 616 | phys_addr &= PAGE_MASK; |
| 617 | size = PAGE_ALIGN(last_addr) - phys_addr; | 617 | size = PAGE_ALIGN(last_addr + 1) - phys_addr; |
| 618 | 618 | ||
| 619 | /* | 619 | /* |
| 620 | * Mappings have to fit in the FIX_BTMAP area. | 620 | * Mappings have to fit in the FIX_BTMAP area. |
