446 строки
14 KiB
C
446 строки
14 KiB
C
/******************************************************************************
|
|
*
|
|
* Name: acdisasm.h - AML disassembler
|
|
*
|
|
*****************************************************************************/
|
|
|
|
/*
|
|
* Copyright (C) 2000 - 2008, Intel Corp.
|
|
* All rights reserved.
|
|
*
|
|
* Redistribution and use in source and binary forms, with or without
|
|
* modification, are permitted provided that the following conditions
|
|
* are met:
|
|
* 1. Redistributions of source code must retain the above copyright
|
|
* notice, this list of conditions, and the following disclaimer,
|
|
* without modification.
|
|
* 2. Redistributions in binary form must reproduce at minimum a disclaimer
|
|
* substantially similar to the "NO WARRANTY" disclaimer below
|
|
* ("Disclaimer") and any redistribution must be conditioned upon
|
|
* including a substantially similar Disclaimer requirement for further
|
|
* binary redistribution.
|
|
* 3. Neither the names of the above-listed copyright holders nor the names
|
|
* of any contributors may be used to endorse or promote products derived
|
|
* from this software without specific prior written permission.
|
|
*
|
|
* Alternatively, this software may be distributed under the terms of the
|
|
* GNU General Public License ("GPL") version 2 as published by the Free
|
|
* Software Foundation.
|
|
*
|
|
* NO WARRANTY
|
|
* THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
* "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
|
* LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR
|
|
* A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
|
* HOLDERS OR CONTRIBUTORS BE LIABLE FOR SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
|
|
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
|
|
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
* STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
* IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
* POSSIBILITY OF SUCH DAMAGES.
|
|
*/
|
|
|
|
#ifndef __ACDISASM_H__
|
|
#define __ACDISASM_H__
|
|
|
|
#include "amlresrc.h"
|
|
|
|
#define BLOCK_NONE 0
|
|
#define BLOCK_PAREN 1
|
|
#define BLOCK_BRACE 2
|
|
#define BLOCK_COMMA_LIST 4
|
|
#define ACPI_DEFAULT_RESNAME *(u32 *) "__RD"
|
|
|
|
struct acpi_external_list {
|
|
char *path;
|
|
char *internal_path;
|
|
struct acpi_external_list *next;
|
|
u32 value;
|
|
u16 length;
|
|
u8 type;
|
|
};
|
|
|
|
extern struct acpi_external_list *acpi_gbl_external_list;
|
|
|
|
typedef const struct acpi_dmtable_info {
|
|
u8 opcode;
|
|
u8 offset;
|
|
char *name;
|
|
|
|
} acpi_dmtable_info;
|
|
|
|
/*
|
|
* Values for Opcode above.
|
|
* Note: 0-7 must not change, used as a flag shift value
|
|
*/
|
|
#define ACPI_DMT_FLAG0 0
|
|
#define ACPI_DMT_FLAG1 1
|
|
#define ACPI_DMT_FLAG2 2
|
|
#define ACPI_DMT_FLAG3 3
|
|
#define ACPI_DMT_FLAG4 4
|
|
#define ACPI_DMT_FLAG5 5
|
|
#define ACPI_DMT_FLAG6 6
|
|
#define ACPI_DMT_FLAG7 7
|
|
#define ACPI_DMT_FLAGS0 8
|
|
#define ACPI_DMT_FLAGS2 9
|
|
#define ACPI_DMT_UINT8 10
|
|
#define ACPI_DMT_UINT16 11
|
|
#define ACPI_DMT_UINT24 12
|
|
#define ACPI_DMT_UINT32 13
|
|
#define ACPI_DMT_UINT56 14
|
|
#define ACPI_DMT_UINT64 15
|
|
#define ACPI_DMT_STRING 16
|
|
#define ACPI_DMT_NAME4 17
|
|
#define ACPI_DMT_NAME6 18
|
|
#define ACPI_DMT_NAME8 19
|
|
#define ACPI_DMT_CHKSUM 20
|
|
#define ACPI_DMT_SPACEID 21
|
|
#define ACPI_DMT_GAS 22
|
|
#define ACPI_DMT_ASF 23
|
|
#define ACPI_DMT_DMAR 24
|
|
#define ACPI_DMT_HEST 25
|
|
#define ACPI_DMT_HESTNTFY 26
|
|
#define ACPI_DMT_HESTNTYP 27
|
|
#define ACPI_DMT_MADT 28
|
|
#define ACPI_DMT_SRAT 29
|
|
#define ACPI_DMT_EXIT 30
|
|
#define ACPI_DMT_SIG 31
|
|
|
|
typedef
|
|
void (*acpi_dmtable_handler) (struct acpi_table_header * table);
|
|
|
|
struct acpi_dmtable_data {
|
|
char *signature;
|
|
struct acpi_dmtable_info *table_info;
|
|
acpi_dmtable_handler table_handler;
|
|
char *name;
|
|
};
|
|
|
|
struct acpi_op_walk_info {
|
|
u32 level;
|
|
u32 last_level;
|
|
u32 count;
|
|
u32 bit_offset;
|
|
u32 flags;
|
|
struct acpi_walk_state *walk_state;
|
|
};
|
|
|
|
typedef
|
|
acpi_status(*asl_walk_callback) (union acpi_parse_object * op,
|
|
u32 level, void *context);
|
|
|
|
struct acpi_resource_tag {
|
|
u32 bit_index;
|
|
char *tag;
|
|
};
|
|
|
|
/* Strings used for decoding flags to ASL keywords */
|
|
|
|
extern const char *acpi_gbl_word_decode[];
|
|
extern const char *acpi_gbl_irq_decode[];
|
|
extern const char *acpi_gbl_lock_rule[];
|
|
extern const char *acpi_gbl_access_types[];
|
|
extern const char *acpi_gbl_update_rules[];
|
|
extern const char *acpi_gbl_match_ops[];
|
|
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf1a[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf2a[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf3[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf4[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_asf_hdr[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_boot[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_bert[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_cpep[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_cpep0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dbgp[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar_hdr[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar_scope[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_dmar2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_ecdt[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_einj[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_einj0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_erst[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_facs[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_fadt1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_fadt2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_gas[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_header[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_hest[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_hest9[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_hest_notify[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_hpet[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt3[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt4[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt5[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt6[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt7[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt8[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt9[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt10[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_madt_hdr[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_mcfg[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_mcfg0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_rsdp1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_rsdp2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_sbst[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_slic[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_slit[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_spcr[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_spmi[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_srat[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_srat_hdr[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_srat0[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_srat1[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_srat2[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_tcpa[];
|
|
extern struct acpi_dmtable_info acpi_dm_table_info_wdrt[];
|
|
|
|
/*
|
|
* dmtable
|
|
*/
|
|
void acpi_dm_dump_data_table(struct acpi_table_header *table);
|
|
|
|
acpi_status
|
|
acpi_dm_dump_table(u32 table_length,
|
|
u32 table_offset,
|
|
void *table,
|
|
u32 sub_table_length, struct acpi_dmtable_info *info);
|
|
|
|
void acpi_dm_line_header(u32 offset, u32 byte_length, char *name);
|
|
|
|
void acpi_dm_line_header2(u32 offset, u32 byte_length, char *name, u32 value);
|
|
|
|
/*
|
|
* dmtbdump
|
|
*/
|
|
void acpi_dm_dump_asf(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_cpep(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_dmar(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_einj(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_erst(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_fadt(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_hest(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_mcfg(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_madt(struct acpi_table_header *table);
|
|
|
|
u32 acpi_dm_dump_rsdp(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_rsdt(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_slit(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_srat(struct acpi_table_header *table);
|
|
|
|
void acpi_dm_dump_xsdt(struct acpi_table_header *table);
|
|
|
|
/*
|
|
* dmwalk
|
|
*/
|
|
void
|
|
acpi_dm_disassemble(struct acpi_walk_state *walk_state,
|
|
union acpi_parse_object *origin, u32 num_opcodes);
|
|
|
|
void
|
|
acpi_dm_walk_parse_tree(union acpi_parse_object *op,
|
|
asl_walk_callback descending_callback,
|
|
asl_walk_callback ascending_callback, void *context);
|
|
|
|
/*
|
|
* dmopcode
|
|
*/
|
|
void
|
|
acpi_dm_disassemble_one_op(struct acpi_walk_state *walk_state,
|
|
struct acpi_op_walk_info *info,
|
|
union acpi_parse_object *op);
|
|
|
|
void acpi_dm_decode_internal_object(union acpi_operand_object *obj_desc);
|
|
|
|
u32 acpi_dm_list_type(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_method_flags(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_field_flags(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_address_space(u8 space_id);
|
|
|
|
void acpi_dm_region_flags(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_match_op(union acpi_parse_object *op);
|
|
|
|
u8 acpi_dm_comma_if_list_member(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_comma_if_field_member(union acpi_parse_object *op);
|
|
|
|
/*
|
|
* dmnames
|
|
*/
|
|
u32 acpi_dm_dump_name(char *name);
|
|
|
|
acpi_status
|
|
acpi_ps_display_object_pathname(struct acpi_walk_state *walk_state,
|
|
union acpi_parse_object *op);
|
|
|
|
void acpi_dm_namestring(char *name);
|
|
|
|
/*
|
|
* dmobject
|
|
*/
|
|
void
|
|
acpi_dm_display_internal_object(union acpi_operand_object *obj_desc,
|
|
struct acpi_walk_state *walk_state);
|
|
|
|
void acpi_dm_display_arguments(struct acpi_walk_state *walk_state);
|
|
|
|
void acpi_dm_display_locals(struct acpi_walk_state *walk_state);
|
|
|
|
void
|
|
acpi_dm_dump_method_info(acpi_status status,
|
|
struct acpi_walk_state *walk_state,
|
|
union acpi_parse_object *op);
|
|
|
|
/*
|
|
* dmbuffer
|
|
*/
|
|
void acpi_dm_disasm_byte_list(u32 level, u8 * byte_data, u32 byte_count);
|
|
|
|
void
|
|
acpi_dm_byte_list(struct acpi_op_walk_info *info, union acpi_parse_object *op);
|
|
|
|
void acpi_dm_is_eisa_id(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_eisa_id(u32 encoded_id);
|
|
|
|
u8 acpi_dm_is_unicode_buffer(union acpi_parse_object *op);
|
|
|
|
u8 acpi_dm_is_string_buffer(union acpi_parse_object *op);
|
|
|
|
/*
|
|
* dmresrc
|
|
*/
|
|
void acpi_dm_dump_integer8(u8 value, char *name);
|
|
|
|
void acpi_dm_dump_integer16(u16 value, char *name);
|
|
|
|
void acpi_dm_dump_integer32(u32 value, char *name);
|
|
|
|
void acpi_dm_dump_integer64(u64 value, char *name);
|
|
|
|
void
|
|
acpi_dm_resource_template(struct acpi_op_walk_info *info,
|
|
union acpi_parse_object *op,
|
|
u8 * byte_data, u32 byte_count);
|
|
|
|
acpi_status acpi_dm_is_resource_template(union acpi_parse_object *op);
|
|
|
|
void acpi_dm_indent(u32 level);
|
|
|
|
void acpi_dm_bit_list(u16 mask);
|
|
|
|
void acpi_dm_decode_attribute(u8 attribute);
|
|
|
|
void acpi_dm_descriptor_name(void);
|
|
|
|
/*
|
|
* dmresrcl
|
|
*/
|
|
void
|
|
acpi_dm_word_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_dword_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_extended_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_qword_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_memory24_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_memory32_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_fixed_memory32_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_generic_register_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_interrupt_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_vendor_large_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void acpi_dm_vendor_common(char *name, u8 * byte_data, u32 length, u32 level);
|
|
|
|
/*
|
|
* dmresrcs
|
|
*/
|
|
void
|
|
acpi_dm_irq_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_dma_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void acpi_dm_io_descriptor(union aml_resource *resource, u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_fixed_io_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_start_dependent_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_end_dependent_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
void
|
|
acpi_dm_vendor_small_descriptor(union aml_resource *resource,
|
|
u32 length, u32 level);
|
|
|
|
/*
|
|
* dmutils
|
|
*/
|
|
void acpi_dm_add_to_external_list(char *path, u8 type, u32 value);
|
|
|
|
/*
|
|
* dmrestag
|
|
*/
|
|
void acpi_dm_find_resources(union acpi_parse_object *root);
|
|
|
|
void
|
|
acpi_dm_check_resource_reference(union acpi_parse_object *op,
|
|
struct acpi_walk_state *walk_state);
|
|
|
|
#endif /* __ACDISASM_H__ */
|