arm-gic-v3.h 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200
  1. /*
  2. * Copyright (C) 2013, 2014 ARM Limited, All Rights Reserved.
  3. * Author: Marc Zyngier <marc.zyngier@arm.com>
  4. *
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * You should have received a copy of the GNU General Public License
  16. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  17. */
  18. #ifndef __LINUX_IRQCHIP_ARM_GIC_V3_H
  19. #define __LINUX_IRQCHIP_ARM_GIC_V3_H
  20. #include <asm/sysreg.h>
  21. /*
  22. * Distributor registers. We assume we're running non-secure, with ARE
  23. * being set. Secure-only and non-ARE registers are not described.
  24. */
  25. #define GICD_CTLR 0x0000
  26. #define GICD_TYPER 0x0004
  27. #define GICD_IIDR 0x0008
  28. #define GICD_STATUSR 0x0010
  29. #define GICD_SETSPI_NSR 0x0040
  30. #define GICD_CLRSPI_NSR 0x0048
  31. #define GICD_SETSPI_SR 0x0050
  32. #define GICD_CLRSPI_SR 0x0058
  33. #define GICD_SEIR 0x0068
  34. #define GICD_ISENABLER 0x0100
  35. #define GICD_ICENABLER 0x0180
  36. #define GICD_ISPENDR 0x0200
  37. #define GICD_ICPENDR 0x0280
  38. #define GICD_ISACTIVER 0x0300
  39. #define GICD_ICACTIVER 0x0380
  40. #define GICD_IPRIORITYR 0x0400
  41. #define GICD_ICFGR 0x0C00
  42. #define GICD_IROUTER 0x6000
  43. #define GICD_PIDR2 0xFFE8
  44. #define GICD_CTLR_RWP (1U << 31)
  45. #define GICD_CTLR_ARE_NS (1U << 4)
  46. #define GICD_CTLR_ENABLE_G1A (1U << 1)
  47. #define GICD_CTLR_ENABLE_G1 (1U << 0)
  48. #define GICD_IROUTER_SPI_MODE_ONE (0U << 31)
  49. #define GICD_IROUTER_SPI_MODE_ANY (1U << 31)
  50. #define GIC_PIDR2_ARCH_MASK 0xf0
  51. #define GIC_PIDR2_ARCH_GICv3 0x30
  52. #define GIC_PIDR2_ARCH_GICv4 0x40
  53. /*
  54. * Re-Distributor registers, offsets from RD_base
  55. */
  56. #define GICR_CTLR GICD_CTLR
  57. #define GICR_IIDR 0x0004
  58. #define GICR_TYPER 0x0008
  59. #define GICR_STATUSR GICD_STATUSR
  60. #define GICR_WAKER 0x0014
  61. #define GICR_SETLPIR 0x0040
  62. #define GICR_CLRLPIR 0x0048
  63. #define GICR_SEIR GICD_SEIR
  64. #define GICR_PROPBASER 0x0070
  65. #define GICR_PENDBASER 0x0078
  66. #define GICR_INVLPIR 0x00A0
  67. #define GICR_INVALLR 0x00B0
  68. #define GICR_SYNCR 0x00C0
  69. #define GICR_MOVLPIR 0x0100
  70. #define GICR_MOVALLR 0x0110
  71. #define GICR_PIDR2 GICD_PIDR2
  72. #define GICR_WAKER_ProcessorSleep (1U << 1)
  73. #define GICR_WAKER_ChildrenAsleep (1U << 2)
  74. /*
  75. * Re-Distributor registers, offsets from SGI_base
  76. */
  77. #define GICR_ISENABLER0 GICD_ISENABLER
  78. #define GICR_ICENABLER0 GICD_ICENABLER
  79. #define GICR_ISPENDR0 GICD_ISPENDR
  80. #define GICR_ICPENDR0 GICD_ICPENDR
  81. #define GICR_ISACTIVER0 GICD_ISACTIVER
  82. #define GICR_ICACTIVER0 GICD_ICACTIVER
  83. #define GICR_IPRIORITYR0 GICD_IPRIORITYR
  84. #define GICR_ICFGR0 GICD_ICFGR
  85. #define GICR_TYPER_VLPIS (1U << 1)
  86. #define GICR_TYPER_LAST (1U << 4)
  87. /*
  88. * CPU interface registers
  89. */
  90. #define ICC_CTLR_EL1_EOImode_drop_dir (0U << 1)
  91. #define ICC_CTLR_EL1_EOImode_drop (1U << 1)
  92. #define ICC_SRE_EL1_SRE (1U << 0)
  93. /*
  94. * Hypervisor interface registers (SRE only)
  95. */
  96. #define ICH_LR_VIRTUAL_ID_MASK ((1UL << 32) - 1)
  97. #define ICH_LR_EOI (1UL << 41)
  98. #define ICH_LR_GROUP (1UL << 60)
  99. #define ICH_LR_STATE (3UL << 62)
  100. #define ICH_LR_PENDING_BIT (1UL << 62)
  101. #define ICH_LR_ACTIVE_BIT (1UL << 63)
  102. #define ICH_MISR_EOI (1 << 0)
  103. #define ICH_MISR_U (1 << 1)
  104. #define ICH_HCR_EN (1 << 0)
  105. #define ICH_HCR_UIE (1 << 1)
  106. #define ICH_VMCR_CTLR_SHIFT 0
  107. #define ICH_VMCR_CTLR_MASK (0x21f << ICH_VMCR_CTLR_SHIFT)
  108. #define ICH_VMCR_BPR1_SHIFT 18
  109. #define ICH_VMCR_BPR1_MASK (7 << ICH_VMCR_BPR1_SHIFT)
  110. #define ICH_VMCR_BPR0_SHIFT 21
  111. #define ICH_VMCR_BPR0_MASK (7 << ICH_VMCR_BPR0_SHIFT)
  112. #define ICH_VMCR_PMR_SHIFT 24
  113. #define ICH_VMCR_PMR_MASK (0xffUL << ICH_VMCR_PMR_SHIFT)
  114. #define ICC_EOIR1_EL1 sys_reg(3, 0, 12, 12, 1)
  115. #define ICC_IAR1_EL1 sys_reg(3, 0, 12, 12, 0)
  116. #define ICC_SGI1R_EL1 sys_reg(3, 0, 12, 11, 5)
  117. #define ICC_PMR_EL1 sys_reg(3, 0, 4, 6, 0)
  118. #define ICC_CTLR_EL1 sys_reg(3, 0, 12, 12, 4)
  119. #define ICC_SRE_EL1 sys_reg(3, 0, 12, 12, 5)
  120. #define ICC_GRPEN1_EL1 sys_reg(3, 0, 12, 12, 7)
  121. #define ICC_IAR1_EL1_SPURIOUS 0x3ff
  122. #define ICC_SRE_EL2 sys_reg(3, 4, 12, 9, 5)
  123. #define ICC_SRE_EL2_SRE (1 << 0)
  124. #define ICC_SRE_EL2_ENABLE (1 << 3)
  125. /*
  126. * System register definitions
  127. */
  128. #define ICH_VSEIR_EL2 sys_reg(3, 4, 12, 9, 4)
  129. #define ICH_HCR_EL2 sys_reg(3, 4, 12, 11, 0)
  130. #define ICH_VTR_EL2 sys_reg(3, 4, 12, 11, 1)
  131. #define ICH_MISR_EL2 sys_reg(3, 4, 12, 11, 2)
  132. #define ICH_EISR_EL2 sys_reg(3, 4, 12, 11, 3)
  133. #define ICH_ELSR_EL2 sys_reg(3, 4, 12, 11, 5)
  134. #define ICH_VMCR_EL2 sys_reg(3, 4, 12, 11, 7)
  135. #define __LR0_EL2(x) sys_reg(3, 4, 12, 12, x)
  136. #define __LR8_EL2(x) sys_reg(3, 4, 12, 13, x)
  137. #define ICH_LR0_EL2 __LR0_EL2(0)
  138. #define ICH_LR1_EL2 __LR0_EL2(1)
  139. #define ICH_LR2_EL2 __LR0_EL2(2)
  140. #define ICH_LR3_EL2 __LR0_EL2(3)
  141. #define ICH_LR4_EL2 __LR0_EL2(4)
  142. #define ICH_LR5_EL2 __LR0_EL2(5)
  143. #define ICH_LR6_EL2 __LR0_EL2(6)
  144. #define ICH_LR7_EL2 __LR0_EL2(7)
  145. #define ICH_LR8_EL2 __LR8_EL2(0)
  146. #define ICH_LR9_EL2 __LR8_EL2(1)
  147. #define ICH_LR10_EL2 __LR8_EL2(2)
  148. #define ICH_LR11_EL2 __LR8_EL2(3)
  149. #define ICH_LR12_EL2 __LR8_EL2(4)
  150. #define ICH_LR13_EL2 __LR8_EL2(5)
  151. #define ICH_LR14_EL2 __LR8_EL2(6)
  152. #define ICH_LR15_EL2 __LR8_EL2(7)
  153. #define __AP0Rx_EL2(x) sys_reg(3, 4, 12, 8, x)
  154. #define ICH_AP0R0_EL2 __AP0Rx_EL2(0)
  155. #define ICH_AP0R1_EL2 __AP0Rx_EL2(1)
  156. #define ICH_AP0R2_EL2 __AP0Rx_EL2(2)
  157. #define ICH_AP0R3_EL2 __AP0Rx_EL2(3)
  158. #define __AP1Rx_EL2(x) sys_reg(3, 4, 12, 9, x)
  159. #define ICH_AP1R0_EL2 __AP1Rx_EL2(0)
  160. #define ICH_AP1R1_EL2 __AP1Rx_EL2(1)
  161. #define ICH_AP1R2_EL2 __AP1Rx_EL2(2)
  162. #define ICH_AP1R3_EL2 __AP1Rx_EL2(3)
  163. #ifndef __ASSEMBLY__
  164. #include <linux/stringify.h>
  165. static inline void gic_write_eoir(u64 irq)
  166. {
  167. asm volatile("msr_s " __stringify(ICC_EOIR1_EL1) ", %0" : : "r" (irq));
  168. isb();
  169. }
  170. #endif
  171. #endif