glue.h 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. /*
  2. * arch/arm/include/asm/glue.h
  3. *
  4. * Copyright (C) 1997-1999 Russell King
  5. * Copyright (C) 2000-2002 Deep Blue Solutions Ltd.
  6. *
  7. * This program is free software; you can redistribute it and/or modify
  8. * it under the terms of the GNU General Public License version 2 as
  9. * published by the Free Software Foundation.
  10. *
  11. * This file provides the glue to stick the processor-specific bits
  12. * into the kernel in an efficient manner. The idea is to use branches
  13. * when we're only targetting one class of TLB, or indirect calls
  14. * when we're targetting multiple classes of TLBs.
  15. */
  16. #ifdef __KERNEL__
  17. #ifdef __STDC__
  18. #define ____glue(name,fn) name##fn
  19. #else
  20. #define ____glue(name,fn) name/**/fn
  21. #endif
  22. #define __glue(name,fn) ____glue(name,fn)
  23. /*
  24. * Data Abort Model
  25. * ================
  26. *
  27. * We have the following to choose from:
  28. * arm6 - ARM6 style
  29. * arm7 - ARM7 style
  30. * v4_early - ARMv4 without Thumb early abort handler
  31. * v4t_late - ARMv4 with Thumb late abort handler
  32. * v4t_early - ARMv4 with Thumb early abort handler
  33. * v5tej_early - ARMv5 with Thumb and Java early abort handler
  34. * xscale - ARMv5 with Thumb with Xscale extensions
  35. * v6_early - ARMv6 generic early abort handler
  36. * v7_early - ARMv7 generic early abort handler
  37. */
  38. #undef CPU_DABORT_HANDLER
  39. #undef MULTI_DABORT
  40. #if defined(CONFIG_CPU_ARM610)
  41. # ifdef CPU_DABORT_HANDLER
  42. # define MULTI_DABORT 1
  43. # else
  44. # define CPU_DABORT_HANDLER cpu_arm6_data_abort
  45. # endif
  46. #endif
  47. #if defined(CONFIG_CPU_ARM710)
  48. # ifdef CPU_DABORT_HANDLER
  49. # define MULTI_DABORT 1
  50. # else
  51. # define CPU_DABORT_HANDLER cpu_arm7_data_abort
  52. # endif
  53. #endif
  54. #ifdef CONFIG_CPU_ABRT_LV4T
  55. # ifdef CPU_DABORT_HANDLER
  56. # define MULTI_DABORT 1
  57. # else
  58. # define CPU_DABORT_HANDLER v4t_late_abort
  59. # endif
  60. #endif
  61. #ifdef CONFIG_CPU_ABRT_EV4
  62. # ifdef CPU_DABORT_HANDLER
  63. # define MULTI_DABORT 1
  64. # else
  65. # define CPU_DABORT_HANDLER v4_early_abort
  66. # endif
  67. #endif
  68. #ifdef CONFIG_CPU_ABRT_EV4T
  69. # ifdef CPU_DABORT_HANDLER
  70. # define MULTI_DABORT 1
  71. # else
  72. # define CPU_DABORT_HANDLER v4t_early_abort
  73. # endif
  74. #endif
  75. #ifdef CONFIG_CPU_ABRT_EV5TJ
  76. # ifdef CPU_DABORT_HANDLER
  77. # define MULTI_DABORT 1
  78. # else
  79. # define CPU_DABORT_HANDLER v5tj_early_abort
  80. # endif
  81. #endif
  82. #ifdef CONFIG_CPU_ABRT_EV5T
  83. # ifdef CPU_DABORT_HANDLER
  84. # define MULTI_DABORT 1
  85. # else
  86. # define CPU_DABORT_HANDLER v5t_early_abort
  87. # endif
  88. #endif
  89. #ifdef CONFIG_CPU_ABRT_EV6
  90. # ifdef CPU_DABORT_HANDLER
  91. # define MULTI_DABORT 1
  92. # else
  93. # define CPU_DABORT_HANDLER v6_early_abort
  94. # endif
  95. #endif
  96. #ifdef CONFIG_CPU_ABRT_EV7
  97. # ifdef CPU_DABORT_HANDLER
  98. # define MULTI_DABORT 1
  99. # else
  100. # define CPU_DABORT_HANDLER v7_early_abort
  101. # endif
  102. #endif
  103. #ifndef CPU_DABORT_HANDLER
  104. #error Unknown data abort handler type
  105. #endif
  106. /*
  107. * Prefetch abort handler. If the CPU has an IFAR use that, otherwise
  108. * use the address of the aborted instruction
  109. */
  110. #undef CPU_PABORT_HANDLER
  111. #undef MULTI_PABORT
  112. #ifdef CONFIG_CPU_PABRT_IFAR
  113. # ifdef CPU_PABORT_HANDLER
  114. # define MULTI_PABORT 1
  115. # else
  116. # define CPU_PABORT_HANDLER(reg, insn) mrc p15, 0, reg, cr6, cr0, 2
  117. # endif
  118. #endif
  119. #ifdef CONFIG_CPU_PABRT_NOIFAR
  120. # ifdef CPU_PABORT_HANDLER
  121. # define MULTI_PABORT 1
  122. # else
  123. # define CPU_PABORT_HANDLER(reg, insn) mov reg, insn
  124. # endif
  125. #endif
  126. #ifndef CPU_PABORT_HANDLER
  127. #error Unknown prefetch abort handler type
  128. #endif
  129. #endif