1 /******************************************************************************
 
   3  * Module Name: tbgetall - Get all required ACPI tables
 
   5  *****************************************************************************/
 
   8  * Copyright (C) 2000 - 2005, R. Byron Moore
 
  11  * Redistribution and use in source and binary forms, with or without
 
  12  * modification, are permitted provided that the following conditions
 
  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.
 
  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.
 
  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.
 
  44 #include <acpi/acpi.h>
 
  45 #include <acpi/actables.h>
 
  47 #define _COMPONENT          ACPI_TABLES
 
  48 ACPI_MODULE_NAME("tbgetall")
 
  50 /* Local prototypes */
 
  52 acpi_tb_get_primary_table(struct acpi_pointer *address,
 
  53                           struct acpi_table_desc *table_info);
 
  56 acpi_tb_get_secondary_table(struct acpi_pointer *address,
 
  57                             acpi_string signature,
 
  58                             struct acpi_table_desc *table_info);
 
  60 /*******************************************************************************
 
  62  * FUNCTION:    acpi_tb_get_primary_table
 
  64  * PARAMETERS:  Address             - Physical address of table to retrieve
 
  65  *              *table_info         - Where the table info is returned
 
  69  * DESCRIPTION: Maps the physical address of table into a logical address
 
  71  ******************************************************************************/
 
  74 acpi_tb_get_primary_table(struct acpi_pointer *address,
 
  75                           struct acpi_table_desc *table_info)
 
  78         struct acpi_table_header header;
 
  80         ACPI_FUNCTION_TRACE("tb_get_primary_table");
 
  82         /* Ignore a NULL address in the RSDT */
 
  84         if (!address->pointer.value) {
 
  85                 return_ACPI_STATUS(AE_OK);
 
  88         /* Get the header in order to get signature and table size */
 
  90         status = acpi_tb_get_table_header(address, &header);
 
  91         if (ACPI_FAILURE(status)) {
 
  92                 return_ACPI_STATUS(status);
 
  95         /* Clear the table_info */
 
  97         ACPI_MEMSET(table_info, 0, sizeof(struct acpi_table_desc));
 
 100          * Check the table signature and make sure it is recognized.
 
 101          * Also checks the header checksum
 
 103         table_info->pointer = &header;
 
 104         status = acpi_tb_recognize_table(table_info, ACPI_TABLE_PRIMARY);
 
 105         if (ACPI_FAILURE(status)) {
 
 106                 return_ACPI_STATUS(status);
 
 109         /* Get the entire table */
 
 111         status = acpi_tb_get_table_body(address, &header, table_info);
 
 112         if (ACPI_FAILURE(status)) {
 
 113                 return_ACPI_STATUS(status);
 
 116         /* Install the table */
 
 118         status = acpi_tb_install_table(table_info);
 
 119         return_ACPI_STATUS(status);
 
 122 /*******************************************************************************
 
 124  * FUNCTION:    acpi_tb_get_secondary_table
 
 126  * PARAMETERS:  Address             - Physical address of table to retrieve
 
 127  *              *table_info         - Where the table info is returned
 
 131  * DESCRIPTION: Maps the physical address of table into a logical address
 
 133  ******************************************************************************/
 
 136 acpi_tb_get_secondary_table(struct acpi_pointer *address,
 
 137                             acpi_string signature,
 
 138                             struct acpi_table_desc *table_info)
 
 141         struct acpi_table_header header;
 
 143         ACPI_FUNCTION_TRACE_STR("tb_get_secondary_table", signature);
 
 145         /* Get the header in order to match the signature */
 
 147         status = acpi_tb_get_table_header(address, &header);
 
 148         if (ACPI_FAILURE(status)) {
 
 149                 return_ACPI_STATUS(status);
 
 152         /* Signature must match request */
 
 154         if (ACPI_STRNCMP(header.signature, signature, ACPI_NAME_SIZE)) {
 
 155                 ACPI_REPORT_ERROR(("Incorrect table signature - wanted [%s] found [%4.4s]\n", signature, header.signature));
 
 156                 return_ACPI_STATUS(AE_BAD_SIGNATURE);
 
 160          * Check the table signature and make sure it is recognized.
 
 161          * Also checks the header checksum
 
 163         table_info->pointer = &header;
 
 164         status = acpi_tb_recognize_table(table_info, ACPI_TABLE_SECONDARY);
 
 165         if (ACPI_FAILURE(status)) {
 
 166                 return_ACPI_STATUS(status);
 
 169         /* Get the entire table */
 
 171         status = acpi_tb_get_table_body(address, &header, table_info);
 
 172         if (ACPI_FAILURE(status)) {
 
 173                 return_ACPI_STATUS(status);
 
 176         /* Install the table */
 
 178         status = acpi_tb_install_table(table_info);
 
 179         return_ACPI_STATUS(status);
 
 182 /*******************************************************************************
 
 184  * FUNCTION:    acpi_tb_get_required_tables
 
 190  * DESCRIPTION: Load and validate tables other than the RSDT.  The RSDT must
 
 191  *              already be loaded and validated.
 
 193  *              Get the minimum set of ACPI tables, namely:
 
 195  *              1) FADT (via RSDT in loop below)
 
 199  ******************************************************************************/
 
 201 acpi_status acpi_tb_get_required_tables(void)
 
 203         acpi_status status = AE_OK;
 
 205         struct acpi_table_desc table_info;
 
 206         struct acpi_pointer address;
 
 208         ACPI_FUNCTION_TRACE("tb_get_required_tables");
 
 210         ACPI_DEBUG_PRINT((ACPI_DB_INFO, "%d ACPI tables in RSDT\n",
 
 211                           acpi_gbl_rsdt_table_count));
 
 213         address.pointer_type = acpi_gbl_table_flags | ACPI_LOGICAL_ADDRESSING;
 
 216          * Loop through all table pointers found in RSDT.
 
 217          * This will NOT include the FACS and DSDT - we must get
 
 218          * them after the loop.
 
 220          * The only tables we are interested in getting here is the FADT and
 
 223         for (i = 0; i < acpi_gbl_rsdt_table_count; i++) {
 
 224                 /* Get the table address from the common internal XSDT */
 
 226                 address.pointer.value = acpi_gbl_XSDT->table_offset_entry[i];
 
 229                  * Get the tables needed by this subsystem (FADT and any SSDTs).
 
 230                  * NOTE: All other tables are completely ignored at this time.
 
 232                 status = acpi_tb_get_primary_table(&address, &table_info);
 
 233                 if ((status != AE_OK) && (status != AE_TABLE_NOT_SUPPORTED)) {
 
 234                         ACPI_REPORT_WARNING(("%s, while getting table at %8.8X%8.8X\n", acpi_format_exception(status), ACPI_FORMAT_UINT64(address.pointer.value)));
 
 238         /* We must have a FADT to continue */
 
 240         if (!acpi_gbl_FADT) {
 
 241                 ACPI_REPORT_ERROR(("No FADT present in RSDT/XSDT\n"));
 
 242                 return_ACPI_STATUS(AE_NO_ACPI_TABLES);
 
 246          * Convert the FADT to a common format.  This allows earlier revisions of
 
 247          * the table to coexist with newer versions, using common access code.
 
 249         status = acpi_tb_convert_table_fadt();
 
 250         if (ACPI_FAILURE(status)) {
 
 251                 ACPI_REPORT_ERROR(("Could not convert FADT to internal common format\n"));
 
 252                 return_ACPI_STATUS(status);
 
 255         /* Get the FACS (Pointed to by the FADT) */
 
 257         address.pointer.value = acpi_gbl_FADT->xfirmware_ctrl;
 
 259         status = acpi_tb_get_secondary_table(&address, FACS_SIG, &table_info);
 
 260         if (ACPI_FAILURE(status)) {
 
 261                 ACPI_REPORT_ERROR(("Could not get/install the FACS, %s\n",
 
 262                                    acpi_format_exception(status)));
 
 263                 return_ACPI_STATUS(status);
 
 267          * Create the common FACS pointer table
 
 268          * (Contains pointers to the original table)
 
 270         status = acpi_tb_build_common_facs(&table_info);
 
 271         if (ACPI_FAILURE(status)) {
 
 272                 return_ACPI_STATUS(status);
 
 275         /* Get/install the DSDT (Pointed to by the FADT) */
 
 277         address.pointer.value = acpi_gbl_FADT->Xdsdt;
 
 279         status = acpi_tb_get_secondary_table(&address, DSDT_SIG, &table_info);
 
 280         if (ACPI_FAILURE(status)) {
 
 281                 ACPI_REPORT_ERROR(("Could not get/install the DSDT\n"));
 
 282                 return_ACPI_STATUS(status);
 
 285         /* Set Integer Width (32/64) based upon DSDT revision */
 
 287         acpi_ut_set_integer_width(acpi_gbl_DSDT->revision);
 
 289         /* Dump the entire DSDT */
 
 291         ACPI_DEBUG_PRINT((ACPI_DB_TABLES,
 
 292                           "Hex dump of entire DSDT, size %d (0x%X), Integer width = %d\n",
 
 293                           acpi_gbl_DSDT->length, acpi_gbl_DSDT->length,
 
 294                           acpi_gbl_integer_bit_width));
 
 295         ACPI_DUMP_BUFFER((u8 *) acpi_gbl_DSDT, acpi_gbl_DSDT->length);
 
 297         /* Always delete the RSDP mapping, we are done with it */
 
 299         acpi_tb_delete_tables_by_type(ACPI_TABLE_RSDP);
 
 300         return_ACPI_STATUS(status);