diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-19 14:46:09 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2014-10-19 14:46:09 -0400 |
commit | 5e2ee7cd58fcee6c6cc954642faa584f54c8391e (patch) | |
tree | 356b258d76b7b60a731a7a4a64a805a8055b247c | |
parent | e25b492741373542fb593477547fcf7a6b7d8b04 (diff) | |
parent | e2653143d7d79a49f1a961aeae1d82612838b12c (diff) |
Merge git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc
Pull sparc fixes from David Miller:
"Here we have two bug fixes:
1) The current thread's fault_code is not setup properly upon entry to
do_sparc64_fault() in some paths, leading to spurious SIGBUS.
2) Don't use a zero length array at the end of thread_info on sparc64,
otherwise end_of_stack() isn't right"
* git://git.kernel.org/pub/scm/linux/kernel/git/davem/sparc:
sparc64: Do not define thread fpregs save area as zero-length array.
sparc64: Fix corrupted thread fault code.
-rw-r--r-- | arch/sparc/include/asm/thread_info_64.h | 3 | ||||
-rw-r--r-- | arch/sparc/kernel/dtlb_prot.S | 6 | ||||
-rw-r--r-- | arch/sparc/kernel/tsb.S | 6 |
3 files changed, 8 insertions, 7 deletions
diff --git a/arch/sparc/include/asm/thread_info_64.h b/arch/sparc/include/asm/thread_info_64.h index f85dc8512ab3..cc6275c931a5 100644 --- a/arch/sparc/include/asm/thread_info_64.h +++ b/arch/sparc/include/asm/thread_info_64.h | |||
@@ -63,7 +63,8 @@ struct thread_info { | |||
63 | struct pt_regs *kern_una_regs; | 63 | struct pt_regs *kern_una_regs; |
64 | unsigned int kern_una_insn; | 64 | unsigned int kern_una_insn; |
65 | 65 | ||
66 | unsigned long fpregs[0] __attribute__ ((aligned(64))); | 66 | unsigned long fpregs[(7 * 256) / sizeof(unsigned long)] |
67 | __attribute__ ((aligned(64))); | ||
67 | }; | 68 | }; |
68 | 69 | ||
69 | #endif /* !(__ASSEMBLY__) */ | 70 | #endif /* !(__ASSEMBLY__) */ |
diff --git a/arch/sparc/kernel/dtlb_prot.S b/arch/sparc/kernel/dtlb_prot.S index b2c2c5be281c..d668ca149e64 100644 --- a/arch/sparc/kernel/dtlb_prot.S +++ b/arch/sparc/kernel/dtlb_prot.S | |||
@@ -24,11 +24,11 @@ | |||
24 | mov TLB_TAG_ACCESS, %g4 ! For reload of vaddr | 24 | mov TLB_TAG_ACCESS, %g4 ! For reload of vaddr |
25 | 25 | ||
26 | /* PROT ** ICACHE line 2: More real fault processing */ | 26 | /* PROT ** ICACHE line 2: More real fault processing */ |
27 | ldxa [%g4] ASI_DMMU, %g5 ! Put tagaccess in %g5 | ||
27 | bgu,pn %xcc, winfix_trampoline ! Yes, perform winfixup | 28 | bgu,pn %xcc, winfix_trampoline ! Yes, perform winfixup |
28 | ldxa [%g4] ASI_DMMU, %g5 ! Put tagaccess in %g5 | ||
29 | ba,pt %xcc, sparc64_realfault_common ! Nope, normal fault | ||
30 | mov FAULT_CODE_DTLB | FAULT_CODE_WRITE, %g4 | 29 | mov FAULT_CODE_DTLB | FAULT_CODE_WRITE, %g4 |
31 | nop | 30 | ba,pt %xcc, sparc64_realfault_common ! Nope, normal fault |
31 | nop | ||
32 | nop | 32 | nop |
33 | nop | 33 | nop |
34 | nop | 34 | nop |
diff --git a/arch/sparc/kernel/tsb.S b/arch/sparc/kernel/tsb.S index 14158d40ba76..be98685c14c6 100644 --- a/arch/sparc/kernel/tsb.S +++ b/arch/sparc/kernel/tsb.S | |||
@@ -162,10 +162,10 @@ tsb_miss_page_table_walk_sun4v_fastpath: | |||
162 | nop | 162 | nop |
163 | .previous | 163 | .previous |
164 | 164 | ||
165 | rdpr %tl, %g3 | 165 | rdpr %tl, %g7 |
166 | cmp %g3, 1 | 166 | cmp %g7, 1 |
167 | bne,pn %xcc, winfix_trampoline | 167 | bne,pn %xcc, winfix_trampoline |
168 | nop | 168 | mov %g3, %g4 |
169 | ba,pt %xcc, etrap | 169 | ba,pt %xcc, etrap |
170 | rd %pc, %g7 | 170 | rd %pc, %g7 |
171 | call hugetlb_setup | 171 | call hugetlb_setup |