utrap.S 576 B

123456789101112131415161718192021222324252627282930
  1. .globl utrap_trap
  2. .type utrap_trap,#function
  3. utrap_trap: /* %g3=handler,%g4=level */
  4. TRAP_LOAD_THREAD_REG(%g6, %g1)
  5. ldx [%g6 + TI_UTRAPS], %g1
  6. brnz,pt %g1, invoke_utrap
  7. nop
  8. ba,pt %xcc, etrap
  9. rd %pc, %g7
  10. mov %l4, %o1
  11. call bad_trap
  12. add %sp, PTREGS_OFF, %o0
  13. ba,pt %xcc, rtrap
  14. nop
  15. invoke_utrap:
  16. sllx %g3, 3, %g3
  17. ldx [%g1 + %g3], %g1
  18. save %sp, -128, %sp
  19. rdpr %tstate, %l6
  20. rdpr %cwp, %l7
  21. andn %l6, TSTATE_CWP, %l6
  22. wrpr %l6, %l7, %tstate
  23. rdpr %tpc, %l6
  24. rdpr %tnpc, %l7
  25. wrpr %g1, 0, %tnpc
  26. done
  27. .size utrap_trap,.-utrap_trap