Merge branch 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs-2.6
[linux-block.git] / include / acpi / acdisasm.h
CommitLineData
1da177e4
LT
1/******************************************************************************
2 *
3 * Name: acdisasm.h - AML disassembler
4 *
5 *****************************************************************************/
6
7/*
75a44ce0 8 * Copyright (C) 2000 - 2008, Intel Corp.
1da177e4
LT
9 * All rights reserved.
10 *
11 * Redistribution and use in source and binary forms, with or without
12 * modification, are permitted provided that the following conditions
13 * are met:
14 * 1. Redistributions of source code must retain the above copyright
15 * notice, this list of conditions, and the following disclaimer,
16 * without modification.
17 * 2. Redistributions in binary form must reproduce at minimum a disclaimer
18 * substantially similar to the "NO WARRANTY" disclaimer below
19 * ("Disclaimer") and any redistribution must be conditioned upon
20 * including a substantially similar Disclaimer requirement for further
21 * binary redistribution.
22 * 3. Neither the names of the above-listed copyright holders nor the names
23 * of any contributors may be used to endorse or promote products derived
24 * from this software without specific prior written permission.
25 *
26 * Alternatively, this software may be distributed under the terms of the
27 * GNU General Public License ("GPL") version 2 as published by the Free
28 * Software Foundation.
29 *
30 * NO WARRANTY
31 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
32 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
33 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
34 * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
35 * HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
36 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
37 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
38 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
39 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
40 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
41 * POSSIBILITY OF SUCH DAMAGES.
42 */
43
44#ifndef __ACDISASM_H__
45#define __ACDISASM_H__
46
47#include "amlresrc.h"
48
1da177e4
LT
49#define BLOCK_NONE 0
50#define BLOCK_PAREN 1
51#define BLOCK_BRACE 2
52#define BLOCK_COMMA_LIST 4
8313524a 53#define ACPI_DEFAULT_RESNAME *(u32 *) "__RD"
1da177e4 54
4be44fcd
LB
55struct acpi_external_list {
56 char *path;
958dd242 57 char *internal_path;
4be44fcd 58 struct acpi_external_list *next;
958dd242
BM
59 u32 value;
60 u16 length;
61 u8 type;
1da177e4
LT
62};
63
4be44fcd 64extern struct acpi_external_list *acpi_gbl_external_list;
defba1d8 65
793c2388
BM
66typedef const struct acpi_dmtable_info {
67 u8 opcode;
68 u8 offset;
69 char *name;
defba1d8 70
793c2388
BM
71} acpi_dmtable_info;
72
73/*
74 * Values for Opcode above.
75 * Note: 0-7 must not change, used as a flag shift value
76 */
77#define ACPI_DMT_FLAG0 0
78#define ACPI_DMT_FLAG1 1
79#define ACPI_DMT_FLAG2 2
80#define ACPI_DMT_FLAG3 3
81#define ACPI_DMT_FLAG4 4
82#define ACPI_DMT_FLAG5 5
83#define ACPI_DMT_FLAG6 6
84#define ACPI_DMT_FLAG7 7
85#define ACPI_DMT_FLAGS0 8
86#define ACPI_DMT_FLAGS2 9
87#define ACPI_DMT_UINT8 10
88#define ACPI_DMT_UINT16 11
89#define ACPI_DMT_UINT24 12
90#define ACPI_DMT_UINT32 13
91#define ACPI_DMT_UINT56 14
92#define ACPI_DMT_UINT64 15
93#define ACPI_DMT_STRING 16
94#define ACPI_DMT_NAME4 17
95#define ACPI_DMT_NAME6 18
96#define ACPI_DMT_NAME8 19
97#define ACPI_DMT_CHKSUM 20
98#define ACPI_DMT_SPACEID 21
99#define ACPI_DMT_GAS 22
a6f4a451
BM
100#define ACPI_DMT_ASF 23
101#define ACPI_DMT_DMAR 24
3fa34777
BM
102#define ACPI_DMT_HEST 25
103#define ACPI_DMT_HESTNTFY 26
104#define ACPI_DMT_HESTNTYP 27
105#define ACPI_DMT_MADT 28
106#define ACPI_DMT_SRAT 29
107#define ACPI_DMT_EXIT 30
108#define ACPI_DMT_SIG 31
793c2388
BM
109
110typedef
3e08e2d2 111void (*acpi_dmtable_handler) (struct acpi_table_header * table);
793c2388
BM
112
113struct acpi_dmtable_data {
114 char *signature;
115 struct acpi_dmtable_info *table_info;
3e08e2d2 116 acpi_dmtable_handler table_handler;
14d64b5e 117 char *name;
793c2388 118};
4be44fcd
LB
119
120struct acpi_op_walk_info {
121 u32 level;
958dd242
BM
122 u32 last_level;
123 u32 count;
4be44fcd 124 u32 bit_offset;
52fc0b02 125 u32 flags;
4be44fcd 126 struct acpi_walk_state *walk_state;
1da177e4
LT
127};
128
129typedef
4be44fcd
LB
130acpi_status(*asl_walk_callback) (union acpi_parse_object * op,
131 u32 level, void *context);
1da177e4 132
8313524a
BM
133struct acpi_resource_tag {
134 u32 bit_index;
135 char *tag;
136};
137
793c2388
BM
138/* Strings used for decoding flags to ASL keywords */
139
b229cf92
BM
140extern const char *acpi_gbl_word_decode[];
141extern const char *acpi_gbl_irq_decode[];
142extern const char *acpi_gbl_lock_rule[];
143extern const char *acpi_gbl_access_types[];
144extern const char *acpi_gbl_update_rules[];
145extern const char *acpi_gbl_match_ops[];
793c2388
BM
146
147extern struct acpi_dmtable_info acpi_dm_table_info_asf0[];
148extern struct acpi_dmtable_info acpi_dm_table_info_asf1[];
cc2a472b 149extern struct acpi_dmtable_info acpi_dm_table_info_asf1a[];
793c2388 150extern struct acpi_dmtable_info acpi_dm_table_info_asf2[];
cc2a472b 151extern struct acpi_dmtable_info acpi_dm_table_info_asf2a[];
793c2388
BM
152extern struct acpi_dmtable_info acpi_dm_table_info_asf3[];
153extern struct acpi_dmtable_info acpi_dm_table_info_asf4[];
154extern struct acpi_dmtable_info acpi_dm_table_info_asf_hdr[];
155extern struct acpi_dmtable_info acpi_dm_table_info_boot[];
3fa34777 156extern struct acpi_dmtable_info acpi_dm_table_info_bert[];
793c2388
BM
157extern struct acpi_dmtable_info acpi_dm_table_info_cpep[];
158extern struct acpi_dmtable_info acpi_dm_table_info_cpep0[];
159extern struct acpi_dmtable_info acpi_dm_table_info_dbgp[];
2502fffb
BM
160extern struct acpi_dmtable_info acpi_dm_table_info_dmar[];
161extern struct acpi_dmtable_info acpi_dm_table_info_dmar_hdr[];
162extern struct acpi_dmtable_info acpi_dm_table_info_dmar_scope[];
163extern struct acpi_dmtable_info acpi_dm_table_info_dmar0[];
164extern struct acpi_dmtable_info acpi_dm_table_info_dmar1[];
75e5b5fb 165extern struct acpi_dmtable_info acpi_dm_table_info_dmar2[];
793c2388 166extern struct acpi_dmtable_info acpi_dm_table_info_ecdt[];
3fa34777
BM
167extern struct acpi_dmtable_info acpi_dm_table_info_einj[];
168extern struct acpi_dmtable_info acpi_dm_table_info_einj0[];
169extern struct acpi_dmtable_info acpi_dm_table_info_erst[];
793c2388
BM
170extern struct acpi_dmtable_info acpi_dm_table_info_facs[];
171extern struct acpi_dmtable_info acpi_dm_table_info_fadt1[];
172extern struct acpi_dmtable_info acpi_dm_table_info_fadt2[];
173extern struct acpi_dmtable_info acpi_dm_table_info_gas[];
174extern struct acpi_dmtable_info acpi_dm_table_info_header[];
3fa34777
BM
175extern struct acpi_dmtable_info acpi_dm_table_info_hest[];
176extern struct acpi_dmtable_info acpi_dm_table_info_hest9[];
177extern struct acpi_dmtable_info acpi_dm_table_info_hest_notify[];
793c2388
BM
178extern struct acpi_dmtable_info acpi_dm_table_info_hpet[];
179extern struct acpi_dmtable_info acpi_dm_table_info_madt[];
180extern struct acpi_dmtable_info acpi_dm_table_info_madt0[];
181extern struct acpi_dmtable_info acpi_dm_table_info_madt1[];
182extern struct acpi_dmtable_info acpi_dm_table_info_madt2[];
183extern struct acpi_dmtable_info acpi_dm_table_info_madt3[];
184extern struct acpi_dmtable_info acpi_dm_table_info_madt4[];
185extern struct acpi_dmtable_info acpi_dm_table_info_madt5[];
186extern struct acpi_dmtable_info acpi_dm_table_info_madt6[];
187extern struct acpi_dmtable_info acpi_dm_table_info_madt7[];
188extern struct acpi_dmtable_info acpi_dm_table_info_madt8[];
1d7cc030
BM
189extern struct acpi_dmtable_info acpi_dm_table_info_madt9[];
190extern struct acpi_dmtable_info acpi_dm_table_info_madt10[];
793c2388
BM
191extern struct acpi_dmtable_info acpi_dm_table_info_madt_hdr[];
192extern struct acpi_dmtable_info acpi_dm_table_info_mcfg[];
193extern struct acpi_dmtable_info acpi_dm_table_info_mcfg0[];
194extern struct acpi_dmtable_info acpi_dm_table_info_rsdp1[];
195extern struct acpi_dmtable_info acpi_dm_table_info_rsdp2[];
196extern struct acpi_dmtable_info acpi_dm_table_info_sbst[];
698c0a0c 197extern struct acpi_dmtable_info acpi_dm_table_info_slic[];
793c2388
BM
198extern struct acpi_dmtable_info acpi_dm_table_info_slit[];
199extern struct acpi_dmtable_info acpi_dm_table_info_spcr[];
200extern struct acpi_dmtable_info acpi_dm_table_info_spmi[];
201extern struct acpi_dmtable_info acpi_dm_table_info_srat[];
1d7cc030 202extern struct acpi_dmtable_info acpi_dm_table_info_srat_hdr[];
793c2388
BM
203extern struct acpi_dmtable_info acpi_dm_table_info_srat0[];
204extern struct acpi_dmtable_info acpi_dm_table_info_srat1[];
1d7cc030 205extern struct acpi_dmtable_info acpi_dm_table_info_srat2[];
793c2388
BM
206extern struct acpi_dmtable_info acpi_dm_table_info_tcpa[];
207extern struct acpi_dmtable_info acpi_dm_table_info_wdrt[];
208
209/*
210 * dmtable
211 */
212void acpi_dm_dump_data_table(struct acpi_table_header *table);
213
a6f4a451 214acpi_status
793c2388
BM
215acpi_dm_dump_table(u32 table_length,
216 u32 table_offset,
217 void *table,
218 u32 sub_table_length, struct acpi_dmtable_info *info);
219
220void acpi_dm_line_header(u32 offset, u32 byte_length, char *name);
221
222void acpi_dm_line_header2(u32 offset, u32 byte_length, char *name, u32 value);
223
224/*
225 * dmtbdump
226 */
227void acpi_dm_dump_asf(struct acpi_table_header *table);
228
229void acpi_dm_dump_cpep(struct acpi_table_header *table);
230
2502fffb
BM
231void acpi_dm_dump_dmar(struct acpi_table_header *table);
232
3fa34777
BM
233void acpi_dm_dump_einj(struct acpi_table_header *table);
234
235void acpi_dm_dump_erst(struct acpi_table_header *table);
236
793c2388
BM
237void acpi_dm_dump_fadt(struct acpi_table_header *table);
238
3fa34777 239void acpi_dm_dump_hest(struct acpi_table_header *table);
793c2388
BM
240
241void acpi_dm_dump_mcfg(struct acpi_table_header *table);
242
243void acpi_dm_dump_madt(struct acpi_table_header *table);
244
245u32 acpi_dm_dump_rsdp(struct acpi_table_header *table);
246
247void acpi_dm_dump_rsdt(struct acpi_table_header *table);
248
249void acpi_dm_dump_slit(struct acpi_table_header *table);
250
3fa34777
BM
251void acpi_dm_dump_srat(struct acpi_table_header *table);
252
793c2388
BM
253void acpi_dm_dump_xsdt(struct acpi_table_header *table);
254
1da177e4
LT
255/*
256 * dmwalk
257 */
1da177e4 258void
4be44fcd
LB
259acpi_dm_disassemble(struct acpi_walk_state *walk_state,
260 union acpi_parse_object *origin, u32 num_opcodes);
1da177e4 261
8313524a
BM
262void
263acpi_dm_walk_parse_tree(union acpi_parse_object *op,
264 asl_walk_callback descending_callback,
265 asl_walk_callback ascending_callback, void *context);
266
44f6c012
RM
267/*
268 * dmopcode
269 */
1da177e4 270void
4be44fcd
LB
271acpi_dm_disassemble_one_op(struct acpi_walk_state *walk_state,
272 struct acpi_op_walk_info *info,
273 union acpi_parse_object *op);
1da177e4 274
4be44fcd 275void acpi_dm_decode_internal_object(union acpi_operand_object *obj_desc);
1da177e4 276
4be44fcd 277u32 acpi_dm_list_type(union acpi_parse_object *op);
1da177e4 278
4be44fcd 279void acpi_dm_method_flags(union acpi_parse_object *op);
1da177e4 280
4be44fcd 281void acpi_dm_field_flags(union acpi_parse_object *op);
1da177e4 282
4be44fcd 283void acpi_dm_address_space(u8 space_id);
1da177e4 284
4be44fcd 285void acpi_dm_region_flags(union acpi_parse_object *op);
1da177e4 286
4be44fcd 287void acpi_dm_match_op(union acpi_parse_object *op);
1da177e4 288
4be44fcd 289u8 acpi_dm_comma_if_list_member(union acpi_parse_object *op);
1da177e4 290
4be44fcd 291void acpi_dm_comma_if_field_member(union acpi_parse_object *op);
1da177e4
LT
292
293/*
44f6c012 294 * dmnames
1da177e4 295 */
4be44fcd 296u32 acpi_dm_dump_name(char *name);
44f6c012
RM
297
298acpi_status
4be44fcd
LB
299acpi_ps_display_object_pathname(struct acpi_walk_state *walk_state,
300 union acpi_parse_object *op);
44f6c012 301
4be44fcd 302void acpi_dm_namestring(char *name);
1da177e4 303
44f6c012
RM
304/*
305 * dmobject
306 */
1da177e4 307void
4be44fcd
LB
308acpi_dm_display_internal_object(union acpi_operand_object *obj_desc,
309 struct acpi_walk_state *walk_state);
1da177e4 310
4be44fcd 311void acpi_dm_display_arguments(struct acpi_walk_state *walk_state);
1da177e4 312
4be44fcd 313void acpi_dm_display_locals(struct acpi_walk_state *walk_state);
1da177e4
LT
314
315void
4be44fcd
LB
316acpi_dm_dump_method_info(acpi_status status,
317 struct acpi_walk_state *walk_state,
318 union acpi_parse_object *op);
1da177e4
LT
319
320/*
321 * dmbuffer
322 */
4be44fcd 323void acpi_dm_disasm_byte_list(u32 level, u8 * byte_data, u32 byte_count);
44f6c012
RM
324
325void
4be44fcd 326acpi_dm_byte_list(struct acpi_op_walk_info *info, union acpi_parse_object *op);
1da177e4 327
4be44fcd 328void acpi_dm_is_eisa_id(union acpi_parse_object *op);
1da177e4 329
4be44fcd 330void acpi_dm_eisa_id(u32 encoded_id);
1da177e4 331
4be44fcd 332u8 acpi_dm_is_unicode_buffer(union acpi_parse_object *op);
1da177e4 333
4be44fcd 334u8 acpi_dm_is_string_buffer(union acpi_parse_object *op);
1da177e4
LT
335
336/*
337 * dmresrc
338 */
0897831b
BM
339void acpi_dm_dump_integer8(u8 value, char *name);
340
341void acpi_dm_dump_integer16(u16 value, char *name);
342
343void acpi_dm_dump_integer32(u32 value, char *name);
344
345void acpi_dm_dump_integer64(u64 value, char *name);
346
1da177e4 347void
0897831b 348acpi_dm_resource_template(struct acpi_op_walk_info *info,
8313524a 349 union acpi_parse_object *op,
0897831b 350 u8 * byte_data, u32 byte_count);
1da177e4 351
cc2a472b 352acpi_status acpi_dm_is_resource_template(union acpi_parse_object *op);
1da177e4 353
4be44fcd 354void acpi_dm_indent(u32 level);
1da177e4 355
4be44fcd 356void acpi_dm_bit_list(u16 mask);
1da177e4 357
4be44fcd 358void acpi_dm_decode_attribute(u8 attribute);
44f6c012 359
8313524a
BM
360void acpi_dm_descriptor_name(void);
361
1da177e4
LT
362/*
363 * dmresrcl
364 */
1da177e4 365void
50eca3eb 366acpi_dm_word_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4
LT
367
368void
50eca3eb 369acpi_dm_dword_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4
LT
370
371void
50eca3eb 372acpi_dm_extended_descriptor(union aml_resource *resource,
4be44fcd 373 u32 length, u32 level);
1da177e4
LT
374
375void
50eca3eb 376acpi_dm_qword_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4
LT
377
378void
50eca3eb 379acpi_dm_memory24_descriptor(union aml_resource *resource,
4be44fcd 380 u32 length, u32 level);
1da177e4
LT
381
382void
50eca3eb 383acpi_dm_memory32_descriptor(union aml_resource *resource,
4be44fcd 384 u32 length, u32 level);
1da177e4
LT
385
386void
50eca3eb 387acpi_dm_fixed_memory32_descriptor(union aml_resource *resource,
bda663d3 388 u32 length, u32 level);
1da177e4
LT
389
390void
50eca3eb 391acpi_dm_generic_register_descriptor(union aml_resource *resource,
4be44fcd 392 u32 length, u32 level);
1da177e4
LT
393
394void
50eca3eb 395acpi_dm_interrupt_descriptor(union aml_resource *resource,
4be44fcd 396 u32 length, u32 level);
1da177e4
LT
397
398void
50eca3eb 399acpi_dm_vendor_large_descriptor(union aml_resource *resource,
4be44fcd 400 u32 length, u32 level);
1da177e4 401
0897831b
BM
402void acpi_dm_vendor_common(char *name, u8 * byte_data, u32 length, u32 level);
403
1da177e4
LT
404/*
405 * dmresrcs
406 */
1da177e4 407void
50eca3eb 408acpi_dm_irq_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4
LT
409
410void
50eca3eb 411acpi_dm_dma_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4 412
50eca3eb 413void acpi_dm_io_descriptor(union aml_resource *resource, u32 length, u32 level);
1da177e4
LT
414
415void
50eca3eb 416acpi_dm_fixed_io_descriptor(union aml_resource *resource,
4be44fcd 417 u32 length, u32 level);
1da177e4
LT
418
419void
50eca3eb 420acpi_dm_start_dependent_descriptor(union aml_resource *resource,
4be44fcd 421 u32 length, u32 level);
1da177e4
LT
422
423void
50eca3eb 424acpi_dm_end_dependent_descriptor(union aml_resource *resource,
4be44fcd 425 u32 length, u32 level);
1da177e4
LT
426
427void
50eca3eb 428acpi_dm_vendor_small_descriptor(union aml_resource *resource,
4be44fcd 429 u32 length, u32 level);
1da177e4
LT
430
431/*
432 * dmutils
433 */
958dd242 434void acpi_dm_add_to_external_list(char *path, u8 type, u32 value);
1da177e4 435
8313524a
BM
436/*
437 * dmrestag
438 */
439void acpi_dm_find_resources(union acpi_parse_object *root);
440
441void
442acpi_dm_check_resource_reference(union acpi_parse_object *op,
443 struct acpi_walk_state *walk_state);
444
4be44fcd 445#endif /* __ACDISASM_H__ */