⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 exdump.c

📁 h内核
💻 C
📖 第 1 页 / 共 2 页
字号:
/****************************************************************************** * * Module Name: exdump - Interpreter debug output routines * *****************************************************************************//* * Copyright (C) 2000 - 2005, R. Byron Moore * 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. */#include <acpi/acpi.h>#include <acpi/acinterp.h>#include <acpi/amlcode.h>#include <acpi/acnamesp.h>#include <acpi/acparser.h>#define _COMPONENT          ACPI_EXECUTER	 ACPI_MODULE_NAME    ("exdump")/* * The following routines are used for debug output only */#if defined(ACPI_DEBUG_OUTPUT) || defined(ACPI_DEBUGGER)/***************************************************************************** * * FUNCTION:    acpi_ex_dump_operand * * PARAMETERS:  *obj_desc         - Pointer to entry to be dumped * * RETURN:      None * * DESCRIPTION: Dump an operand object * ****************************************************************************/voidacpi_ex_dump_operand (	union acpi_operand_object       *obj_desc,	u32                             depth){	u32                             length;	u32                             index;	ACPI_FUNCTION_NAME ("ex_dump_operand")	if (!((ACPI_LV_EXEC & acpi_dbg_level) && (_COMPONENT & acpi_dbg_layer))) {		return;	}	if (!obj_desc) {		/*		 * This could be a null element of a package		 */		ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "Null Object Descriptor\n"));		return;	}	if (ACPI_GET_DESCRIPTOR_TYPE (obj_desc) == ACPI_DESC_TYPE_NAMED) {		ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p is a NS Node: ", obj_desc));		ACPI_DUMP_ENTRY (obj_desc, ACPI_LV_EXEC);		return;	}	if (ACPI_GET_DESCRIPTOR_TYPE (obj_desc) != ACPI_DESC_TYPE_OPERAND) {		ACPI_DEBUG_PRINT ((ACPI_DB_EXEC,			"%p is not a node or operand object: [%s]\n",			obj_desc, acpi_ut_get_descriptor_name (obj_desc)));		ACPI_DUMP_BUFFER (obj_desc, sizeof (union acpi_operand_object));		return;	}	/* obj_desc is a valid object */	if (depth > 0) {		ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%*s[%u] %p ",			depth, " ", depth, obj_desc));	}	else {		ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "%p ", obj_desc));	}	switch (ACPI_GET_OBJECT_TYPE (obj_desc)) {	case ACPI_TYPE_LOCAL_REFERENCE:		switch (obj_desc->reference.opcode) {		case AML_DEBUG_OP:			acpi_os_printf ("Reference: Debug\n");			break;		case AML_NAME_OP:			ACPI_DUMP_PATHNAME (obj_desc->reference.object,				"Reference: Name: ", ACPI_LV_INFO, _COMPONENT);			ACPI_DUMP_ENTRY (obj_desc->reference.object, ACPI_LV_INFO);			break;		case AML_INDEX_OP:			acpi_os_printf ("Reference: Index %p\n",				obj_desc->reference.object);			break;		case AML_REF_OF_OP:			acpi_os_printf ("Reference: (ref_of) %p\n",				obj_desc->reference.object);			break;		case AML_ARG_OP:			acpi_os_printf ("Reference: Arg%d",				obj_desc->reference.offset);			if (ACPI_GET_OBJECT_TYPE (obj_desc) == ACPI_TYPE_INTEGER) {				/* Value is an Integer */				acpi_os_printf (" value is [%8.8X%8.8x]",					ACPI_FORMAT_UINT64 (obj_desc->integer.value));			}			acpi_os_printf ("\n");			break;		case AML_LOCAL_OP:			acpi_os_printf ("Reference: Local%d",				obj_desc->reference.offset);			if (ACPI_GET_OBJECT_TYPE (obj_desc) == ACPI_TYPE_INTEGER) {				/* Value is an Integer */				acpi_os_printf (" value is [%8.8X%8.8x]",					ACPI_FORMAT_UINT64 (obj_desc->integer.value));			}			acpi_os_printf ("\n");			break;		case AML_INT_NAMEPATH_OP:			acpi_os_printf ("Reference.Node->Name %X\n",				obj_desc->reference.node->name.integer);			break;		default:			/* Unknown opcode */			acpi_os_printf ("Unknown Reference opcode=%X\n",				obj_desc->reference.opcode);			break;		}		break;	case ACPI_TYPE_BUFFER:		acpi_os_printf ("Buffer len %X @ %p \n",			obj_desc->buffer.length, obj_desc->buffer.pointer);		length = obj_desc->buffer.length;		if (length > 64) {			length = 64;		}		/* Debug only -- dump the buffer contents */		if (obj_desc->buffer.pointer) {			acpi_os_printf ("Buffer Contents: ");			for (index = 0; index < length; index++) {				acpi_os_printf (" %02x", obj_desc->buffer.pointer[index]);			}			acpi_os_printf ("\n");		}		break;	case ACPI_TYPE_INTEGER:		acpi_os_printf ("Integer %8.8X%8.8X\n",			ACPI_FORMAT_UINT64 (obj_desc->integer.value));		break;	case ACPI_TYPE_PACKAGE:		acpi_os_printf ("Package [Len %X] element_array %p\n",			obj_desc->package.count, obj_desc->package.elements);		/*		 * If elements exist, package element pointer is valid,		 * and debug_level exceeds 1, dump package's elements.		 */		if (obj_desc->package.count &&			obj_desc->package.elements &&			acpi_dbg_level > 1) {			for (index = 0; index < obj_desc->package.count; index++) {				acpi_ex_dump_operand (obj_desc->package.elements[index], depth+1);			}		}		break;	case ACPI_TYPE_REGION:		acpi_os_printf ("Region %s (%X)",			acpi_ut_get_region_name (obj_desc->region.space_id),			obj_desc->region.space_id);		/*		 * If the address and length have not been evaluated,		 * don't print them.		 */		if (!(obj_desc->region.flags & AOPOBJ_DATA_VALID)) {			acpi_os_printf ("\n");		}		else {			acpi_os_printf (" base %8.8X%8.8X Length %X\n",				ACPI_FORMAT_UINT64 (obj_desc->region.address),				obj_desc->region.length);		}		break;	case ACPI_TYPE_STRING:		acpi_os_printf ("String length %X @ %p ",			obj_desc->string.length, obj_desc->string.pointer);		acpi_ut_print_string (obj_desc->string.pointer, ACPI_UINT8_MAX);		acpi_os_printf ("\n");		break;	case ACPI_TYPE_LOCAL_BANK_FIELD:		acpi_os_printf ("bank_field\n");		break;	case ACPI_TYPE_LOCAL_REGION_FIELD:		acpi_os_printf (			"region_field: Bits=%X acc_width=%X Lock=%X Update=%X at byte=%X bit=%X of below:\n",			obj_desc->field.bit_length, obj_desc->field.access_byte_width,			obj_desc->field.field_flags & AML_FIELD_LOCK_RULE_MASK,			obj_desc->field.field_flags & AML_FIELD_UPDATE_RULE_MASK,			obj_desc->field.base_byte_offset, obj_desc->field.start_field_bit_offset);		acpi_ex_dump_operand (obj_desc->field.region_obj, depth+1);		break;	case ACPI_TYPE_LOCAL_INDEX_FIELD:		acpi_os_printf ("index_field\n");		break;	case ACPI_TYPE_BUFFER_FIELD:		acpi_os_printf (			"buffer_field: %X bits at byte %X bit %X of \n",			obj_desc->buffer_field.bit_length, obj_desc->buffer_field.base_byte_offset,			obj_desc->buffer_field.start_field_bit_offset);		if (!obj_desc->buffer_field.buffer_obj) {			ACPI_DEBUG_PRINT ((ACPI_DB_EXEC, "*NULL* \n"));		}		else if (ACPI_GET_OBJECT_TYPE (obj_desc->buffer_field.buffer_obj) != ACPI_TYPE_BUFFER) {			acpi_os_printf ("*not a Buffer* \n");		}		else {			acpi_ex_dump_operand (obj_desc->buffer_field.buffer_obj, depth+1);		}		break;	case ACPI_TYPE_EVENT:		acpi_os_printf ("Event\n");		break;	case ACPI_TYPE_METHOD:		acpi_os_printf (			"Method(%X) @ %p:%X\n",			obj_desc->method.param_count,			obj_desc->method.aml_start, obj_desc->method.aml_length);		break;	case ACPI_TYPE_MUTEX:		acpi_os_printf ("Mutex\n");		break;	case ACPI_TYPE_DEVICE:		acpi_os_printf ("Device\n");		break;	case ACPI_TYPE_POWER:		acpi_os_printf ("Power\n");		break;	case ACPI_TYPE_PROCESSOR:		acpi_os_printf ("Processor\n");		break;	case ACPI_TYPE_THERMAL:		acpi_os_printf ("Thermal\n");		break;	default:		/* Unknown Type */		acpi_os_printf ("Unknown Type %X\n", ACPI_GET_OBJECT_TYPE (obj_desc));		break;	}	return;}/***************************************************************************** * * FUNCTION:    acpi_ex_dump_operands * * PARAMETERS:  Operands            - Operand list *              interpreter_mode    - Load or Exec *              Ident               - Identification *              num_levels          - # of stack entries to dump above line *              Note                - Output notation *              module_name         - Caller's module name *              line_number         - Caller's invocation line number * * DESCRIPTION: Dump the object stack * ****************************************************************************/

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -