alt_exception_trap.S 3.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. /******************************************************************************
  2. * *
  3. * License Agreement *
  4. * *
  5. * Copyright (c) 2003-2005 Altera Corporation, San Jose, California, USA. *
  6. * All rights reserved. *
  7. * *
  8. * Permission is hereby granted, free of charge, to any person obtaining a *
  9. * copy of this software and associated documentation files (the "Software"), *
  10. * to deal in the Software without restriction, including without limitation *
  11. * the rights to use, copy, modify, merge, publish, distribute, sublicense, *
  12. * and/or sell copies of the Software, and to permit persons to whom the *
  13. * Software is furnished to do so, subject to the following conditions: *
  14. * *
  15. * The above copyright notice and this permission notice shall be included in *
  16. * all copies or substantial portions of the Software. *
  17. * *
  18. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR *
  19. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, *
  20. * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE *
  21. * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER *
  22. * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING *
  23. * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER *
  24. * DEALINGS IN THE SOFTWARE. *
  25. * *
  26. * This agreement shall be governed in all respects by the laws of the State *
  27. * of California and by the laws of the United States of America. *
  28. * *
  29. ******************************************************************************/
  30. /*
  31. * This is the trap exception handler for Nios2.
  32. */
  33. /*
  34. * Provide a label which can be used to pull this file in.
  35. */
  36. .section .exceptions.start
  37. .globl alt_exception_trap
  38. alt_exception_trap:
  39. /*
  40. * Pull in the entry/exit code.
  41. */
  42. .globl alt_exception
  43. .section .exceptions.soft, "xa"
  44. .Ltrap_handler:
  45. /*
  46. * Did a trap instruction cause the exception?
  47. *
  48. * The instruction which the exception occurred on has been loaded
  49. * into r2 by code in alt_exception_entry.S
  50. *
  51. */
  52. #ifdef ALT_CPU_CPU_ARCH_NIOS2_R2
  53. movhi r3,0xb41d /* upper half of trap opcode */
  54. ori r3,r3,0x0020 /* lower half of trap opcode */
  55. beq r2,r3,.Lis_trap
  56. #ifdef NIOS2_CDX_PRESENT
  57. mov r3,r2
  58. andhi r3,r3,0xffff
  59. ori r3,r3,0xd009 /* trap.n opcode */
  60. beq r2,r3,.Lis_trap
  61. #endif
  62. br .Lnot_trap
  63. #else
  64. movhi r3,0x003b /* upper half of trap opcode */
  65. ori r3,r3,0x683a /* lower half of trap opcode */
  66. bne r2,r3,.Lnot_trap
  67. #endif
  68. .Lis_trap:
  69. /*
  70. * There is no trap handler defined here, and so executing a trap
  71. * instruction causes a software break. If you provide a trap handler,
  72. * then you must replace the break instruction below with your handler.
  73. * Your handler must preserve ea and the usual callee saved registers.
  74. */
  75. break
  76. br .Lexception_exit
  77. .Lnot_trap:
  78. .section .exceptions.exit.label
  79. .Lexception_exit: