rsdumpinfo.c 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560
  1. // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
  2. /*******************************************************************************
  3. *
  4. * Module Name: rsdumpinfo - Tables used to display resource descriptors.
  5. *
  6. ******************************************************************************/
  7. #include <acpi/acpi.h>
  8. #include "accommon.h"
  9. #include "acresrc.h"
  10. #define _COMPONENT ACPI_RESOURCES
  11. ACPI_MODULE_NAME("rsdumpinfo")
  12. #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DISASSEMBLER) || defined(ACPI_DEBUGGER)
  13. #define ACPI_RSD_OFFSET(f) (u8) ACPI_OFFSET (union acpi_resource_data,f)
  14. #define ACPI_PRT_OFFSET(f) (u8) ACPI_OFFSET (struct acpi_pci_routing_table,f)
  15. #define ACPI_RSD_TABLE_SIZE(name) (sizeof(name) / sizeof (struct acpi_rsdump_info))
  16. /*******************************************************************************
  17. *
  18. * Resource Descriptor info tables
  19. *
  20. * Note: The first table entry must be a Title or Literal and must contain
  21. * the table length (number of table entries)
  22. *
  23. ******************************************************************************/
  24. struct acpi_rsdump_info acpi_rs_dump_irq[7] = {
  25. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_irq), "IRQ", NULL},
  26. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(irq.descriptor_length),
  27. "Descriptor Length", NULL},
  28. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(irq.triggering), "Triggering",
  29. acpi_gbl_he_decode},
  30. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(irq.polarity), "Polarity",
  31. acpi_gbl_ll_decode},
  32. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(irq.shareable), "Sharing",
  33. acpi_gbl_shr_decode},
  34. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(irq.interrupt_count),
  35. "Interrupt Count", NULL},
  36. {ACPI_RSD_SHORTLIST, ACPI_RSD_OFFSET(irq.interrupts[0]),
  37. "Interrupt List", NULL}
  38. };
  39. struct acpi_rsdump_info acpi_rs_dump_dma[6] = {
  40. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_dma), "DMA", NULL},
  41. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(dma.type), "Speed",
  42. acpi_gbl_typ_decode},
  43. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(dma.bus_master), "Mastering",
  44. acpi_gbl_bm_decode},
  45. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(dma.transfer), "Transfer Type",
  46. acpi_gbl_siz_decode},
  47. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(dma.channel_count), "Channel Count",
  48. NULL},
  49. {ACPI_RSD_SHORTLIST, ACPI_RSD_OFFSET(dma.channels[0]), "Channel List",
  50. NULL}
  51. };
  52. struct acpi_rsdump_info acpi_rs_dump_start_dpf[4] = {
  53. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_start_dpf),
  54. "Start-Dependent-Functions", NULL},
  55. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(start_dpf.descriptor_length),
  56. "Descriptor Length", NULL},
  57. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(start_dpf.compatibility_priority),
  58. "Compatibility Priority", acpi_gbl_config_decode},
  59. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(start_dpf.performance_robustness),
  60. "Performance/Robustness", acpi_gbl_config_decode}
  61. };
  62. struct acpi_rsdump_info acpi_rs_dump_end_dpf[1] = {
  63. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_end_dpf),
  64. "End-Dependent-Functions", NULL}
  65. };
  66. struct acpi_rsdump_info acpi_rs_dump_io[6] = {
  67. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_io), "I/O", NULL},
  68. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(io.io_decode), "Address Decoding",
  69. acpi_gbl_io_decode},
  70. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(io.minimum), "Address Minimum", NULL},
  71. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(io.maximum), "Address Maximum", NULL},
  72. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(io.alignment), "Alignment", NULL},
  73. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(io.address_length), "Address Length",
  74. NULL}
  75. };
  76. struct acpi_rsdump_info acpi_rs_dump_fixed_io[3] = {
  77. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_fixed_io),
  78. "Fixed I/O", NULL},
  79. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(fixed_io.address), "Address", NULL},
  80. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(fixed_io.address_length),
  81. "Address Length", NULL}
  82. };
  83. struct acpi_rsdump_info acpi_rs_dump_vendor[3] = {
  84. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_vendor),
  85. "Vendor Specific", NULL},
  86. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(vendor.byte_length), "Length", NULL},
  87. {ACPI_RSD_LONGLIST, ACPI_RSD_OFFSET(vendor.byte_data[0]), "Vendor Data",
  88. NULL}
  89. };
  90. struct acpi_rsdump_info acpi_rs_dump_end_tag[1] = {
  91. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_end_tag), "EndTag",
  92. NULL}
  93. };
  94. struct acpi_rsdump_info acpi_rs_dump_memory24[6] = {
  95. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_memory24),
  96. "24-Bit Memory Range", NULL},
  97. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(memory24.write_protect),
  98. "Write Protect", acpi_gbl_rw_decode},
  99. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(memory24.minimum), "Address Minimum",
  100. NULL},
  101. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(memory24.maximum), "Address Maximum",
  102. NULL},
  103. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(memory24.alignment), "Alignment",
  104. NULL},
  105. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(memory24.address_length),
  106. "Address Length", NULL}
  107. };
  108. struct acpi_rsdump_info acpi_rs_dump_memory32[6] = {
  109. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_memory32),
  110. "32-Bit Memory Range", NULL},
  111. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(memory32.write_protect),
  112. "Write Protect", acpi_gbl_rw_decode},
  113. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(memory32.minimum), "Address Minimum",
  114. NULL},
  115. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(memory32.maximum), "Address Maximum",
  116. NULL},
  117. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(memory32.alignment), "Alignment",
  118. NULL},
  119. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(memory32.address_length),
  120. "Address Length", NULL}
  121. };
  122. struct acpi_rsdump_info acpi_rs_dump_fixed_memory32[4] = {
  123. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_fixed_memory32),
  124. "32-Bit Fixed Memory Range", NULL},
  125. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(fixed_memory32.write_protect),
  126. "Write Protect", acpi_gbl_rw_decode},
  127. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(fixed_memory32.address), "Address",
  128. NULL},
  129. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(fixed_memory32.address_length),
  130. "Address Length", NULL}
  131. };
  132. struct acpi_rsdump_info acpi_rs_dump_address16[8] = {
  133. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_address16),
  134. "16-Bit WORD Address Space", NULL},
  135. {ACPI_RSD_ADDRESS, 0, NULL, NULL},
  136. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(address16.address.granularity),
  137. "Granularity", NULL},
  138. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(address16.address.minimum),
  139. "Address Minimum", NULL},
  140. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(address16.address.maximum),
  141. "Address Maximum", NULL},
  142. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(address16.address.translation_offset),
  143. "Translation Offset", NULL},
  144. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(address16.address.address_length),
  145. "Address Length", NULL},
  146. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(address16.resource_source), NULL, NULL}
  147. };
  148. struct acpi_rsdump_info acpi_rs_dump_address32[8] = {
  149. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_address32),
  150. "32-Bit DWORD Address Space", NULL},
  151. {ACPI_RSD_ADDRESS, 0, NULL, NULL},
  152. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(address32.address.granularity),
  153. "Granularity", NULL},
  154. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(address32.address.minimum),
  155. "Address Minimum", NULL},
  156. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(address32.address.maximum),
  157. "Address Maximum", NULL},
  158. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(address32.address.translation_offset),
  159. "Translation Offset", NULL},
  160. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(address32.address.address_length),
  161. "Address Length", NULL},
  162. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(address32.resource_source), NULL, NULL}
  163. };
  164. struct acpi_rsdump_info acpi_rs_dump_address64[8] = {
  165. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_address64),
  166. "64-Bit QWORD Address Space", NULL},
  167. {ACPI_RSD_ADDRESS, 0, NULL, NULL},
  168. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(address64.address.granularity),
  169. "Granularity", NULL},
  170. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(address64.address.minimum),
  171. "Address Minimum", NULL},
  172. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(address64.address.maximum),
  173. "Address Maximum", NULL},
  174. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(address64.address.translation_offset),
  175. "Translation Offset", NULL},
  176. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(address64.address.address_length),
  177. "Address Length", NULL},
  178. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(address64.resource_source), NULL, NULL}
  179. };
  180. struct acpi_rsdump_info acpi_rs_dump_ext_address64[8] = {
  181. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_ext_address64),
  182. "64-Bit Extended Address Space", NULL},
  183. {ACPI_RSD_ADDRESS, 0, NULL, NULL},
  184. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(ext_address64.address.granularity),
  185. "Granularity", NULL},
  186. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(ext_address64.address.minimum),
  187. "Address Minimum", NULL},
  188. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(ext_address64.address.maximum),
  189. "Address Maximum", NULL},
  190. {ACPI_RSD_UINT64,
  191. ACPI_RSD_OFFSET(ext_address64.address.translation_offset),
  192. "Translation Offset", NULL},
  193. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(ext_address64.address.address_length),
  194. "Address Length", NULL},
  195. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(ext_address64.type_specific),
  196. "Type-Specific Attribute", NULL}
  197. };
  198. struct acpi_rsdump_info acpi_rs_dump_ext_irq[8] = {
  199. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_ext_irq),
  200. "Extended IRQ", NULL},
  201. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(extended_irq.producer_consumer),
  202. "Type", acpi_gbl_consume_decode},
  203. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(extended_irq.triggering),
  204. "Triggering", acpi_gbl_he_decode},
  205. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(extended_irq.polarity), "Polarity",
  206. acpi_gbl_ll_decode},
  207. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(extended_irq.shareable), "Sharing",
  208. acpi_gbl_shr_decode},
  209. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(extended_irq.resource_source), NULL,
  210. NULL},
  211. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(extended_irq.interrupt_count),
  212. "Interrupt Count", NULL},
  213. {ACPI_RSD_DWORDLIST, ACPI_RSD_OFFSET(extended_irq.interrupts[0]),
  214. "Interrupt List", NULL}
  215. };
  216. struct acpi_rsdump_info acpi_rs_dump_generic_reg[6] = {
  217. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_generic_reg),
  218. "Generic Register", NULL},
  219. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(generic_reg.space_id), "Space ID",
  220. NULL},
  221. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(generic_reg.bit_width), "Bit Width",
  222. NULL},
  223. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(generic_reg.bit_offset), "Bit Offset",
  224. NULL},
  225. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(generic_reg.access_size),
  226. "Access Size", NULL},
  227. {ACPI_RSD_UINT64, ACPI_RSD_OFFSET(generic_reg.address), "Address", NULL}
  228. };
  229. struct acpi_rsdump_info acpi_rs_dump_gpio[16] = {
  230. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_gpio), "GPIO", NULL},
  231. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(gpio.revision_id), "RevisionId", NULL},
  232. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(gpio.connection_type),
  233. "ConnectionType", acpi_gbl_ct_decode},
  234. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(gpio.producer_consumer),
  235. "ProducerConsumer", acpi_gbl_consume_decode},
  236. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(gpio.pin_config), "PinConfig",
  237. acpi_gbl_ppc_decode},
  238. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(gpio.shareable), "Sharing",
  239. acpi_gbl_shr_decode},
  240. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(gpio.io_restriction),
  241. "IoRestriction", acpi_gbl_ior_decode},
  242. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(gpio.triggering), "Triggering",
  243. acpi_gbl_he_decode},
  244. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(gpio.polarity), "Polarity",
  245. acpi_gbl_ll_decode},
  246. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(gpio.drive_strength), "DriveStrength",
  247. NULL},
  248. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(gpio.debounce_timeout),
  249. "DebounceTimeout", NULL},
  250. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(gpio.resource_source),
  251. "ResourceSource", NULL},
  252. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(gpio.pin_table_length),
  253. "PinTableLength", NULL},
  254. {ACPI_RSD_WORDLIST, ACPI_RSD_OFFSET(gpio.pin_table), "PinTable", NULL},
  255. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(gpio.vendor_length), "VendorLength",
  256. NULL},
  257. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(gpio.vendor_data), "VendorData",
  258. NULL},
  259. };
  260. struct acpi_rsdump_info acpi_rs_dump_pin_function[10] = {
  261. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_pin_function),
  262. "PinFunction", NULL},
  263. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_function.revision_id),
  264. "RevisionId", NULL},
  265. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_function.pin_config), "PinConfig",
  266. acpi_gbl_ppc_decode},
  267. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_function.shareable), "Sharing",
  268. acpi_gbl_shr_decode},
  269. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_function.function_number),
  270. "FunctionNumber", NULL},
  271. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(pin_function.resource_source),
  272. "ResourceSource", NULL},
  273. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_function.pin_table_length),
  274. "PinTableLength", NULL},
  275. {ACPI_RSD_WORDLIST, ACPI_RSD_OFFSET(pin_function.pin_table), "PinTable",
  276. NULL},
  277. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_function.vendor_length),
  278. "VendorLength", NULL},
  279. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(pin_function.vendor_data),
  280. "VendorData", NULL},
  281. };
  282. struct acpi_rsdump_info acpi_rs_dump_pin_config[11] = {
  283. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_pin_config),
  284. "PinConfig", NULL},
  285. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_config.revision_id), "RevisionId",
  286. NULL},
  287. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_config.producer_consumer),
  288. "ProducerConsumer", acpi_gbl_consume_decode},
  289. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_config.shareable), "Sharing",
  290. acpi_gbl_shr_decode},
  291. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_config.pin_config_type),
  292. "PinConfigType", NULL},
  293. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(pin_config.pin_config_value),
  294. "PinConfigValue", NULL},
  295. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(pin_config.resource_source),
  296. "ResourceSource", NULL},
  297. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_config.pin_table_length),
  298. "PinTableLength", NULL},
  299. {ACPI_RSD_WORDLIST, ACPI_RSD_OFFSET(pin_config.pin_table), "PinTable",
  300. NULL},
  301. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_config.vendor_length),
  302. "VendorLength", NULL},
  303. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(pin_config.vendor_data),
  304. "VendorData", NULL},
  305. };
  306. struct acpi_rsdump_info acpi_rs_dump_pin_group[8] = {
  307. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_pin_group),
  308. "PinGroup", NULL},
  309. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_group.revision_id), "RevisionId",
  310. NULL},
  311. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_group.producer_consumer),
  312. "ProducerConsumer", acpi_gbl_consume_decode},
  313. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_group.pin_table_length),
  314. "PinTableLength", NULL},
  315. {ACPI_RSD_WORDLIST, ACPI_RSD_OFFSET(pin_group.pin_table), "PinTable",
  316. NULL},
  317. {ACPI_RSD_LABEL, ACPI_RSD_OFFSET(pin_group.resource_label),
  318. "ResourceLabel", NULL},
  319. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_group.vendor_length),
  320. "VendorLength", NULL},
  321. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(pin_group.vendor_data),
  322. "VendorData", NULL},
  323. };
  324. struct acpi_rsdump_info acpi_rs_dump_pin_group_function[9] = {
  325. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_pin_group_function),
  326. "PinGroupFunction", NULL},
  327. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_group_function.revision_id),
  328. "RevisionId", NULL},
  329. {ACPI_RSD_1BITFLAG,
  330. ACPI_RSD_OFFSET(pin_group_function.producer_consumer),
  331. "ProducerConsumer", acpi_gbl_consume_decode},
  332. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_group_function.shareable),
  333. "Sharing", acpi_gbl_shr_decode},
  334. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_group_function.function_number),
  335. "FunctionNumber", NULL},
  336. {ACPI_RSD_SOURCE_LABEL,
  337. ACPI_RSD_OFFSET(pin_group_function.resource_source_label),
  338. "ResourceSourceLabel", NULL},
  339. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(pin_group_function.resource_source),
  340. "ResourceSource", NULL},
  341. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_group_function.vendor_length),
  342. "VendorLength", NULL},
  343. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(pin_group_function.vendor_data),
  344. "VendorData", NULL},
  345. };
  346. struct acpi_rsdump_info acpi_rs_dump_pin_group_config[10] = {
  347. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_pin_group_config),
  348. "PinGroupConfig", NULL},
  349. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_group_config.revision_id),
  350. "RevisionId", NULL},
  351. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_group_config.producer_consumer),
  352. "ProducerConsumer", acpi_gbl_consume_decode},
  353. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(pin_group_config.shareable),
  354. "Sharing", acpi_gbl_shr_decode},
  355. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(pin_group_config.pin_config_type),
  356. "PinConfigType", NULL},
  357. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(pin_group_config.pin_config_value),
  358. "PinConfigValue", NULL},
  359. {ACPI_RSD_SOURCE_LABEL,
  360. ACPI_RSD_OFFSET(pin_group_config.resource_source_label),
  361. "ResourceSourceLabel", NULL},
  362. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(pin_group_config.resource_source),
  363. "ResourceSource", NULL},
  364. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(pin_group_config.vendor_length),
  365. "VendorLength", NULL},
  366. {ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(pin_group_config.vendor_data),
  367. "VendorData", NULL},
  368. };
  369. struct acpi_rsdump_info acpi_rs_dump_fixed_dma[4] = {
  370. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_fixed_dma),
  371. "FixedDma", NULL},
  372. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(fixed_dma.request_lines),
  373. "RequestLines", NULL},
  374. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(fixed_dma.channels), "Channels",
  375. NULL},
  376. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(fixed_dma.width), "TransferWidth",
  377. acpi_gbl_dts_decode},
  378. };
  379. #define ACPI_RS_DUMP_COMMON_SERIAL_BUS \
  380. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET (common_serial_bus.revision_id), "RevisionId", NULL}, \
  381. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET (common_serial_bus.type), "Type", acpi_gbl_sbt_decode}, \
  382. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (common_serial_bus.producer_consumer), "ProducerConsumer", acpi_gbl_consume_decode}, \
  383. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (common_serial_bus.slave_mode), "SlaveMode", acpi_gbl_sm_decode}, \
  384. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET (common_serial_bus.connection_sharing),"ConnectionSharing", acpi_gbl_shr_decode}, \
  385. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET (common_serial_bus.type_revision_id), "TypeRevisionId", NULL}, \
  386. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET (common_serial_bus.type_data_length), "TypeDataLength", NULL}, \
  387. {ACPI_RSD_SOURCE, ACPI_RSD_OFFSET (common_serial_bus.resource_source), "ResourceSource", NULL}, \
  388. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET (common_serial_bus.vendor_length), "VendorLength", NULL}, \
  389. {ACPI_RSD_SHORTLISTX,ACPI_RSD_OFFSET (common_serial_bus.vendor_data), "VendorData", NULL},
  390. struct acpi_rsdump_info acpi_rs_dump_common_serial_bus[11] = {
  391. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_common_serial_bus),
  392. "Common Serial Bus", NULL},
  393. ACPI_RS_DUMP_COMMON_SERIAL_BUS
  394. };
  395. struct acpi_rsdump_info acpi_rs_dump_csi2_serial_bus[11] = {
  396. { ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_csi2_serial_bus),
  397. "Camera Serial Bus", NULL },
  398. { ACPI_RSD_UINT8, ACPI_RSD_OFFSET(csi2_serial_bus.revision_id),
  399. "RevisionId", NULL },
  400. { ACPI_RSD_UINT8, ACPI_RSD_OFFSET(csi2_serial_bus.type), "Type",
  401. acpi_gbl_sbt_decode },
  402. { ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(csi2_serial_bus.producer_consumer),
  403. "ProducerConsumer", acpi_gbl_consume_decode },
  404. { ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(csi2_serial_bus.slave_mode),
  405. "SlaveMode", acpi_gbl_sm_decode },
  406. { ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(csi2_serial_bus.phy_type),
  407. "PhyType", acpi_gbl_phy_decode },
  408. { ACPI_RSD_6BITFLAG,
  409. ACPI_RSD_OFFSET(csi2_serial_bus.local_port_instance),
  410. "LocalPortInstance", NULL },
  411. { ACPI_RSD_UINT8, ACPI_RSD_OFFSET(csi2_serial_bus.type_revision_id),
  412. "TypeRevisionId", NULL },
  413. { ACPI_RSD_UINT16, ACPI_RSD_OFFSET(csi2_serial_bus.vendor_length),
  414. "VendorLength", NULL },
  415. { ACPI_RSD_SHORTLISTX, ACPI_RSD_OFFSET(csi2_serial_bus.vendor_data),
  416. "VendorData", NULL },
  417. { ACPI_RSD_SOURCE, ACPI_RSD_OFFSET(csi2_serial_bus.resource_source),
  418. "ResourceSource", NULL },
  419. };
  420. struct acpi_rsdump_info acpi_rs_dump_i2c_serial_bus[14] = {
  421. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_i2c_serial_bus),
  422. "I2C Serial Bus", NULL},
  423. ACPI_RS_DUMP_COMMON_SERIAL_BUS {ACPI_RSD_1BITFLAG,
  424. ACPI_RSD_OFFSET(i2c_serial_bus.
  425. access_mode),
  426. "AccessMode", acpi_gbl_am_decode},
  427. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(i2c_serial_bus.connection_speed),
  428. "ConnectionSpeed", NULL},
  429. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(i2c_serial_bus.slave_address),
  430. "SlaveAddress", NULL},
  431. };
  432. struct acpi_rsdump_info acpi_rs_dump_spi_serial_bus[18] = {
  433. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_spi_serial_bus),
  434. "Spi Serial Bus", NULL},
  435. ACPI_RS_DUMP_COMMON_SERIAL_BUS {ACPI_RSD_1BITFLAG,
  436. ACPI_RSD_OFFSET(spi_serial_bus.
  437. wire_mode), "WireMode",
  438. acpi_gbl_wm_decode},
  439. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(spi_serial_bus.device_polarity),
  440. "DevicePolarity", acpi_gbl_dp_decode},
  441. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(spi_serial_bus.data_bit_length),
  442. "DataBitLength", NULL},
  443. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(spi_serial_bus.clock_phase),
  444. "ClockPhase", acpi_gbl_cph_decode},
  445. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(spi_serial_bus.clock_polarity),
  446. "ClockPolarity", acpi_gbl_cpo_decode},
  447. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(spi_serial_bus.device_selection),
  448. "DeviceSelection", NULL},
  449. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(spi_serial_bus.connection_speed),
  450. "ConnectionSpeed", NULL},
  451. };
  452. struct acpi_rsdump_info acpi_rs_dump_uart_serial_bus[20] = {
  453. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_uart_serial_bus),
  454. "Uart Serial Bus", NULL},
  455. ACPI_RS_DUMP_COMMON_SERIAL_BUS {ACPI_RSD_2BITFLAG,
  456. ACPI_RSD_OFFSET(uart_serial_bus.
  457. flow_control),
  458. "FlowControl", acpi_gbl_fc_decode},
  459. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(uart_serial_bus.stop_bits),
  460. "StopBits", acpi_gbl_sb_decode},
  461. {ACPI_RSD_3BITFLAG, ACPI_RSD_OFFSET(uart_serial_bus.data_bits),
  462. "DataBits", acpi_gbl_bpb_decode},
  463. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(uart_serial_bus.endian), "Endian",
  464. acpi_gbl_ed_decode},
  465. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(uart_serial_bus.parity), "Parity",
  466. acpi_gbl_pt_decode},
  467. {ACPI_RSD_UINT8, ACPI_RSD_OFFSET(uart_serial_bus.lines_enabled),
  468. "LinesEnabled", NULL},
  469. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(uart_serial_bus.rx_fifo_size),
  470. "RxFifoSize", NULL},
  471. {ACPI_RSD_UINT16, ACPI_RSD_OFFSET(uart_serial_bus.tx_fifo_size),
  472. "TxFifoSize", NULL},
  473. {ACPI_RSD_UINT32, ACPI_RSD_OFFSET(uart_serial_bus.default_baud_rate),
  474. "ConnectionSpeed", NULL},
  475. };
  476. /*
  477. * Tables used for common address descriptor flag fields
  478. */
  479. struct acpi_rsdump_info acpi_rs_dump_general_flags[5] = {
  480. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_general_flags), NULL,
  481. NULL},
  482. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.producer_consumer),
  483. "Consumer/Producer", acpi_gbl_consume_decode},
  484. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.decode), "Address Decode",
  485. acpi_gbl_dec_decode},
  486. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.min_address_fixed),
  487. "Min Relocatability", acpi_gbl_min_decode},
  488. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.max_address_fixed),
  489. "Max Relocatability", acpi_gbl_max_decode}
  490. };
  491. struct acpi_rsdump_info acpi_rs_dump_memory_flags[5] = {
  492. {ACPI_RSD_LITERAL, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_memory_flags),
  493. "Resource Type", (void *)"Memory Range"},
  494. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.info.mem.write_protect),
  495. "Write Protect", acpi_gbl_rw_decode},
  496. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(address.info.mem.caching),
  497. "Caching", acpi_gbl_mem_decode},
  498. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(address.info.mem.range_type),
  499. "Range Type", acpi_gbl_mtp_decode},
  500. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.info.mem.translation),
  501. "Translation", acpi_gbl_ttp_decode}
  502. };
  503. struct acpi_rsdump_info acpi_rs_dump_io_flags[4] = {
  504. {ACPI_RSD_LITERAL, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_io_flags),
  505. "Resource Type", (void *)"I/O Range"},
  506. {ACPI_RSD_2BITFLAG, ACPI_RSD_OFFSET(address.info.io.range_type),
  507. "Range Type", acpi_gbl_rng_decode},
  508. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.info.io.translation),
  509. "Translation", acpi_gbl_ttp_decode},
  510. {ACPI_RSD_1BITFLAG, ACPI_RSD_OFFSET(address.info.io.translation_type),
  511. "Translation Type", acpi_gbl_trs_decode}
  512. };
  513. /*
  514. * Table used to dump _PRT contents
  515. */
  516. struct acpi_rsdump_info acpi_rs_dump_prt[5] = {
  517. {ACPI_RSD_TITLE, ACPI_RSD_TABLE_SIZE(acpi_rs_dump_prt), NULL, NULL},
  518. {ACPI_RSD_UINT64, ACPI_PRT_OFFSET(address), "Address", NULL},
  519. {ACPI_RSD_UINT32, ACPI_PRT_OFFSET(pin), "Pin", NULL},
  520. {ACPI_RSD_STRING, ACPI_PRT_OFFSET(source[0]), "Source", NULL},
  521. {ACPI_RSD_UINT32, ACPI_PRT_OFFSET(source_index), "Source Index", NULL}
  522. };
  523. #endif