at v2.6.19-rc3 410 lines 13 kB view raw
1/****************************************************************************** 2 * 3 * Name: acdisasm.h - AML disassembler 4 * 5 *****************************************************************************/ 6 7/* 8 * Copyright (C) 2000 - 2006, R. Byron Moore 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 49#define BLOCK_NONE 0 50#define BLOCK_PAREN 1 51#define BLOCK_BRACE 2 52#define BLOCK_COMMA_LIST 4 53#define ACPI_DEFAULT_RESNAME *(u32 *) "__RD" 54 55struct acpi_external_list { 56 char *path; 57 char *internal_path; 58 struct acpi_external_list *next; 59 u32 value; 60 u16 length; 61 u8 type; 62}; 63 64extern struct acpi_external_list *acpi_gbl_external_list; 65 66typedef const struct acpi_dmtable_info { 67 u8 opcode; 68 u8 offset; 69 char *name; 70 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 100#define ACPI_DMT_MADT 23 101#define ACPI_DMT_SRAT 24 102#define ACPI_DMT_EXIT 25 103 104typedef 105void (*ACPI_TABLE_HANDLER) (struct acpi_table_header * table); 106 107struct acpi_dmtable_data { 108 char *signature; 109 struct acpi_dmtable_info *table_info; 110 ACPI_TABLE_HANDLER table_handler; 111}; 112 113struct acpi_op_walk_info { 114 u32 level; 115 u32 last_level; 116 u32 count; 117 u32 bit_offset; 118 u32 flags; 119 struct acpi_walk_state *walk_state; 120}; 121 122typedef 123acpi_status(*asl_walk_callback) (union acpi_parse_object * op, 124 u32 level, void *context); 125 126struct acpi_resource_tag { 127 u32 bit_index; 128 char *tag; 129}; 130 131/* Strings used for decoding flags to ASL keywords */ 132 133extern const char *acpi_gbl_word_decode[]; 134extern const char *acpi_gbl_irq_decode[]; 135extern const char *acpi_gbl_lock_rule[]; 136extern const char *acpi_gbl_access_types[]; 137extern const char *acpi_gbl_update_rules[]; 138extern const char *acpi_gbl_match_ops[]; 139 140extern struct acpi_dmtable_info acpi_dm_table_info_asf0[]; 141extern struct acpi_dmtable_info acpi_dm_table_info_asf1[]; 142extern struct acpi_dmtable_info acpi_dm_table_info_asf2[]; 143extern struct acpi_dmtable_info acpi_dm_table_info_asf3[]; 144extern struct acpi_dmtable_info acpi_dm_table_info_asf4[]; 145extern struct acpi_dmtable_info acpi_dm_table_info_asf_hdr[]; 146extern struct acpi_dmtable_info acpi_dm_table_info_boot[]; 147extern struct acpi_dmtable_info acpi_dm_table_info_cpep[]; 148extern struct acpi_dmtable_info acpi_dm_table_info_cpep0[]; 149extern struct acpi_dmtable_info acpi_dm_table_info_dbgp[]; 150extern struct acpi_dmtable_info acpi_dm_table_info_ecdt[]; 151extern struct acpi_dmtable_info acpi_dm_table_info_facs[]; 152extern struct acpi_dmtable_info acpi_dm_table_info_fadt1[]; 153extern struct acpi_dmtable_info acpi_dm_table_info_fadt2[]; 154extern struct acpi_dmtable_info acpi_dm_table_info_gas[]; 155extern struct acpi_dmtable_info acpi_dm_table_info_header[]; 156extern struct acpi_dmtable_info acpi_dm_table_info_hpet[]; 157extern struct acpi_dmtable_info acpi_dm_table_info_madt[]; 158extern struct acpi_dmtable_info acpi_dm_table_info_madt0[]; 159extern struct acpi_dmtable_info acpi_dm_table_info_madt1[]; 160extern struct acpi_dmtable_info acpi_dm_table_info_madt2[]; 161extern struct acpi_dmtable_info acpi_dm_table_info_madt3[]; 162extern struct acpi_dmtable_info acpi_dm_table_info_madt4[]; 163extern struct acpi_dmtable_info acpi_dm_table_info_madt5[]; 164extern struct acpi_dmtable_info acpi_dm_table_info_madt6[]; 165extern struct acpi_dmtable_info acpi_dm_table_info_madt7[]; 166extern struct acpi_dmtable_info acpi_dm_table_info_madt8[]; 167extern struct acpi_dmtable_info acpi_dm_table_info_madt_hdr[]; 168extern struct acpi_dmtable_info acpi_dm_table_info_mcfg[]; 169extern struct acpi_dmtable_info acpi_dm_table_info_mcfg0[]; 170extern struct acpi_dmtable_info acpi_dm_table_info_rsdp1[]; 171extern struct acpi_dmtable_info acpi_dm_table_info_rsdp2[]; 172extern struct acpi_dmtable_info acpi_dm_table_info_sbst[]; 173extern struct acpi_dmtable_info acpi_dm_table_info_slit[]; 174extern struct acpi_dmtable_info acpi_dm_table_info_spcr[]; 175extern struct acpi_dmtable_info acpi_dm_table_info_spmi[]; 176extern struct acpi_dmtable_info acpi_dm_table_info_srat[]; 177extern struct acpi_dmtable_info acpi_dm_table_info_srat0[]; 178extern struct acpi_dmtable_info acpi_dm_table_info_srat1[]; 179extern struct acpi_dmtable_info acpi_dm_table_info_tcpa[]; 180extern struct acpi_dmtable_info acpi_dm_table_info_wdrt[]; 181 182/* 183 * dmtable 184 */ 185void acpi_dm_dump_data_table(struct acpi_table_header *table); 186 187void 188acpi_dm_dump_table(u32 table_length, 189 u32 table_offset, 190 void *table, 191 u32 sub_table_length, struct acpi_dmtable_info *info); 192 193void acpi_dm_line_header(u32 offset, u32 byte_length, char *name); 194 195void acpi_dm_line_header2(u32 offset, u32 byte_length, char *name, u32 value); 196 197/* 198 * dmtbdump 199 */ 200void acpi_dm_dump_asf(struct acpi_table_header *table); 201 202void acpi_dm_dump_cpep(struct acpi_table_header *table); 203 204void acpi_dm_dump_fadt(struct acpi_table_header *table); 205 206void acpi_dm_dump_srat(struct acpi_table_header *table); 207 208void acpi_dm_dump_mcfg(struct acpi_table_header *table); 209 210void acpi_dm_dump_madt(struct acpi_table_header *table); 211 212u32 acpi_dm_dump_rsdp(struct acpi_table_header *table); 213 214void acpi_dm_dump_rsdt(struct acpi_table_header *table); 215 216void acpi_dm_dump_slit(struct acpi_table_header *table); 217 218void acpi_dm_dump_xsdt(struct acpi_table_header *table); 219 220/* 221 * dmwalk 222 */ 223void 224acpi_dm_disassemble(struct acpi_walk_state *walk_state, 225 union acpi_parse_object *origin, u32 num_opcodes); 226 227void 228acpi_dm_walk_parse_tree(union acpi_parse_object *op, 229 asl_walk_callback descending_callback, 230 asl_walk_callback ascending_callback, void *context); 231 232/* 233 * dmopcode 234 */ 235void 236acpi_dm_disassemble_one_op(struct acpi_walk_state *walk_state, 237 struct acpi_op_walk_info *info, 238 union acpi_parse_object *op); 239 240void acpi_dm_decode_internal_object(union acpi_operand_object *obj_desc); 241 242u32 acpi_dm_list_type(union acpi_parse_object *op); 243 244void acpi_dm_method_flags(union acpi_parse_object *op); 245 246void acpi_dm_field_flags(union acpi_parse_object *op); 247 248void acpi_dm_address_space(u8 space_id); 249 250void acpi_dm_region_flags(union acpi_parse_object *op); 251 252void acpi_dm_match_op(union acpi_parse_object *op); 253 254u8 acpi_dm_comma_if_list_member(union acpi_parse_object *op); 255 256void acpi_dm_comma_if_field_member(union acpi_parse_object *op); 257 258/* 259 * dmnames 260 */ 261u32 acpi_dm_dump_name(char *name); 262 263acpi_status 264acpi_ps_display_object_pathname(struct acpi_walk_state *walk_state, 265 union acpi_parse_object *op); 266 267void acpi_dm_namestring(char *name); 268 269/* 270 * dmobject 271 */ 272void 273acpi_dm_display_internal_object(union acpi_operand_object *obj_desc, 274 struct acpi_walk_state *walk_state); 275 276void acpi_dm_display_arguments(struct acpi_walk_state *walk_state); 277 278void acpi_dm_display_locals(struct acpi_walk_state *walk_state); 279 280void 281acpi_dm_dump_method_info(acpi_status status, 282 struct acpi_walk_state *walk_state, 283 union acpi_parse_object *op); 284 285/* 286 * dmbuffer 287 */ 288void acpi_dm_disasm_byte_list(u32 level, u8 * byte_data, u32 byte_count); 289 290void 291acpi_dm_byte_list(struct acpi_op_walk_info *info, union acpi_parse_object *op); 292 293void acpi_dm_is_eisa_id(union acpi_parse_object *op); 294 295void acpi_dm_eisa_id(u32 encoded_id); 296 297u8 acpi_dm_is_unicode_buffer(union acpi_parse_object *op); 298 299u8 acpi_dm_is_string_buffer(union acpi_parse_object *op); 300 301/* 302 * dmresrc 303 */ 304void acpi_dm_dump_integer8(u8 value, char *name); 305 306void acpi_dm_dump_integer16(u16 value, char *name); 307 308void acpi_dm_dump_integer32(u32 value, char *name); 309 310void acpi_dm_dump_integer64(u64 value, char *name); 311 312void 313acpi_dm_resource_template(struct acpi_op_walk_info *info, 314 union acpi_parse_object *op, 315 u8 * byte_data, u32 byte_count); 316 317u8 acpi_dm_is_resource_template(union acpi_parse_object *op); 318 319void acpi_dm_indent(u32 level); 320 321void acpi_dm_bit_list(u16 mask); 322 323void acpi_dm_decode_attribute(u8 attribute); 324 325void acpi_dm_descriptor_name(void); 326 327/* 328 * dmresrcl 329 */ 330void 331acpi_dm_word_descriptor(union aml_resource *resource, u32 length, u32 level); 332 333void 334acpi_dm_dword_descriptor(union aml_resource *resource, u32 length, u32 level); 335 336void 337acpi_dm_extended_descriptor(union aml_resource *resource, 338 u32 length, u32 level); 339 340void 341acpi_dm_qword_descriptor(union aml_resource *resource, u32 length, u32 level); 342 343void 344acpi_dm_memory24_descriptor(union aml_resource *resource, 345 u32 length, u32 level); 346 347void 348acpi_dm_memory32_descriptor(union aml_resource *resource, 349 u32 length, u32 level); 350 351void 352acpi_dm_fixed_memory32_descriptor(union aml_resource *resource, 353 u32 length, u32 level); 354 355void 356acpi_dm_generic_register_descriptor(union aml_resource *resource, 357 u32 length, u32 level); 358 359void 360acpi_dm_interrupt_descriptor(union aml_resource *resource, 361 u32 length, u32 level); 362 363void 364acpi_dm_vendor_large_descriptor(union aml_resource *resource, 365 u32 length, u32 level); 366 367void acpi_dm_vendor_common(char *name, u8 * byte_data, u32 length, u32 level); 368 369/* 370 * dmresrcs 371 */ 372void 373acpi_dm_irq_descriptor(union aml_resource *resource, u32 length, u32 level); 374 375void 376acpi_dm_dma_descriptor(union aml_resource *resource, u32 length, u32 level); 377 378void acpi_dm_io_descriptor(union aml_resource *resource, u32 length, u32 level); 379 380void 381acpi_dm_fixed_io_descriptor(union aml_resource *resource, 382 u32 length, u32 level); 383 384void 385acpi_dm_start_dependent_descriptor(union aml_resource *resource, 386 u32 length, u32 level); 387 388void 389acpi_dm_end_dependent_descriptor(union aml_resource *resource, 390 u32 length, u32 level); 391 392void 393acpi_dm_vendor_small_descriptor(union aml_resource *resource, 394 u32 length, u32 level); 395 396/* 397 * dmutils 398 */ 399void acpi_dm_add_to_external_list(char *path, u8 type, u32 value); 400 401/* 402 * dmrestag 403 */ 404void acpi_dm_find_resources(union acpi_parse_object *root); 405 406void 407acpi_dm_check_resource_reference(union acpi_parse_object *op, 408 struct acpi_walk_state *walk_state); 409 410#endif /* __ACDISASM_H__ */