amlcode.h 20 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500
  1. /******************************************************************************
  2. *
  3. * Name: amlcode.h - Definitions for AML, as included in "definition blocks"
  4. * Declarations and definitions contained herein are derived
  5. * directly from the ACPI specification.
  6. *
  7. *****************************************************************************/
  8. /*
  9. * Copyright (C) 2000 - 2018, Intel Corp.
  10. * All rights reserved.
  11. *
  12. * Redistribution and use in source and binary forms, with or without
  13. * modification, are permitted provided that the following conditions
  14. * are met:
  15. * 1. Redistributions of source code must retain the above copyright
  16. * notice, this list of conditions, and the following disclaimer,
  17. * without modification.
  18. * 2. Redistributions in binary form must reproduce at minimum a disclaimer
  19. * substantially similar to the "NO WARRANTY" disclaimer below
  20. * ("Disclaimer") and any redistribution must be conditioned upon
  21. * including a substantially similar Disclaimer requirement for further
  22. * binary redistribution.
  23. * 3. Neither the names of the above-listed copyright holders nor the names
  24. * of any contributors may be used to endorse or promote products derived
  25. * from this software without specific prior written permission.
  26. *
  27. * Alternatively, this software may be distributed under the terms of the
  28. * GNU General Public License ("GPL") version 2 as published by the Free
  29. * Software Foundation.
  30. *
  31. * NO WARRANTY
  32. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  33. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  34. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
  35. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  36. * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
  37. * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
  38. * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
  39. * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
  40. * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
  41. * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
  42. * POSSIBILITY OF SUCH DAMAGES.
  43. */
  44. #ifndef __AMLCODE_H__
  45. #define __AMLCODE_H__
  46. /* primary opcodes */
  47. #define AML_ZERO_OP (u16) 0x00
  48. #define AML_ONE_OP (u16) 0x01
  49. #define AML_ALIAS_OP (u16) 0x06
  50. #define AML_NAME_OP (u16) 0x08
  51. #define AML_BYTE_OP (u16) 0x0a
  52. #define AML_WORD_OP (u16) 0x0b
  53. #define AML_DWORD_OP (u16) 0x0c
  54. #define AML_STRING_OP (u16) 0x0d
  55. #define AML_QWORD_OP (u16) 0x0e /* ACPI 2.0 */
  56. #define AML_SCOPE_OP (u16) 0x10
  57. #define AML_BUFFER_OP (u16) 0x11
  58. #define AML_PACKAGE_OP (u16) 0x12
  59. #define AML_VARIABLE_PACKAGE_OP (u16) 0x13 /* ACPI 2.0 */
  60. #define AML_METHOD_OP (u16) 0x14
  61. #define AML_EXTERNAL_OP (u16) 0x15 /* ACPI 6.0 */
  62. #define AML_DUAL_NAME_PREFIX (u16) 0x2e
  63. #define AML_MULTI_NAME_PREFIX (u16) 0x2f
  64. #define AML_EXTENDED_PREFIX (u16) 0x5b
  65. #define AML_ROOT_PREFIX (u16) 0x5c
  66. #define AML_PARENT_PREFIX (u16) 0x5e
  67. #define AML_FIRST_LOCAL_OP (u16) 0x60 /* Used for Local op # calculations */
  68. #define AML_LOCAL0 (u16) 0x60
  69. #define AML_LOCAL1 (u16) 0x61
  70. #define AML_LOCAL2 (u16) 0x62
  71. #define AML_LOCAL3 (u16) 0x63
  72. #define AML_LOCAL4 (u16) 0x64
  73. #define AML_LOCAL5 (u16) 0x65
  74. #define AML_LOCAL6 (u16) 0x66
  75. #define AML_LOCAL7 (u16) 0x67
  76. #define AML_FIRST_ARG_OP (u16) 0x68 /* Used for Arg op # calculations */
  77. #define AML_ARG0 (u16) 0x68
  78. #define AML_ARG1 (u16) 0x69
  79. #define AML_ARG2 (u16) 0x6a
  80. #define AML_ARG3 (u16) 0x6b
  81. #define AML_ARG4 (u16) 0x6c
  82. #define AML_ARG5 (u16) 0x6d
  83. #define AML_ARG6 (u16) 0x6e
  84. #define AML_STORE_OP (u16) 0x70
  85. #define AML_REF_OF_OP (u16) 0x71
  86. #define AML_ADD_OP (u16) 0x72
  87. #define AML_CONCATENATE_OP (u16) 0x73
  88. #define AML_SUBTRACT_OP (u16) 0x74
  89. #define AML_INCREMENT_OP (u16) 0x75
  90. #define AML_DECREMENT_OP (u16) 0x76
  91. #define AML_MULTIPLY_OP (u16) 0x77
  92. #define AML_DIVIDE_OP (u16) 0x78
  93. #define AML_SHIFT_LEFT_OP (u16) 0x79
  94. #define AML_SHIFT_RIGHT_OP (u16) 0x7a
  95. #define AML_BIT_AND_OP (u16) 0x7b
  96. #define AML_BIT_NAND_OP (u16) 0x7c
  97. #define AML_BIT_OR_OP (u16) 0x7d
  98. #define AML_BIT_NOR_OP (u16) 0x7e
  99. #define AML_BIT_XOR_OP (u16) 0x7f
  100. #define AML_BIT_NOT_OP (u16) 0x80
  101. #define AML_FIND_SET_LEFT_BIT_OP (u16) 0x81
  102. #define AML_FIND_SET_RIGHT_BIT_OP (u16) 0x82
  103. #define AML_DEREF_OF_OP (u16) 0x83
  104. #define AML_CONCATENATE_TEMPLATE_OP (u16) 0x84 /* ACPI 2.0 */
  105. #define AML_MOD_OP (u16) 0x85 /* ACPI 2.0 */
  106. #define AML_NOTIFY_OP (u16) 0x86
  107. #define AML_SIZE_OF_OP (u16) 0x87
  108. #define AML_INDEX_OP (u16) 0x88
  109. #define AML_MATCH_OP (u16) 0x89
  110. #define AML_CREATE_DWORD_FIELD_OP (u16) 0x8a
  111. #define AML_CREATE_WORD_FIELD_OP (u16) 0x8b
  112. #define AML_CREATE_BYTE_FIELD_OP (u16) 0x8c
  113. #define AML_CREATE_BIT_FIELD_OP (u16) 0x8d
  114. #define AML_OBJECT_TYPE_OP (u16) 0x8e
  115. #define AML_CREATE_QWORD_FIELD_OP (u16) 0x8f /* ACPI 2.0 */
  116. #define AML_LOGICAL_AND_OP (u16) 0x90
  117. #define AML_LOGICAL_OR_OP (u16) 0x91
  118. #define AML_LOGICAL_NOT_OP (u16) 0x92
  119. #define AML_LOGICAL_EQUAL_OP (u16) 0x93
  120. #define AML_LOGICAL_GREATER_OP (u16) 0x94
  121. #define AML_LOGICAL_LESS_OP (u16) 0x95
  122. #define AML_TO_BUFFER_OP (u16) 0x96 /* ACPI 2.0 */
  123. #define AML_TO_DECIMAL_STRING_OP (u16) 0x97 /* ACPI 2.0 */
  124. #define AML_TO_HEX_STRING_OP (u16) 0x98 /* ACPI 2.0 */
  125. #define AML_TO_INTEGER_OP (u16) 0x99 /* ACPI 2.0 */
  126. #define AML_TO_STRING_OP (u16) 0x9c /* ACPI 2.0 */
  127. #define AML_COPY_OBJECT_OP (u16) 0x9d /* ACPI 2.0 */
  128. #define AML_MID_OP (u16) 0x9e /* ACPI 2.0 */
  129. #define AML_CONTINUE_OP (u16) 0x9f /* ACPI 2.0 */
  130. #define AML_IF_OP (u16) 0xa0
  131. #define AML_ELSE_OP (u16) 0xa1
  132. #define AML_WHILE_OP (u16) 0xa2
  133. #define AML_NOOP_OP (u16) 0xa3
  134. #define AML_RETURN_OP (u16) 0xa4
  135. #define AML_BREAK_OP (u16) 0xa5
  136. #define AML_COMMENT_OP (u16) 0xa9
  137. #define AML_BREAKPOINT_OP (u16) 0xcc
  138. #define AML_ONES_OP (u16) 0xff
  139. /*
  140. * Combination opcodes (actually two one-byte opcodes)
  141. * Used by the disassembler and iASL compiler
  142. */
  143. #define AML_LOGICAL_GREATER_EQUAL_OP (u16) 0x9295 /* LNot (LLess) */
  144. #define AML_LOGICAL_LESS_EQUAL_OP (u16) 0x9294 /* LNot (LGreater) */
  145. #define AML_LOGICAL_NOT_EQUAL_OP (u16) 0x9293 /* LNot (LEqual) */
  146. /* Prefixed (2-byte) opcodes (with AML_EXTENDED_PREFIX) */
  147. #define AML_EXTENDED_OPCODE (u16) 0x5b00 /* Prefix for 2-byte opcodes */
  148. #define AML_MUTEX_OP (u16) 0x5b01
  149. #define AML_EVENT_OP (u16) 0x5b02
  150. #define AML_SHIFT_RIGHT_BIT_OP (u16) 0x5b10 /* Obsolete, not in ACPI spec */
  151. #define AML_SHIFT_LEFT_BIT_OP (u16) 0x5b11 /* Obsolete, not in ACPI spec */
  152. #define AML_CONDITIONAL_REF_OF_OP (u16) 0x5b12
  153. #define AML_CREATE_FIELD_OP (u16) 0x5b13
  154. #define AML_LOAD_TABLE_OP (u16) 0x5b1f /* ACPI 2.0 */
  155. #define AML_LOAD_OP (u16) 0x5b20
  156. #define AML_STALL_OP (u16) 0x5b21
  157. #define AML_SLEEP_OP (u16) 0x5b22
  158. #define AML_ACQUIRE_OP (u16) 0x5b23
  159. #define AML_SIGNAL_OP (u16) 0x5b24
  160. #define AML_WAIT_OP (u16) 0x5b25
  161. #define AML_RESET_OP (u16) 0x5b26
  162. #define AML_RELEASE_OP (u16) 0x5b27
  163. #define AML_FROM_BCD_OP (u16) 0x5b28
  164. #define AML_TO_BCD_OP (u16) 0x5b29
  165. #define AML_UNLOAD_OP (u16) 0x5b2a
  166. #define AML_REVISION_OP (u16) 0x5b30
  167. #define AML_DEBUG_OP (u16) 0x5b31
  168. #define AML_FATAL_OP (u16) 0x5b32
  169. #define AML_TIMER_OP (u16) 0x5b33 /* ACPI 3.0 */
  170. #define AML_REGION_OP (u16) 0x5b80
  171. #define AML_FIELD_OP (u16) 0x5b81
  172. #define AML_DEVICE_OP (u16) 0x5b82
  173. #define AML_PROCESSOR_OP (u16) 0x5b83
  174. #define AML_POWER_RESOURCE_OP (u16) 0x5b84
  175. #define AML_THERMAL_ZONE_OP (u16) 0x5b85
  176. #define AML_INDEX_FIELD_OP (u16) 0x5b86
  177. #define AML_BANK_FIELD_OP (u16) 0x5b87
  178. #define AML_DATA_REGION_OP (u16) 0x5b88 /* ACPI 2.0 */
  179. /*
  180. * Opcodes for "Field" operators
  181. */
  182. #define AML_FIELD_OFFSET_OP (u8) 0x00
  183. #define AML_FIELD_ACCESS_OP (u8) 0x01
  184. #define AML_FIELD_CONNECTION_OP (u8) 0x02 /* ACPI 5.0 */
  185. #define AML_FIELD_EXT_ACCESS_OP (u8) 0x03 /* ACPI 5.0 */
  186. /*
  187. * Internal opcodes
  188. * Use only "Unknown" AML opcodes, don't attempt to use
  189. * any valid ACPI ASCII values (A-Z, 0-9, '-')
  190. */
  191. #define AML_INT_NAMEPATH_OP (u16) 0x002d
  192. #define AML_INT_NAMEDFIELD_OP (u16) 0x0030
  193. #define AML_INT_RESERVEDFIELD_OP (u16) 0x0031
  194. #define AML_INT_ACCESSFIELD_OP (u16) 0x0032
  195. #define AML_INT_BYTELIST_OP (u16) 0x0033
  196. #define AML_INT_METHODCALL_OP (u16) 0x0035
  197. #define AML_INT_RETURN_VALUE_OP (u16) 0x0036
  198. #define AML_INT_EVAL_SUBTREE_OP (u16) 0x0037
  199. #define AML_INT_CONNECTION_OP (u16) 0x0038
  200. #define AML_INT_EXTACCESSFIELD_OP (u16) 0x0039
  201. #define ARG_NONE 0x0
  202. /*
  203. * Argument types for the AML Parser
  204. * Each field in the arg_types u32 is 5 bits, allowing for a maximum of 6 arguments.
  205. * There can be up to 31 unique argument types
  206. * Zero is reserved as end-of-list indicator
  207. */
  208. #define ARGP_BYTEDATA 0x01
  209. #define ARGP_BYTELIST 0x02
  210. #define ARGP_CHARLIST 0x03
  211. #define ARGP_DATAOBJ 0x04
  212. #define ARGP_DATAOBJLIST 0x05
  213. #define ARGP_DWORDDATA 0x06
  214. #define ARGP_FIELDLIST 0x07
  215. #define ARGP_NAME 0x08
  216. #define ARGP_NAMESTRING 0x09
  217. #define ARGP_OBJLIST 0x0A
  218. #define ARGP_PKGLENGTH 0x0B
  219. #define ARGP_SUPERNAME 0x0C
  220. #define ARGP_TARGET 0x0D
  221. #define ARGP_TERMARG 0x0E
  222. #define ARGP_TERMLIST 0x0F
  223. #define ARGP_WORDDATA 0x10
  224. #define ARGP_QWORDDATA 0x11
  225. #define ARGP_SIMPLENAME 0x12 /* name_string | local_term | arg_term */
  226. #define ARGP_NAME_OR_REF 0x13 /* For object_type only */
  227. #define ARGP_MAX 0x13
  228. #define ARGP_COMMENT 0x14
  229. /*
  230. * Resolved argument types for the AML Interpreter
  231. * Each field in the arg_types u32 is 5 bits, allowing for a maximum of 6 arguments.
  232. * There can be up to 31 unique argument types (0 is end-of-arg-list indicator)
  233. *
  234. * Note1: These values are completely independent from the ACPI_TYPEs
  235. * i.e., ARGI_INTEGER != ACPI_TYPE_INTEGER
  236. *
  237. * Note2: If and when 5 bits becomes insufficient, it would probably be best
  238. * to convert to a 6-byte array of argument types, allowing 8 bits per argument.
  239. */
  240. /* Single, simple types */
  241. #define ARGI_ANYTYPE 0x01 /* Don't care */
  242. #define ARGI_PACKAGE 0x02
  243. #define ARGI_EVENT 0x03
  244. #define ARGI_MUTEX 0x04
  245. #define ARGI_DDBHANDLE 0x05
  246. /* Interchangeable types (via implicit conversion) */
  247. #define ARGI_INTEGER 0x06
  248. #define ARGI_STRING 0x07
  249. #define ARGI_BUFFER 0x08
  250. #define ARGI_BUFFER_OR_STRING 0x09 /* Used by MID op only */
  251. #define ARGI_COMPUTEDATA 0x0A /* Buffer, String, or Integer */
  252. /* Reference objects */
  253. #define ARGI_INTEGER_REF 0x0B
  254. #define ARGI_OBJECT_REF 0x0C
  255. #define ARGI_DEVICE_REF 0x0D
  256. #define ARGI_REFERENCE 0x0E
  257. #define ARGI_TARGETREF 0x0F /* Target, subject to implicit conversion */
  258. #define ARGI_SIMPLE_TARGET 0x10 /* Name, Local, Arg -- no implicit conversion */
  259. #define ARGI_STORE_TARGET 0x11 /* Target for store is TARGETREF + package objects */
  260. /*
  261. * #define ARGI_FIXED_TARGET 0x10 Target, no implicit conversion
  262. *
  263. * Removed 10/2016. ARGI_FIXED_TARGET was used for these operators:
  264. * from_BCD
  265. * to_BCD
  266. * to_decimal_string
  267. * to_hex_string
  268. * to_integer
  269. * to_buffer
  270. * The purpose of this type was to disable "implicit result conversion",
  271. * but this was incorrect per the ACPI spec and other ACPI implementations.
  272. * These operators now have the target operand defined as a normal
  273. * ARGI_TARGETREF.
  274. */
  275. /* Multiple/complex types */
  276. #define ARGI_DATAOBJECT 0x13 /* Buffer, String, package or reference to a node - Used only by size_of operator */
  277. #define ARGI_COMPLEXOBJ 0x14 /* Buffer, String, or package (Used by INDEX op only) */
  278. #define ARGI_REF_OR_STRING 0x15 /* Reference or String (Used by DEREFOF op only) */
  279. #define ARGI_REGION_OR_BUFFER 0x16 /* Used by LOAD op only */
  280. #define ARGI_DATAREFOBJ 0x17
  281. /* Note: types above can expand to 0x1F maximum */
  282. #define ARGI_INVALID_OPCODE 0xFFFFFFFF
  283. /*
  284. * Some of the flags and types below are of the form:
  285. *
  286. * AML_FLAGS_EXEC_#A_#T,#R, or
  287. * AML_TYPE_EXEC_#A_#T,#R where:
  288. *
  289. * #A is the number of required arguments
  290. * #T is the number of target operands
  291. * #R indicates whether there is a return value
  292. *
  293. * These types are used for the top-level dispatch of the AML
  294. * opcode. They group similar operators that can share common
  295. * front-end code before dispatch to the final code that implements
  296. * the operator.
  297. */
  298. /*
  299. * Opcode information flags
  300. */
  301. #define AML_LOGICAL 0x0001
  302. #define AML_LOGICAL_NUMERIC 0x0002
  303. #define AML_MATH 0x0004
  304. #define AML_CREATE 0x0008
  305. #define AML_FIELD 0x0010
  306. #define AML_DEFER 0x0020
  307. #define AML_NAMED 0x0040
  308. #define AML_NSNODE 0x0080
  309. #define AML_NSOPCODE 0x0100
  310. #define AML_NSOBJECT 0x0200
  311. #define AML_HAS_RETVAL 0x0400
  312. #define AML_HAS_TARGET 0x0800
  313. #define AML_HAS_ARGS 0x1000
  314. #define AML_CONSTANT 0x2000
  315. #define AML_NO_OPERAND_RESOLVE 0x4000
  316. /* Convenient flag groupings of the flags above */
  317. #define AML_FLAGS_EXEC_0A_0T_1R AML_HAS_RETVAL
  318. #define AML_FLAGS_EXEC_1A_0T_0R AML_HAS_ARGS /* Monadic1 */
  319. #define AML_FLAGS_EXEC_1A_0T_1R AML_HAS_ARGS | AML_HAS_RETVAL /* Monadic2 */
  320. #define AML_FLAGS_EXEC_1A_1T_0R AML_HAS_ARGS | AML_HAS_TARGET
  321. #define AML_FLAGS_EXEC_1A_1T_1R AML_HAS_ARGS | AML_HAS_TARGET | AML_HAS_RETVAL /* monadic2_r */
  322. #define AML_FLAGS_EXEC_2A_0T_0R AML_HAS_ARGS /* Dyadic1 */
  323. #define AML_FLAGS_EXEC_2A_0T_1R AML_HAS_ARGS | AML_HAS_RETVAL /* Dyadic2 */
  324. #define AML_FLAGS_EXEC_2A_1T_1R AML_HAS_ARGS | AML_HAS_TARGET | AML_HAS_RETVAL /* dyadic2_r */
  325. #define AML_FLAGS_EXEC_2A_2T_1R AML_HAS_ARGS | AML_HAS_TARGET | AML_HAS_RETVAL
  326. #define AML_FLAGS_EXEC_3A_0T_0R AML_HAS_ARGS
  327. #define AML_FLAGS_EXEC_3A_1T_1R AML_HAS_ARGS | AML_HAS_TARGET | AML_HAS_RETVAL
  328. #define AML_FLAGS_EXEC_6A_0T_1R AML_HAS_ARGS | AML_HAS_RETVAL
  329. /*
  330. * The opcode Type is used in a dispatch table, do not change
  331. * or add anything new without updating the table.
  332. */
  333. #define AML_TYPE_EXEC_0A_0T_1R 0x00 /* 0 Args, 0 Target, 1 ret_val */
  334. #define AML_TYPE_EXEC_1A_0T_0R 0x01 /* 1 Args, 0 Target, 0 ret_val */
  335. #define AML_TYPE_EXEC_1A_0T_1R 0x02 /* 1 Args, 0 Target, 1 ret_val */
  336. #define AML_TYPE_EXEC_1A_1T_0R 0x03 /* 1 Args, 1 Target, 0 ret_val */
  337. #define AML_TYPE_EXEC_1A_1T_1R 0x04 /* 1 Args, 1 Target, 1 ret_val */
  338. #define AML_TYPE_EXEC_2A_0T_0R 0x05 /* 2 Args, 0 Target, 0 ret_val */
  339. #define AML_TYPE_EXEC_2A_0T_1R 0x06 /* 2 Args, 0 Target, 1 ret_val */
  340. #define AML_TYPE_EXEC_2A_1T_1R 0x07 /* 2 Args, 1 Target, 1 ret_val */
  341. #define AML_TYPE_EXEC_2A_2T_1R 0x08 /* 2 Args, 2 Target, 1 ret_val */
  342. #define AML_TYPE_EXEC_3A_0T_0R 0x09 /* 3 Args, 0 Target, 0 ret_val */
  343. #define AML_TYPE_EXEC_3A_1T_1R 0x0A /* 3 Args, 1 Target, 1 ret_val */
  344. #define AML_TYPE_EXEC_6A_0T_1R 0x0B /* 6 Args, 0 Target, 1 ret_val */
  345. /* End of types used in dispatch table */
  346. #define AML_TYPE_LITERAL 0x0C
  347. #define AML_TYPE_CONSTANT 0x0D
  348. #define AML_TYPE_METHOD_ARGUMENT 0x0E
  349. #define AML_TYPE_LOCAL_VARIABLE 0x0F
  350. #define AML_TYPE_DATA_TERM 0x10
  351. /* Generic for an op that returns a value */
  352. #define AML_TYPE_METHOD_CALL 0x11
  353. /* Miscellaneous types */
  354. #define AML_TYPE_CREATE_FIELD 0x12
  355. #define AML_TYPE_CREATE_OBJECT 0x13
  356. #define AML_TYPE_CONTROL 0x14
  357. #define AML_TYPE_NAMED_NO_OBJ 0x15
  358. #define AML_TYPE_NAMED_FIELD 0x16
  359. #define AML_TYPE_NAMED_SIMPLE 0x17
  360. #define AML_TYPE_NAMED_COMPLEX 0x18
  361. #define AML_TYPE_RETURN 0x19
  362. #define AML_TYPE_UNDEFINED 0x1A
  363. #define AML_TYPE_BOGUS 0x1B
  364. /* AML Package Length encodings */
  365. #define ACPI_AML_PACKAGE_TYPE1 0x40
  366. #define ACPI_AML_PACKAGE_TYPE2 0x4000
  367. #define ACPI_AML_PACKAGE_TYPE3 0x400000
  368. #define ACPI_AML_PACKAGE_TYPE4 0x40000000
  369. /*
  370. * Opcode classes
  371. */
  372. #define AML_CLASS_EXECUTE 0x00
  373. #define AML_CLASS_CREATE 0x01
  374. #define AML_CLASS_ARGUMENT 0x02
  375. #define AML_CLASS_NAMED_OBJECT 0x03
  376. #define AML_CLASS_CONTROL 0x04
  377. #define AML_CLASS_ASCII 0x05
  378. #define AML_CLASS_PREFIX 0x06
  379. #define AML_CLASS_INTERNAL 0x07
  380. #define AML_CLASS_RETURN_VALUE 0x08
  381. #define AML_CLASS_METHOD_CALL 0x09
  382. #define AML_CLASS_UNKNOWN 0x0A
  383. /* Comparison operation codes for match_op operator */
  384. typedef enum {
  385. MATCH_MTR = 0,
  386. MATCH_MEQ = 1,
  387. MATCH_MLE = 2,
  388. MATCH_MLT = 3,
  389. MATCH_MGE = 4,
  390. MATCH_MGT = 5
  391. } AML_MATCH_OPERATOR;
  392. #define MAX_MATCH_OPERATOR 5
  393. /*
  394. * field_flags
  395. *
  396. * This byte is extracted from the AML and includes three separate
  397. * pieces of information about the field:
  398. * 1) The field access type
  399. * 2) The field update rule
  400. * 3) The lock rule for the field
  401. *
  402. * Bits 00 - 03 : access_type (any_acc, byte_acc, etc.)
  403. * 04 : lock_rule (1 == Lock)
  404. * 05 - 06 : update_rule
  405. */
  406. #define AML_FIELD_ACCESS_TYPE_MASK 0x0F
  407. #define AML_FIELD_LOCK_RULE_MASK 0x10
  408. #define AML_FIELD_UPDATE_RULE_MASK 0x60
  409. /* 1) Field Access Types */
  410. typedef enum {
  411. AML_FIELD_ACCESS_ANY = 0x00,
  412. AML_FIELD_ACCESS_BYTE = 0x01,
  413. AML_FIELD_ACCESS_WORD = 0x02,
  414. AML_FIELD_ACCESS_DWORD = 0x03,
  415. AML_FIELD_ACCESS_QWORD = 0x04, /* ACPI 2.0 */
  416. AML_FIELD_ACCESS_BUFFER = 0x05 /* ACPI 2.0 */
  417. } AML_ACCESS_TYPE;
  418. /* 2) Field Lock Rules */
  419. typedef enum {
  420. AML_FIELD_LOCK_NEVER = 0x00,
  421. AML_FIELD_LOCK_ALWAYS = 0x10
  422. } AML_LOCK_RULE;
  423. /* 3) Field Update Rules */
  424. typedef enum {
  425. AML_FIELD_UPDATE_PRESERVE = 0x00,
  426. AML_FIELD_UPDATE_WRITE_AS_ONES = 0x20,
  427. AML_FIELD_UPDATE_WRITE_AS_ZEROS = 0x40
  428. } AML_UPDATE_RULE;
  429. /*
  430. * Field Access Attributes.
  431. * This byte is extracted from the AML via the
  432. * access_as keyword
  433. */
  434. typedef enum {
  435. AML_FIELD_ATTRIB_QUICK = 0x02,
  436. AML_FIELD_ATTRIB_SEND_RCV = 0x04,
  437. AML_FIELD_ATTRIB_BYTE = 0x06,
  438. AML_FIELD_ATTRIB_WORD = 0x08,
  439. AML_FIELD_ATTRIB_BLOCK = 0x0A,
  440. AML_FIELD_ATTRIB_MULTIBYTE = 0x0B,
  441. AML_FIELD_ATTRIB_WORD_CALL = 0x0C,
  442. AML_FIELD_ATTRIB_BLOCK_CALL = 0x0D,
  443. AML_FIELD_ATTRIB_RAW_BYTES = 0x0E,
  444. AML_FIELD_ATTRIB_RAW_PROCESS = 0x0F
  445. } AML_ACCESS_ATTRIBUTE;
  446. /* Bit fields in the AML method_flags byte */
  447. #define AML_METHOD_ARG_COUNT 0x07
  448. #define AML_METHOD_SERIALIZED 0x08
  449. #define AML_METHOD_SYNC_LEVEL 0xF0
  450. #endif /* __AMLCODE_H__ */