1
0

vector_gcc.S 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. /*
  2. * Copyright (c) 2020, Shenzhen Academy of Aerospace Technology
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2020-10-16 Dystopia the first version
  9. */
  10. #define TRAPL(H) mov %g0, %l0; sethi %hi(H), %l4; jmp %l4 + %lo(H); nop;
  11. #define TRAP(H) mov %psr, %l0; sethi %hi(H), %l4; jmp %l4 + %lo(H); nop;
  12. #define TRAP_ENTRY(H) mov %psr, %l0; sethi %hi(H), %l4; jmp %l4 + %lo(H); mov %tbr, %l3;
  13. #define BAD_TRAP ta 0; nop; nop; nop;
  14. #define SOFT_TRAP BAD_TRAP
  15. #define NWINDOWS 8
  16. .section .vectors, "ax"
  17. .globl _ISR_Handler
  18. .globl _window_overflow
  19. .globl _window_underflow
  20. .globl _reset
  21. .globl _context_switch
  22. .globl system_vectors
  23. system_vectors:
  24. TRAPL(_reset); ! 00 reset trap
  25. BAD_TRAP; ! 01 instruction_access_exception
  26. BAD_TRAP; ! 02 illegal_instruction
  27. BAD_TRAP; ! 03 priveleged_instruction
  28. BAD_TRAP;
  29. TRAP(_window_overflow); ! 05 window_overflow
  30. TRAP(_window_underflow); ! 06 window_underflow
  31. BAD_TRAP; ! 07 memory_add0ress_not_aligned
  32. BAD_TRAP; ! 08 fp_exception
  33. BAD_TRAP; ! 09 data_access_exception
  34. BAD_TRAP; ! 0A tag_overflow
  35. BAD_TRAP; ! 0B undefined
  36. BAD_TRAP; ! 0C undefined
  37. BAD_TRAP; ! 0D undefined
  38. BAD_TRAP; ! 0E undefined
  39. BAD_TRAP; ! 0F undefined
  40. BAD_TRAP; ! 10 undefined
  41. /* Interrupt entries */
  42. TRAP_ENTRY(_ISR_Handler) ! 11 interrupt level 1
  43. TRAP_ENTRY(_ISR_Handler) ! 12 interrupt level 2
  44. TRAP_ENTRY(_ISR_Handler) ! 13 interrupt level 3
  45. TRAP_ENTRY(_ISR_Handler) ! 14 interrupt level 4
  46. TRAP_ENTRY(_ISR_Handler) ! 15 interrupt level 5
  47. TRAP_ENTRY(_ISR_Handler) ! 16 interrupt level 6
  48. TRAP_ENTRY(_ISR_Handler) ! 17 interrupt level 7
  49. TRAP_ENTRY(_ISR_Handler) ! 18 interrupt level 8
  50. TRAP_ENTRY(_ISR_Handler) ! 19 interrupt level 9
  51. TRAP_ENTRY(_ISR_Handler) ! 1A interrupt level 1
  52. TRAP_ENTRY(_ISR_Handler) ! 1B interrupt level 11
  53. TRAP_ENTRY(_ISR_Handler) ! 1C interrupt level 12
  54. TRAP_ENTRY(_ISR_Handler) ! 1D interrupt level 13
  55. TRAP_ENTRY(_ISR_Handler) ! 1E interrupt level 14
  56. TRAP_ENTRY(_ISR_Handler) ! 1F interrupt level 15
  57. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 20 - 23 undefined
  58. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 24 - 27 undefined
  59. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 28 - 2B undefined
  60. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 2C - 2F undefined
  61. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 30 - 33 undefined
  62. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 34 - 37 undefined
  63. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 38 - 3B undefined
  64. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 3C - 3F undefined
  65. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 40 - 43 undefined
  66. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 44 - 47 undefined
  67. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 48 - 4B undefined
  68. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 4C - 4F undefined
  69. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 50 - 53 undefined
  70. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 54 - 57 undefined
  71. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 58 - 5B undefined
  72. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 5C - 5F undefined
  73. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 60 - 63 undefined
  74. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 64 - 67 undefined
  75. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 68 - 6B undefined
  76. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 6C - 6F undefined
  77. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 70 - 73 undefined
  78. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 74 - 77 undefined
  79. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 78 - 7B undefined
  80. BAD_TRAP; BAD_TRAP; BAD_TRAP; BAD_TRAP; ! 7C - 7F undefined
  81. /* Software traps */
  82. SOFT_TRAP; SOFT_TRAP; TRAP_ENTRY(_context_switch); TRAP_ENTRY(_context_switch) ! 80 - 83
  83. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 84 - 87
  84. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 88 - 8B
  85. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 8C - 8F
  86. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 90 - 93
  87. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 94 - 97
  88. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 98 - 9B
  89. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! 9C - 9F
  90. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! A0 - A3
  91. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! A4 - A7
  92. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! A8 - AB
  93. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! AC - AF
  94. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! B0 - B3
  95. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! B4 - B7
  96. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! B8 - BB
  97. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! BC - BF
  98. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! C0 - C3
  99. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! C4 - C7
  100. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! C8 - CB
  101. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! CC - CF
  102. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! D0 - D3
  103. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! D4 - D7
  104. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! D8 - DB
  105. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! DC - DF
  106. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! E0 - E3
  107. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! E4 - E7
  108. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! E8 - EB
  109. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! EC - EF
  110. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! F0 - F3
  111. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! F4 - F7
  112. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! F8 - FB
  113. SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; SOFT_TRAP; ! FC - FF
  114. _window_overflow:
  115. mov %wim, %l3 ! Calculate next WIM
  116. mov %g1, %l7
  117. srl %l3, 1, %g1
  118. sll %l3, NWINDOWS - 1, %l4
  119. or %l4, %g1, %g1
  120. save ! Get into window to be saved.
  121. mov %g1, %wim
  122. nop
  123. nop
  124. nop
  125. std %l0, [%sp + 0]
  126. std %l2, [%sp + 8]
  127. std %l4, [%sp + 16]
  128. std %l6, [%sp + 24]
  129. std %i0, [%sp + 32]
  130. std %i2, [%sp + 40]
  131. std %i4, [%sp + 48]
  132. std %i6, [%sp + 56]
  133. restore ! Go back to trap window.
  134. mov %l7, %g1
  135. jmp %l1 ! Re-execute save.
  136. rett %l2
  137. _window_underflow:
  138. mov %wim, %l3 ! Calculate next WIM
  139. sll %l3, 1, %l4
  140. srl %l3, NWINDOWS - 1, %l5
  141. or %l5, %l4, %l5
  142. mov %l5, %wim
  143. nop
  144. nop
  145. nop
  146. restore ! Two restores to get into the
  147. restore ! window to restore
  148. ldd [%sp + 0], %l0 ! Restore window from the stack
  149. ldd [%sp + 8], %l2
  150. ldd [%sp + 16], %l4
  151. ldd [%sp + 24], %l6
  152. ldd [%sp + 32], %i0
  153. ldd [%sp + 40], %i2
  154. ldd [%sp + 48], %i4
  155. ldd [%sp + 56], %i6
  156. save ! Get back to the trap window.
  157. save
  158. jmp %l1 ! Re-execute restore.
  159. rett %l2