diff --git a/sys/sun4v/sun4v/exception.S b/sys/sun4v/sun4v/exception.S index 4e3d9bcca18d..5115f979c6c2 100644 --- a/sys/sun4v/sun4v/exception.S +++ b/sys/sun4v/sun4v/exception.S @@ -1997,20 +1997,19 @@ ENTRY(tl1_trap) 4: wrpr %g0, %g7, %tnpc wrpr %g0, 1, %gl - rdpr %tt, %g5 + rdpr %tt, %g2 GET_MMFSA_SCRATCH(%g7) wr %g0, ASI_REAL, %asi - ldxa [%g7 + MMFSA_D_ADDR]%asi, %g6 + ldxa [%g7 + MMFSA_D_ADDR]%asi, %g3 ldxa [%g7 + MMFSA_D_CTX]%asi, %g7 - cmp %g5, T_ALIGNMENT - be,pn %xcc, 5f - nop - srlx %g6, PAGE_SHIFT, %g6 - sllx %g6, PAGE_SHIFT, %g6 ! mask off bottom - or %g6, %g7, %g6 + ! XXX we're only handling page faults here + srlx %g3, PAGE_SHIFT, %g3 + sllx %g3, PAGE_SHIFT, %g3 ! mask off bottom + or %g3, %g7, %g3 done -5: +#ifdef notyet sllx %g7, TRAP_CTX_SHIFT, %g7 or %g7, %g5, %g5 done +#endif END(tl1_trap) diff --git a/sys/sun4v/sun4v/wbuf.S b/sys/sun4v/sun4v/wbuf.S index 482ec52308e0..b4b27a1d4a24 100644 --- a/sys/sun4v/sun4v/wbuf.S +++ b/sys/sun4v/sun4v/wbuf.S @@ -32,21 +32,19 @@ END(fault_32bit_so1) ENTRY(fault_64bit_sn0) GET_PCB(%g4) stx %sp, [%g4 + PCB_RWSP] - add %g4, PCB_RW, %g3 - SAVE_WINDOW(%g3) - mov 1, %g3 - stx %g3, [%g4 + PCB_NSAVED] + add %g4, PCB_RW, %g5 + SAVE_WINDOW(%g5) + mov 1, %g5 + stx %g5, [%g4 + PCB_NSAVED] ! convert hardware trap type to kernel trap type set trap_conversion, %g1 - sllx %g5, INT_SHIFT, %g5 - ld [%g1 + %g5], %g2 + sllx %g2, INT_SHIFT, %g2 + ld [%g1 + %g2], %g2 set trap, %g1 - mov %g6, %g3 sub %g0, 1, %g4 - rdpr %tstate, %g5 and %g5, TSTATE_CWP_MASK, %g5 ba,pt %xcc, tl0_utrap @@ -129,12 +127,6 @@ ENTRY(fault_32bit_fn0) MAGIC_TRAP_ON MAGIC_EXIT fault_fn0_common: - mov %g6, %g3 - mov T_DATA_MISS, %g2 - cmp %g5, T_ALIGNMENT - beq,a,pn %xcc, 1f - mov T_ALIGNMENT, %g2 -1: set trap, %g1 sub %g0, 1, %g4 rdpr %tstate, %g5 @@ -166,14 +158,13 @@ fault_fn1_common: ! convert hardware trap type to kernel trap type set trap_conversion, %g1 - sllx %g5, INT_SHIFT, %g5 - ld [%g1 + %g5], %g5 + sllx %g2, INT_SHIFT, %g2 + ld [%g1 + %g2], %g2 set trap, %g1 - mov 1, %g2 - sllx %g2, CTX_OTHER_SHIFT, %g2 + mov 1, %g5 + sllx %g5, CTX_OTHER_SHIFT, %g5 or %g5, %g2, %g2 - mov %g6, %g3 sub %g0, 1, %g4 rdpr %wstate, %l1