uv_mmrs.h 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. /*
  2. * This file is subject to the terms and conditions of the GNU General Public
  3. * License. See the file "COPYING" in the main directory of this archive
  4. * for more details.
  5. *
  6. * SGI UV MMR definitions
  7. *
  8. * Copyright (C) 2007-2008 Silicon Graphics, Inc. All rights reserved.
  9. */
  10. #ifndef __ASM_X86_UV_MMRS__
  11. #define __ASM_X86_UV_MMRS__
  12. /*
  13. * AUTO GENERATED - Do not edit
  14. */
  15. #define UV_MMR_ENABLE (1UL << 63)
  16. /* ========================================================================= */
  17. /* UVH_IPI_INT */
  18. /* ========================================================================= */
  19. #define UVH_IPI_INT 0x60500UL
  20. #define UVH_IPI_INT_32 0x0360
  21. #define UVH_IPI_INT_VECTOR_SHFT 0
  22. #define UVH_IPI_INT_VECTOR_MASK 0x00000000000000ffUL
  23. #define UVH_IPI_INT_DELIVERY_MODE_SHFT 8
  24. #define UVH_IPI_INT_DELIVERY_MODE_MASK 0x0000000000000700UL
  25. #define UVH_IPI_INT_DESTMODE_SHFT 11
  26. #define UVH_IPI_INT_DESTMODE_MASK 0x0000000000000800UL
  27. #define UVH_IPI_INT_APIC_ID_SHFT 16
  28. #define UVH_IPI_INT_APIC_ID_MASK 0x0000ffffffff0000UL
  29. #define UVH_IPI_INT_SEND_SHFT 63
  30. #define UVH_IPI_INT_SEND_MASK 0x8000000000000000UL
  31. union uvh_ipi_int_u {
  32. unsigned long v;
  33. struct uvh_ipi_int_s {
  34. unsigned long vector_ : 8; /* RW */
  35. unsigned long delivery_mode : 3; /* RW */
  36. unsigned long destmode : 1; /* RW */
  37. unsigned long rsvd_12_15 : 4; /* */
  38. unsigned long apic_id : 32; /* RW */
  39. unsigned long rsvd_48_62 : 15; /* */
  40. unsigned long send : 1; /* WP */
  41. } s;
  42. };
  43. /* ========================================================================= */
  44. /* UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST */
  45. /* ========================================================================= */
  46. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST 0x320050UL
  47. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST_32 0x009f0
  48. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST_ADDRESS_SHFT 4
  49. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST_ADDRESS_MASK 0x000007fffffffff0UL
  50. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST_NODE_ID_SHFT 49
  51. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_FIRST_NODE_ID_MASK 0x7ffe000000000000UL
  52. union uvh_lb_bau_intd_payload_queue_first_u {
  53. unsigned long v;
  54. struct uvh_lb_bau_intd_payload_queue_first_s {
  55. unsigned long rsvd_0_3: 4; /* */
  56. unsigned long address : 39; /* RW */
  57. unsigned long rsvd_43_48: 6; /* */
  58. unsigned long node_id : 14; /* RW */
  59. unsigned long rsvd_63 : 1; /* */
  60. } s;
  61. };
  62. /* ========================================================================= */
  63. /* UVH_LB_BAU_INTD_PAYLOAD_QUEUE_LAST */
  64. /* ========================================================================= */
  65. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_LAST 0x320060UL
  66. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_LAST_32 0x009f8
  67. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_LAST_ADDRESS_SHFT 4
  68. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_LAST_ADDRESS_MASK 0x000007fffffffff0UL
  69. union uvh_lb_bau_intd_payload_queue_last_u {
  70. unsigned long v;
  71. struct uvh_lb_bau_intd_payload_queue_last_s {
  72. unsigned long rsvd_0_3: 4; /* */
  73. unsigned long address : 39; /* RW */
  74. unsigned long rsvd_43_63: 21; /* */
  75. } s;
  76. };
  77. /* ========================================================================= */
  78. /* UVH_LB_BAU_INTD_PAYLOAD_QUEUE_TAIL */
  79. /* ========================================================================= */
  80. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_TAIL 0x320070UL
  81. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_TAIL_32 0x00a00
  82. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_TAIL_ADDRESS_SHFT 4
  83. #define UVH_LB_BAU_INTD_PAYLOAD_QUEUE_TAIL_ADDRESS_MASK 0x000007fffffffff0UL
  84. union uvh_lb_bau_intd_payload_queue_tail_u {
  85. unsigned long v;
  86. struct uvh_lb_bau_intd_payload_queue_tail_s {
  87. unsigned long rsvd_0_3: 4; /* */
  88. unsigned long address : 39; /* RW */
  89. unsigned long rsvd_43_63: 21; /* */
  90. } s;
  91. };
  92. /* ========================================================================= */
  93. /* UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE */
  94. /* ========================================================================= */
  95. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE 0x320080UL
  96. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_0_SHFT 0
  97. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_0_MASK 0x0000000000000001UL
  98. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_1_SHFT 1
  99. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_1_MASK 0x0000000000000002UL
  100. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_2_SHFT 2
  101. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_2_MASK 0x0000000000000004UL
  102. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_3_SHFT 3
  103. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_3_MASK 0x0000000000000008UL
  104. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_4_SHFT 4
  105. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_4_MASK 0x0000000000000010UL
  106. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_5_SHFT 5
  107. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_5_MASK 0x0000000000000020UL
  108. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_6_SHFT 6
  109. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_6_MASK 0x0000000000000040UL
  110. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_7_SHFT 7
  111. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_PENDING_7_MASK 0x0000000000000080UL
  112. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_0_SHFT 8
  113. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_0_MASK 0x0000000000000100UL
  114. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_1_SHFT 9
  115. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_1_MASK 0x0000000000000200UL
  116. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_2_SHFT 10
  117. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_2_MASK 0x0000000000000400UL
  118. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_3_SHFT 11
  119. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_3_MASK 0x0000000000000800UL
  120. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_4_SHFT 12
  121. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_4_MASK 0x0000000000001000UL
  122. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_5_SHFT 13
  123. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_5_MASK 0x0000000000002000UL
  124. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_6_SHFT 14
  125. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_6_MASK 0x0000000000004000UL
  126. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_7_SHFT 15
  127. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_TIMEOUT_7_MASK 0x0000000000008000UL
  128. union uvh_lb_bau_intd_software_acknowledge_u {
  129. unsigned long v;
  130. struct uvh_lb_bau_intd_software_acknowledge_s {
  131. unsigned long pending_0 : 1; /* RW, W1C */
  132. unsigned long pending_1 : 1; /* RW, W1C */
  133. unsigned long pending_2 : 1; /* RW, W1C */
  134. unsigned long pending_3 : 1; /* RW, W1C */
  135. unsigned long pending_4 : 1; /* RW, W1C */
  136. unsigned long pending_5 : 1; /* RW, W1C */
  137. unsigned long pending_6 : 1; /* RW, W1C */
  138. unsigned long pending_7 : 1; /* RW, W1C */
  139. unsigned long timeout_0 : 1; /* RW, W1C */
  140. unsigned long timeout_1 : 1; /* RW, W1C */
  141. unsigned long timeout_2 : 1; /* RW, W1C */
  142. unsigned long timeout_3 : 1; /* RW, W1C */
  143. unsigned long timeout_4 : 1; /* RW, W1C */
  144. unsigned long timeout_5 : 1; /* RW, W1C */
  145. unsigned long timeout_6 : 1; /* RW, W1C */
  146. unsigned long timeout_7 : 1; /* RW, W1C */
  147. unsigned long rsvd_16_63: 48; /* */
  148. } s;
  149. };
  150. /* ========================================================================= */
  151. /* UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_ALIAS */
  152. /* ========================================================================= */
  153. #define UVH_LB_BAU_INTD_SOFTWARE_ACKNOWLEDGE_ALIAS 0x0000000000320088UL
  154. /* ========================================================================= */
  155. /* UVH_LB_BAU_SB_ACTIVATION_CONTROL */
  156. /* ========================================================================= */
  157. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL 0x320020UL
  158. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_32 0x009d8
  159. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_INDEX_SHFT 0
  160. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_INDEX_MASK 0x000000000000003fUL
  161. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_PUSH_SHFT 62
  162. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_PUSH_MASK 0x4000000000000000UL
  163. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_INIT_SHFT 63
  164. #define UVH_LB_BAU_SB_ACTIVATION_CONTROL_INIT_MASK 0x8000000000000000UL
  165. union uvh_lb_bau_sb_activation_control_u {
  166. unsigned long v;
  167. struct uvh_lb_bau_sb_activation_control_s {
  168. unsigned long index : 6; /* RW */
  169. unsigned long rsvd_6_61: 56; /* */
  170. unsigned long push : 1; /* WP */
  171. unsigned long init : 1; /* WP */
  172. } s;
  173. };
  174. /* ========================================================================= */
  175. /* UVH_LB_BAU_SB_ACTIVATION_STATUS_0 */
  176. /* ========================================================================= */
  177. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_0 0x320030UL
  178. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_0_32 0x009e0
  179. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_0_STATUS_SHFT 0
  180. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_0_STATUS_MASK 0xffffffffffffffffUL
  181. union uvh_lb_bau_sb_activation_status_0_u {
  182. unsigned long v;
  183. struct uvh_lb_bau_sb_activation_status_0_s {
  184. unsigned long status : 64; /* RW */
  185. } s;
  186. };
  187. /* ========================================================================= */
  188. /* UVH_LB_BAU_SB_ACTIVATION_STATUS_1 */
  189. /* ========================================================================= */
  190. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_1 0x320040UL
  191. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_1_32 0x009e8
  192. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_1_STATUS_SHFT 0
  193. #define UVH_LB_BAU_SB_ACTIVATION_STATUS_1_STATUS_MASK 0xffffffffffffffffUL
  194. union uvh_lb_bau_sb_activation_status_1_u {
  195. unsigned long v;
  196. struct uvh_lb_bau_sb_activation_status_1_s {
  197. unsigned long status : 64; /* RW */
  198. } s;
  199. };
  200. /* ========================================================================= */
  201. /* UVH_LB_BAU_SB_DESCRIPTOR_BASE */
  202. /* ========================================================================= */
  203. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE 0x320010UL
  204. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE_32 0x009d0
  205. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE_PAGE_ADDRESS_SHFT 12
  206. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE_PAGE_ADDRESS_MASK 0x000007fffffff000UL
  207. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE_NODE_ID_SHFT 49
  208. #define UVH_LB_BAU_SB_DESCRIPTOR_BASE_NODE_ID_MASK 0x7ffe000000000000UL
  209. union uvh_lb_bau_sb_descriptor_base_u {
  210. unsigned long v;
  211. struct uvh_lb_bau_sb_descriptor_base_s {
  212. unsigned long rsvd_0_11 : 12; /* */
  213. unsigned long page_address : 31; /* RW */
  214. unsigned long rsvd_43_48 : 6; /* */
  215. unsigned long node_id : 14; /* RW */
  216. unsigned long rsvd_63 : 1; /* */
  217. } s;
  218. };
  219. /* ========================================================================= */
  220. /* UVH_NODE_ID */
  221. /* ========================================================================= */
  222. #define UVH_NODE_ID 0x0UL
  223. #define UVH_NODE_ID_FORCE1_SHFT 0
  224. #define UVH_NODE_ID_FORCE1_MASK 0x0000000000000001UL
  225. #define UVH_NODE_ID_MANUFACTURER_SHFT 1
  226. #define UVH_NODE_ID_MANUFACTURER_MASK 0x0000000000000ffeUL
  227. #define UVH_NODE_ID_PART_NUMBER_SHFT 12
  228. #define UVH_NODE_ID_PART_NUMBER_MASK 0x000000000ffff000UL
  229. #define UVH_NODE_ID_REVISION_SHFT 28
  230. #define UVH_NODE_ID_REVISION_MASK 0x00000000f0000000UL
  231. #define UVH_NODE_ID_NODE_ID_SHFT 32
  232. #define UVH_NODE_ID_NODE_ID_MASK 0x00007fff00000000UL
  233. #define UVH_NODE_ID_NODES_PER_BIT_SHFT 48
  234. #define UVH_NODE_ID_NODES_PER_BIT_MASK 0x007f000000000000UL
  235. #define UVH_NODE_ID_NI_PORT_SHFT 56
  236. #define UVH_NODE_ID_NI_PORT_MASK 0x0f00000000000000UL
  237. union uvh_node_id_u {
  238. unsigned long v;
  239. struct uvh_node_id_s {
  240. unsigned long force1 : 1; /* RO */
  241. unsigned long manufacturer : 11; /* RO */
  242. unsigned long part_number : 16; /* RO */
  243. unsigned long revision : 4; /* RO */
  244. unsigned long node_id : 15; /* RW */
  245. unsigned long rsvd_47 : 1; /* */
  246. unsigned long nodes_per_bit : 7; /* RW */
  247. unsigned long rsvd_55 : 1; /* */
  248. unsigned long ni_port : 4; /* RO */
  249. unsigned long rsvd_60_63 : 4; /* */
  250. } s;
  251. };
  252. /* ========================================================================= */
  253. /* UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR */
  254. /* ========================================================================= */
  255. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR 0x1600010UL
  256. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_BASE_SHFT 28
  257. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_BASE_MASK 0x00003ffff0000000UL
  258. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_GR4_SHFT 46
  259. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_GR4_MASK 0x0000400000000000UL
  260. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_N_GRU_SHFT 52
  261. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_N_GRU_MASK 0x00f0000000000000UL
  262. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_ENABLE_SHFT 63
  263. #define UVH_RH_GAM_GRU_OVERLAY_CONFIG_MMR_ENABLE_MASK 0x8000000000000000UL
  264. union uvh_rh_gam_gru_overlay_config_mmr_u {
  265. unsigned long v;
  266. struct uvh_rh_gam_gru_overlay_config_mmr_s {
  267. unsigned long rsvd_0_27: 28; /* */
  268. unsigned long base : 18; /* RW */
  269. unsigned long gr4 : 1; /* RW */
  270. unsigned long rsvd_47_51: 5; /* */
  271. unsigned long n_gru : 4; /* RW */
  272. unsigned long rsvd_56_62: 7; /* */
  273. unsigned long enable : 1; /* RW */
  274. } s;
  275. };
  276. /* ========================================================================= */
  277. /* UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR */
  278. /* ========================================================================= */
  279. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR 0x1600028UL
  280. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_BASE_SHFT 26
  281. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_BASE_MASK 0x00003ffffc000000UL
  282. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_DUAL_HUB_SHFT 46
  283. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_DUAL_HUB_MASK 0x0000400000000000UL
  284. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_ENABLE_SHFT 63
  285. #define UVH_RH_GAM_MMR_OVERLAY_CONFIG_MMR_ENABLE_MASK 0x8000000000000000UL
  286. union uvh_rh_gam_mmr_overlay_config_mmr_u {
  287. unsigned long v;
  288. struct uvh_rh_gam_mmr_overlay_config_mmr_s {
  289. unsigned long rsvd_0_25: 26; /* */
  290. unsigned long base : 20; /* RW */
  291. unsigned long dual_hub : 1; /* RW */
  292. unsigned long rsvd_47_62: 16; /* */
  293. unsigned long enable : 1; /* RW */
  294. } s;
  295. };
  296. /* ========================================================================= */
  297. /* UVH_RTC */
  298. /* ========================================================================= */
  299. #define UVH_RTC 0x28000UL
  300. #define UVH_RTC_REAL_TIME_CLOCK_SHFT 0
  301. #define UVH_RTC_REAL_TIME_CLOCK_MASK 0x00ffffffffffffffUL
  302. union uvh_rtc_u {
  303. unsigned long v;
  304. struct uvh_rtc_s {
  305. unsigned long real_time_clock : 56; /* RW */
  306. unsigned long rsvd_56_63 : 8; /* */
  307. } s;
  308. };
  309. /* ========================================================================= */
  310. /* UVH_SI_ADDR_MAP_CONFIG */
  311. /* ========================================================================= */
  312. #define UVH_SI_ADDR_MAP_CONFIG 0xc80000UL
  313. #define UVH_SI_ADDR_MAP_CONFIG_M_SKT_SHFT 0
  314. #define UVH_SI_ADDR_MAP_CONFIG_M_SKT_MASK 0x000000000000003fUL
  315. #define UVH_SI_ADDR_MAP_CONFIG_N_SKT_SHFT 8
  316. #define UVH_SI_ADDR_MAP_CONFIG_N_SKT_MASK 0x0000000000000f00UL
  317. union uvh_si_addr_map_config_u {
  318. unsigned long v;
  319. struct uvh_si_addr_map_config_s {
  320. unsigned long m_skt : 6; /* RW */
  321. unsigned long rsvd_6_7: 2; /* */
  322. unsigned long n_skt : 4; /* RW */
  323. unsigned long rsvd_12_63: 52; /* */
  324. } s;
  325. };
  326. #endif /* __ASM_X86_UV_MMRS__ */