aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid S. Miller <davem@davemloft.net>2005-08-29 15:44:57 -0400
committerDavid S. Miller <davem@davemloft.net>2005-08-29 15:44:57 -0400
commitbde4e4ee9f90142d550e2684dec2c8df302f5f8e (patch)
tree9ea03bd0e3cfe7ed1de41171dd5a906779b02e72
parent5ea68e02766c52c153c62fc423cda659a80e45fa (diff)
[SPARC64]: Do not call winfix_dax blindly
Verify we really are taking a data access exception trap, at TL1, from one of the window spill/fill handlers. Else call a new function, data_access_exception_tl1, to log the error. Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r--arch/sparc64/kernel/entry.S16
-rw-r--r--arch/sparc64/kernel/traps.c11
2 files changed, 27 insertions, 0 deletions
diff --git a/arch/sparc64/kernel/entry.S b/arch/sparc64/kernel/entry.S
index 6d0476ff4ff8..214cd0ebe832 100644
--- a/arch/sparc64/kernel/entry.S
+++ b/arch/sparc64/kernel/entry.S
@@ -701,8 +701,24 @@ __do_data_access_exception_tl1:
701 ldxa [%g5] ASI_DMMU, %g5 ! Get SFAR 701 ldxa [%g5] ASI_DMMU, %g5 ! Get SFAR
702 stxa %g0, [%g3] ASI_DMMU ! Clear SFSR.FaultValid bit 702 stxa %g0, [%g3] ASI_DMMU ! Clear SFSR.FaultValid bit
703 membar #Sync 703 membar #Sync
704 rdpr %tt, %g3
705 cmp %g3, 0x80 ! first win spill/fill trap
706 blu,pn %xcc, 1f
707 cmp %g3, 0xff ! last win spill/fill trap
708 bgu,pn %xcc, 1f
709 nop
704 ba,pt %xcc, winfix_dax 710 ba,pt %xcc, winfix_dax
705 rdpr %tpc, %g3 711 rdpr %tpc, %g3
7121: sethi %hi(109f), %g7
713 ba,pt %xcc, etraptl1
714109: or %g7, %lo(109b), %g7
715 mov %l4, %o1
716 mov %l5, %o2
717 call data_access_exception_tl1
718 add %sp, PTREGS_OFF, %o0
719 ba,pt %xcc, rtrap
720 clr %l6
721
706__do_data_access_exception: 722__do_data_access_exception:
707 rdpr %pstate, %g4 723 rdpr %pstate, %g4
708 wrpr %g4, PSTATE_MG|PSTATE_AG, %pstate 724 wrpr %g4, PSTATE_MG|PSTATE_AG, %pstate
diff --git a/arch/sparc64/kernel/traps.c b/arch/sparc64/kernel/traps.c
index 0c9e54b2f0c8..210b3e321c29 100644
--- a/arch/sparc64/kernel/traps.c
+++ b/arch/sparc64/kernel/traps.c
@@ -220,6 +220,17 @@ void data_access_exception(struct pt_regs *regs,
220 force_sig_info(SIGSEGV, &info, current); 220 force_sig_info(SIGSEGV, &info, current);
221} 221}
222 222
223void data_access_exception_tl1(struct pt_regs *regs,
224 unsigned long sfsr, unsigned long sfar)
225{
226 if (notify_die(DIE_TRAP_TL1, "data access exception tl1", regs,
227 0, 0x30, SIGTRAP) == NOTIFY_STOP)
228 return;
229
230 dump_tl1_traplog((struct tl1_traplog *)(regs + 1));
231 data_access_exception(regs, sfsr, sfar);
232}
233
223#ifdef CONFIG_PCI 234#ifdef CONFIG_PCI
224/* This is really pathetic... */ 235/* This is really pathetic... */
225extern volatile int pci_poke_in_progress; 236extern volatile int pci_poke_in_progress;