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

📄 tbxfroot.c

📁 h内核
💻 C
📖 第 1 页 / 共 2 页
字号:
/****************************************************************************** * * Module Name: tbxfroot - Find the root ACPI table (RSDT) * *****************************************************************************//* * 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 <linux/module.h>#include <acpi/acpi.h>#include <acpi/actables.h>#define _COMPONENT          ACPI_TABLES	 ACPI_MODULE_NAME    ("tbxfroot")/******************************************************************************* * * FUNCTION:    acpi_tb_find_table * * PARAMETERS:  Signature           - String with ACPI table signature *              oem_id              - String with the table OEM ID *              oem_table_id        - String with the OEM Table ID. * * RETURN:      Status * * DESCRIPTION: Find an ACPI table (in the RSDT/XSDT) that matches the *              Signature, OEM ID and OEM Table ID. * ******************************************************************************/acpi_statusacpi_tb_find_table (	char                            *signature,	char                            *oem_id,	char                            *oem_table_id,	struct acpi_table_header        **table_ptr){	acpi_status                     status;	struct acpi_table_header        *table;	ACPI_FUNCTION_TRACE ("tb_find_table");	/* Validate string lengths */	if ((ACPI_STRLEN (signature)  > ACPI_NAME_SIZE) ||		(ACPI_STRLEN (oem_id)     > sizeof (table->oem_id)) ||		(ACPI_STRLEN (oem_table_id) > sizeof (table->oem_table_id))) {		return_ACPI_STATUS (AE_AML_STRING_LIMIT);	}	if (!ACPI_STRNCMP (signature, DSDT_SIG, ACPI_NAME_SIZE)) {		/*		 * The DSDT pointer is contained in the FADT, not the RSDT.		 * This code should suffice, because the only code that would perform		 * a "find" on the DSDT is the data_table_region() AML opcode -- in		 * which case, the DSDT is guaranteed to be already loaded.		 * If this becomes insufficient, the FADT will have to be found first.		 */		if (!acpi_gbl_DSDT) {			return_ACPI_STATUS (AE_NO_ACPI_TABLES);		}		table = acpi_gbl_DSDT;	}	else {		/* Find the table */		status = acpi_get_firmware_table (signature, 1,				   ACPI_LOGICAL_ADDRESSING, &table);		if (ACPI_FAILURE (status)) {			return_ACPI_STATUS (status);		}	}	/* Check oem_id and oem_table_id */	if ((oem_id[0]     && ACPI_STRNCMP (			 oem_id, table->oem_id, sizeof (table->oem_id))) ||		(oem_table_id[0] && ACPI_STRNCMP (				   oem_table_id, table->oem_table_id, sizeof (table->oem_table_id)))) {		return_ACPI_STATUS (AE_AML_NAME_NOT_FOUND);	}	ACPI_DEBUG_PRINT ((ACPI_DB_TABLES, "Found table [%4.4s]\n", table->signature));	*table_ptr = table;	return_ACPI_STATUS (AE_OK);}/******************************************************************************* * * FUNCTION:    acpi_get_firmware_table * * PARAMETERS:  Signature       - Any ACPI table signature *              Instance        - the non zero instance of the table, allows *                                support for multiple tables of the same type *              Flags           - Physical/Virtual support *              table_pointer   - Where a buffer containing the table is *                                returned * * RETURN:      Status * * DESCRIPTION: This function is called to get an ACPI table. A buffer is *              allocated for the table and returned in table_pointer. *              This table will be a complete table including the header. * ******************************************************************************/acpi_statusacpi_get_firmware_table (	acpi_string                     signature,	u32                             instance,	u32                             flags,	struct acpi_table_header        **table_pointer){	acpi_status                     status;	struct acpi_pointer             address;	struct acpi_table_header        *header = NULL;	struct acpi_table_desc          *table_info = NULL;	struct acpi_table_desc          *rsdt_info;	u32                             table_count;	u32                             i;	u32                             j;	ACPI_FUNCTION_TRACE ("acpi_get_firmware_table");	/*	 * Ensure that at least the table manager is initialized.  We don't	 * require that the entire ACPI subsystem is up for this interface.	 * If we have a buffer, we must have a length too	 */	if ((instance == 0)     ||		(!signature)        ||		(!table_pointer)) {		return_ACPI_STATUS (AE_BAD_PARAMETER);	}	/* Ensure that we have a RSDP */	if (!acpi_gbl_RSDP) {		/* Get the RSDP */		status = acpi_os_get_root_pointer (flags, &address);		if (ACPI_FAILURE (status)) {			ACPI_DEBUG_PRINT ((ACPI_DB_INFO, "RSDP not found\n"));			return_ACPI_STATUS (AE_NO_ACPI_TABLES);		}		/* Map and validate the RSDP */		if ((flags & ACPI_MEMORY_MODE) == ACPI_LOGICAL_ADDRESSING) {			status = acpi_os_map_memory (address.pointer.physical, sizeof (struct rsdp_descriptor),					  (void *) &acpi_gbl_RSDP);			if (ACPI_FAILURE (status)) {				return_ACPI_STATUS (status);			}		}		else {			acpi_gbl_RSDP = address.pointer.logical;		}		/* The signature and checksum must both be correct */		if (ACPI_STRNCMP ((char *) acpi_gbl_RSDP, RSDP_SIG, sizeof (RSDP_SIG)-1) != 0) {			/* Nope, BAD Signature */			return_ACPI_STATUS (AE_BAD_SIGNATURE);		}		if (acpi_tb_checksum (acpi_gbl_RSDP, ACPI_RSDP_CHECKSUM_LENGTH) != 0) {			/* Nope, BAD Checksum */			return_ACPI_STATUS (AE_BAD_CHECKSUM);		}	}	/* Get the RSDT address via the RSDP */	acpi_tb_get_rsdt_address (&address);	ACPI_DEBUG_PRINT ((ACPI_DB_INFO,		"RSDP located at %p, RSDT physical=%8.8X%8.8X \n",		acpi_gbl_RSDP,		ACPI_FORMAT_UINT64 (address.pointer.value)));	/* Insert processor_mode flags */	address.pointer_type |= flags;	/* Get and validate the RSDT */	rsdt_info = ACPI_MEM_CALLOCATE (sizeof (struct acpi_table_desc));	if (!rsdt_info) {		return_ACPI_STATUS (AE_NO_MEMORY);	}	status = acpi_tb_get_table (&address, rsdt_info);	if (ACPI_FAILURE (status)) {		goto cleanup;	}	status = acpi_tb_validate_rsdt (rsdt_info->pointer);	if (ACPI_FAILURE (status)) {		goto cleanup;	}	/* Allocate a scratch table header and table descriptor */	header = ACPI_MEM_ALLOCATE (sizeof (struct acpi_table_header));	if (!header) {		status = AE_NO_MEMORY;		goto cleanup;	}	table_info = ACPI_MEM_ALLOCATE (sizeof (struct acpi_table_desc));	if (!table_info) {		status = AE_NO_MEMORY;		goto cleanup;	}	/* Get the number of table pointers within the RSDT */	table_count = acpi_tb_get_table_count (acpi_gbl_RSDP, rsdt_info->pointer);	address.pointer_type = acpi_gbl_table_flags | flags;	/*	 * Search the RSDT/XSDT for the correct instance of the	 * requested table	 */	for (i = 0, j = 0; i < table_count; i++) {		/* Get the next table pointer, handle RSDT vs. XSDT */		if (acpi_gbl_RSDP->revision < 2) {			address.pointer.value = (ACPI_CAST_PTR (				RSDT_DESCRIPTOR, rsdt_info->pointer))->table_offset_entry[i];		}		else {			address.pointer.value = (ACPI_CAST_PTR (				XSDT_DESCRIPTOR, rsdt_info->pointer))->table_offset_entry[i];		}		/* Get the table header */		status = acpi_tb_get_table_header (&address, header);		if (ACPI_FAILURE (status)) {			goto cleanup;		}		/* Compare table signatures and table instance */		if (!ACPI_STRNCMP (header->signature, signature, ACPI_NAME_SIZE)) {			/* An instance of the table was found */			j++;			if (j >= instance) {				/* Found the correct instance, get the entire table */				status = acpi_tb_get_table_body (&address, header, table_info);				if (ACPI_FAILURE (status)) {					goto cleanup;				}				*table_pointer = table_info->pointer;

⌨️ 快捷键说明

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