rsinfo.c 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
  2. /*******************************************************************************
  3. *
  4. * Module Name: rsinfo - Dispatch and Info tables
  5. *
  6. ******************************************************************************/
  7. #include <acpi/acpi.h>
  8. #include "accommon.h"
  9. #include "acresrc.h"
  10. #define _COMPONENT ACPI_RESOURCES
  11. ACPI_MODULE_NAME("rsinfo")
  12. /*
  13. * Resource dispatch and information tables. Any new resource types (either
  14. * Large or Small) must be reflected in each of these tables, so they are here
  15. * in one place.
  16. *
  17. * The tables for Large descriptors are indexed by bits 6:0 of the AML
  18. * descriptor type byte. The tables for Small descriptors are indexed by
  19. * bits 6:3 of the descriptor byte. The tables for internal resource
  20. * descriptors are indexed by the acpi_resource_type field.
  21. */
  22. /* Dispatch table for resource-to-AML (Set Resource) conversion functions */
  23. struct acpi_rsconvert_info *acpi_gbl_set_resource_dispatch[] = {
  24. acpi_rs_set_irq, /* 0x00, ACPI_RESOURCE_TYPE_IRQ */
  25. acpi_rs_convert_dma, /* 0x01, ACPI_RESOURCE_TYPE_DMA */
  26. acpi_rs_set_start_dpf, /* 0x02, ACPI_RESOURCE_TYPE_START_DEPENDENT */
  27. acpi_rs_convert_end_dpf, /* 0x03, ACPI_RESOURCE_TYPE_END_DEPENDENT */
  28. acpi_rs_convert_io, /* 0x04, ACPI_RESOURCE_TYPE_IO */
  29. acpi_rs_convert_fixed_io, /* 0x05, ACPI_RESOURCE_TYPE_FIXED_IO */
  30. acpi_rs_set_vendor, /* 0x06, ACPI_RESOURCE_TYPE_VENDOR */
  31. acpi_rs_convert_end_tag, /* 0x07, ACPI_RESOURCE_TYPE_END_TAG */
  32. acpi_rs_convert_memory24, /* 0x08, ACPI_RESOURCE_TYPE_MEMORY24 */
  33. acpi_rs_convert_memory32, /* 0x09, ACPI_RESOURCE_TYPE_MEMORY32 */
  34. acpi_rs_convert_fixed_memory32, /* 0x0A, ACPI_RESOURCE_TYPE_FIXED_MEMORY32 */
  35. acpi_rs_convert_address16, /* 0x0B, ACPI_RESOURCE_TYPE_ADDRESS16 */
  36. acpi_rs_convert_address32, /* 0x0C, ACPI_RESOURCE_TYPE_ADDRESS32 */
  37. acpi_rs_convert_address64, /* 0x0D, ACPI_RESOURCE_TYPE_ADDRESS64 */
  38. acpi_rs_convert_ext_address64, /* 0x0E, ACPI_RESOURCE_TYPE_EXTENDED_ADDRESS64 */
  39. acpi_rs_convert_ext_irq, /* 0x0F, ACPI_RESOURCE_TYPE_EXTENDED_IRQ */
  40. acpi_rs_convert_generic_reg, /* 0x10, ACPI_RESOURCE_TYPE_GENERIC_REGISTER */
  41. acpi_rs_convert_gpio, /* 0x11, ACPI_RESOURCE_TYPE_GPIO */
  42. acpi_rs_convert_fixed_dma, /* 0x12, ACPI_RESOURCE_TYPE_FIXED_DMA */
  43. NULL, /* 0x13, ACPI_RESOURCE_TYPE_SERIAL_BUS - Use subtype table below */
  44. acpi_rs_convert_pin_function, /* 0x14, ACPI_RESOURCE_TYPE_PIN_FUNCTION */
  45. acpi_rs_convert_pin_config, /* 0x15, ACPI_RESOURCE_TYPE_PIN_CONFIG */
  46. acpi_rs_convert_pin_group, /* 0x16, ACPI_RESOURCE_TYPE_PIN_GROUP */
  47. acpi_rs_convert_pin_group_function, /* 0x17, ACPI_RESOURCE_TYPE_PIN_GROUP_FUNCTION */
  48. acpi_rs_convert_pin_group_config, /* 0x18, ACPI_RESOURCE_TYPE_PIN_GROUP_CONFIG */
  49. acpi_rs_convert_clock_input, /* 0x19, ACPI_RESOURCE_TYPE_CLOCK_INPUT */
  50. };
  51. /* Dispatch tables for AML-to-resource (Get Resource) conversion functions */
  52. struct acpi_rsconvert_info *acpi_gbl_get_resource_dispatch[] = {
  53. /* Small descriptors */
  54. NULL, /* 0x00, Reserved */
  55. NULL, /* 0x01, Reserved */
  56. NULL, /* 0x02, Reserved */
  57. NULL, /* 0x03, Reserved */
  58. acpi_rs_get_irq, /* 0x04, ACPI_RESOURCE_NAME_IRQ */
  59. acpi_rs_convert_dma, /* 0x05, ACPI_RESOURCE_NAME_DMA */
  60. acpi_rs_get_start_dpf, /* 0x06, ACPI_RESOURCE_NAME_START_DEPENDENT */
  61. acpi_rs_convert_end_dpf, /* 0x07, ACPI_RESOURCE_NAME_END_DEPENDENT */
  62. acpi_rs_convert_io, /* 0x08, ACPI_RESOURCE_NAME_IO */
  63. acpi_rs_convert_fixed_io, /* 0x09, ACPI_RESOURCE_NAME_FIXED_IO */
  64. acpi_rs_convert_fixed_dma, /* 0x0A, ACPI_RESOURCE_NAME_FIXED_DMA */
  65. NULL, /* 0x0B, Reserved */
  66. NULL, /* 0x0C, Reserved */
  67. NULL, /* 0x0D, Reserved */
  68. acpi_rs_get_vendor_small, /* 0x0E, ACPI_RESOURCE_NAME_VENDOR_SMALL */
  69. acpi_rs_convert_end_tag, /* 0x0F, ACPI_RESOURCE_NAME_END_TAG */
  70. /* Large descriptors */
  71. NULL, /* 0x00, Reserved */
  72. acpi_rs_convert_memory24, /* 0x01, ACPI_RESOURCE_NAME_MEMORY24 */
  73. acpi_rs_convert_generic_reg, /* 0x02, ACPI_RESOURCE_NAME_GENERIC_REGISTER */
  74. NULL, /* 0x03, Reserved */
  75. acpi_rs_get_vendor_large, /* 0x04, ACPI_RESOURCE_NAME_VENDOR_LARGE */
  76. acpi_rs_convert_memory32, /* 0x05, ACPI_RESOURCE_NAME_MEMORY32 */
  77. acpi_rs_convert_fixed_memory32, /* 0x06, ACPI_RESOURCE_NAME_FIXED_MEMORY32 */
  78. acpi_rs_convert_address32, /* 0x07, ACPI_RESOURCE_NAME_ADDRESS32 */
  79. acpi_rs_convert_address16, /* 0x08, ACPI_RESOURCE_NAME_ADDRESS16 */
  80. acpi_rs_convert_ext_irq, /* 0x09, ACPI_RESOURCE_NAME_EXTENDED_IRQ */
  81. acpi_rs_convert_address64, /* 0x0A, ACPI_RESOURCE_NAME_ADDRESS64 */
  82. acpi_rs_convert_ext_address64, /* 0x0B, ACPI_RESOURCE_NAME_EXTENDED_ADDRESS64 */
  83. acpi_rs_convert_gpio, /* 0x0C, ACPI_RESOURCE_NAME_GPIO */
  84. acpi_rs_convert_pin_function, /* 0x0D, ACPI_RESOURCE_NAME_PIN_FUNCTION */
  85. NULL, /* 0x0E, ACPI_RESOURCE_NAME_SERIAL_BUS - Use subtype table below */
  86. acpi_rs_convert_pin_config, /* 0x0F, ACPI_RESOURCE_NAME_PIN_CONFIG */
  87. acpi_rs_convert_pin_group, /* 0x10, ACPI_RESOURCE_NAME_PIN_GROUP */
  88. acpi_rs_convert_pin_group_function, /* 0x11, ACPI_RESOURCE_NAME_PIN_GROUP_FUNCTION */
  89. acpi_rs_convert_pin_group_config, /* 0x12, ACPI_RESOURCE_NAME_PIN_GROUP_CONFIG */
  90. acpi_rs_convert_clock_input, /* 0x13, ACPI_RESOURCE_NAME_CLOCK_INPUT */
  91. };
  92. /* Subtype table for serial_bus -- I2C, SPI, UART, and CSI2 */
  93. struct acpi_rsconvert_info *acpi_gbl_convert_resource_serial_bus_dispatch[] = {
  94. NULL,
  95. acpi_rs_convert_i2c_serial_bus,
  96. acpi_rs_convert_spi_serial_bus,
  97. acpi_rs_convert_uart_serial_bus,
  98. acpi_rs_convert_csi2_serial_bus
  99. };
  100. #if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DISASSEMBLER) || defined(ACPI_DEBUGGER)
  101. /* Dispatch table for resource dump functions */
  102. struct acpi_rsdump_info *acpi_gbl_dump_resource_dispatch[] = {
  103. acpi_rs_dump_irq, /* ACPI_RESOURCE_TYPE_IRQ */
  104. acpi_rs_dump_dma, /* ACPI_RESOURCE_TYPE_DMA */
  105. acpi_rs_dump_start_dpf, /* ACPI_RESOURCE_TYPE_START_DEPENDENT */
  106. acpi_rs_dump_end_dpf, /* ACPI_RESOURCE_TYPE_END_DEPENDENT */
  107. acpi_rs_dump_io, /* ACPI_RESOURCE_TYPE_IO */
  108. acpi_rs_dump_fixed_io, /* ACPI_RESOURCE_TYPE_FIXED_IO */
  109. acpi_rs_dump_vendor, /* ACPI_RESOURCE_TYPE_VENDOR */
  110. acpi_rs_dump_end_tag, /* ACPI_RESOURCE_TYPE_END_TAG */
  111. acpi_rs_dump_memory24, /* ACPI_RESOURCE_TYPE_MEMORY24 */
  112. acpi_rs_dump_memory32, /* ACPI_RESOURCE_TYPE_MEMORY32 */
  113. acpi_rs_dump_fixed_memory32, /* ACPI_RESOURCE_TYPE_FIXED_MEMORY32 */
  114. acpi_rs_dump_address16, /* ACPI_RESOURCE_TYPE_ADDRESS16 */
  115. acpi_rs_dump_address32, /* ACPI_RESOURCE_TYPE_ADDRESS32 */
  116. acpi_rs_dump_address64, /* ACPI_RESOURCE_TYPE_ADDRESS64 */
  117. acpi_rs_dump_ext_address64, /* ACPI_RESOURCE_TYPE_EXTENDED_ADDRESS64 */
  118. acpi_rs_dump_ext_irq, /* ACPI_RESOURCE_TYPE_EXTENDED_IRQ */
  119. acpi_rs_dump_generic_reg, /* ACPI_RESOURCE_TYPE_GENERIC_REGISTER */
  120. acpi_rs_dump_gpio, /* ACPI_RESOURCE_TYPE_GPIO */
  121. acpi_rs_dump_fixed_dma, /* ACPI_RESOURCE_TYPE_FIXED_DMA */
  122. NULL, /* ACPI_RESOURCE_TYPE_SERIAL_BUS */
  123. acpi_rs_dump_pin_function, /* ACPI_RESOURCE_TYPE_PIN_FUNCTION */
  124. acpi_rs_dump_pin_config, /* ACPI_RESOURCE_TYPE_PIN_CONFIG */
  125. acpi_rs_dump_pin_group, /* ACPI_RESOURCE_TYPE_PIN_GROUP */
  126. acpi_rs_dump_pin_group_function, /* ACPI_RESOURCE_TYPE_PIN_GROUP_FUNCTION */
  127. acpi_rs_dump_pin_group_config, /* ACPI_RESOURCE_TYPE_PIN_GROUP_CONFIG */
  128. acpi_rs_dump_clock_input, /* ACPI_RESOURCE_TYPE_CLOCK_INPUT */
  129. };
  130. struct acpi_rsdump_info *acpi_gbl_dump_serial_bus_dispatch[] = {
  131. NULL,
  132. acpi_rs_dump_i2c_serial_bus, /* AML_RESOURCE_I2C_BUS_TYPE */
  133. acpi_rs_dump_spi_serial_bus, /* AML_RESOURCE_SPI_BUS_TYPE */
  134. acpi_rs_dump_uart_serial_bus, /* AML_RESOURCE_UART_BUS_TYPE */
  135. acpi_rs_dump_csi2_serial_bus, /* AML_RESOURCE_CSI2_BUS_TYPE */
  136. };
  137. #endif
  138. /*
  139. * Base sizes for external AML resource descriptors, indexed by internal type.
  140. * Includes size of the descriptor header (1 byte for small descriptors,
  141. * 3 bytes for large descriptors)
  142. */
  143. const u8 acpi_gbl_aml_resource_sizes[] = {
  144. sizeof(struct aml_resource_irq), /* ACPI_RESOURCE_TYPE_IRQ (optional Byte 3 always created) */
  145. sizeof(struct aml_resource_dma), /* ACPI_RESOURCE_TYPE_DMA */
  146. sizeof(struct aml_resource_start_dependent), /* ACPI_RESOURCE_TYPE_START_DEPENDENT (optional Byte 1 always created) */
  147. sizeof(struct aml_resource_end_dependent), /* ACPI_RESOURCE_TYPE_END_DEPENDENT */
  148. sizeof(struct aml_resource_io), /* ACPI_RESOURCE_TYPE_IO */
  149. sizeof(struct aml_resource_fixed_io), /* ACPI_RESOURCE_TYPE_FIXED_IO */
  150. sizeof(struct aml_resource_vendor_small), /* ACPI_RESOURCE_TYPE_VENDOR */
  151. sizeof(struct aml_resource_end_tag), /* ACPI_RESOURCE_TYPE_END_TAG */
  152. sizeof(struct aml_resource_memory24), /* ACPI_RESOURCE_TYPE_MEMORY24 */
  153. sizeof(struct aml_resource_memory32), /* ACPI_RESOURCE_TYPE_MEMORY32 */
  154. sizeof(struct aml_resource_fixed_memory32), /* ACPI_RESOURCE_TYPE_FIXED_MEMORY32 */
  155. sizeof(struct aml_resource_address16), /* ACPI_RESOURCE_TYPE_ADDRESS16 */
  156. sizeof(struct aml_resource_address32), /* ACPI_RESOURCE_TYPE_ADDRESS32 */
  157. sizeof(struct aml_resource_address64), /* ACPI_RESOURCE_TYPE_ADDRESS64 */
  158. sizeof(struct aml_resource_extended_address64), /*ACPI_RESOURCE_TYPE_EXTENDED_ADDRESS64 */
  159. sizeof(struct aml_resource_extended_irq), /* ACPI_RESOURCE_TYPE_EXTENDED_IRQ */
  160. sizeof(struct aml_resource_generic_register), /* ACPI_RESOURCE_TYPE_GENERIC_REGISTER */
  161. sizeof(struct aml_resource_gpio), /* ACPI_RESOURCE_TYPE_GPIO */
  162. sizeof(struct aml_resource_fixed_dma), /* ACPI_RESOURCE_TYPE_FIXED_DMA */
  163. sizeof(struct aml_resource_common_serialbus), /* ACPI_RESOURCE_TYPE_SERIAL_BUS */
  164. sizeof(struct aml_resource_pin_function), /* ACPI_RESOURCE_TYPE_PIN_FUNCTION */
  165. sizeof(struct aml_resource_pin_config), /* ACPI_RESOURCE_TYPE_PIN_CONFIG */
  166. sizeof(struct aml_resource_pin_group), /* ACPI_RESOURCE_TYPE_PIN_GROUP */
  167. sizeof(struct aml_resource_pin_group_function), /* ACPI_RESOURCE_TYPE_PIN_GROUP_FUNCTION */
  168. sizeof(struct aml_resource_pin_group_config), /* ACPI_RESOURCE_TYPE_PIN_GROUP_CONFIG */
  169. sizeof(struct aml_resource_clock_input), /* ACPI_RESOURCE_TYPE_CLOCK_INPUT */
  170. };
  171. const u8 acpi_gbl_resource_struct_sizes[] = {
  172. /* Small descriptors */
  173. 0,
  174. 0,
  175. 0,
  176. 0,
  177. ACPI_RS_SIZE(struct acpi_resource_irq),
  178. ACPI_RS_SIZE(struct acpi_resource_dma),
  179. ACPI_RS_SIZE(struct acpi_resource_start_dependent),
  180. ACPI_RS_SIZE_MIN,
  181. ACPI_RS_SIZE(struct acpi_resource_io),
  182. ACPI_RS_SIZE(struct acpi_resource_fixed_io),
  183. ACPI_RS_SIZE(struct acpi_resource_fixed_dma),
  184. 0,
  185. 0,
  186. 0,
  187. ACPI_RS_SIZE(struct acpi_resource_vendor),
  188. ACPI_RS_SIZE_MIN,
  189. /* Large descriptors */
  190. 0,
  191. ACPI_RS_SIZE(struct acpi_resource_memory24),
  192. ACPI_RS_SIZE(struct acpi_resource_generic_register),
  193. 0,
  194. ACPI_RS_SIZE(struct acpi_resource_vendor),
  195. ACPI_RS_SIZE(struct acpi_resource_memory32),
  196. ACPI_RS_SIZE(struct acpi_resource_fixed_memory32),
  197. ACPI_RS_SIZE(struct acpi_resource_address32),
  198. ACPI_RS_SIZE(struct acpi_resource_address16),
  199. ACPI_RS_SIZE(struct acpi_resource_extended_irq),
  200. ACPI_RS_SIZE(struct acpi_resource_address64),
  201. ACPI_RS_SIZE(struct acpi_resource_extended_address64),
  202. ACPI_RS_SIZE(struct acpi_resource_gpio),
  203. ACPI_RS_SIZE(struct acpi_resource_pin_function),
  204. ACPI_RS_SIZE(struct acpi_resource_common_serialbus),
  205. ACPI_RS_SIZE(struct acpi_resource_pin_config),
  206. ACPI_RS_SIZE(struct acpi_resource_pin_group),
  207. ACPI_RS_SIZE(struct acpi_resource_pin_group_function),
  208. ACPI_RS_SIZE(struct acpi_resource_pin_group_config),
  209. ACPI_RS_SIZE(struct acpi_resource_clock_input),
  210. };
  211. const u8 acpi_gbl_aml_resource_serial_bus_sizes[] = {
  212. 0,
  213. sizeof(struct aml_resource_i2c_serialbus),
  214. sizeof(struct aml_resource_spi_serialbus),
  215. sizeof(struct aml_resource_uart_serialbus),
  216. sizeof(struct aml_resource_csi2_serialbus),
  217. };
  218. const u8 acpi_gbl_resource_struct_serial_bus_sizes[] = {
  219. 0,
  220. ACPI_RS_SIZE(struct acpi_resource_i2c_serialbus),
  221. ACPI_RS_SIZE(struct acpi_resource_spi_serialbus),
  222. ACPI_RS_SIZE(struct acpi_resource_uart_serialbus),
  223. ACPI_RS_SIZE(struct acpi_resource_csi2_serialbus),
  224. };