1 /******************************************************************************
 
   3  * Module Name: tbfadt   - FADT table utilities
 
   5  *****************************************************************************/
 
   8  * Copyright (C) 2000 - 2008, Intel Corp.
 
  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>
 
  48 #define _COMPONENT          ACPI_TABLES
 
  49 ACPI_MODULE_NAME("tbfadt")
 
  51 /* Local prototypes */
 
  53 acpi_tb_init_generic_address(struct acpi_generic_address *generic_address,
 
  54                              u8 space_id, u8 byte_width, u64 address);
 
  56 static void acpi_tb_convert_fadt(void);
 
  58 static void acpi_tb_validate_fadt(void);
 
  60 static void acpi_tb_setup_fadt_registers(void);
 
  62 /* Table for conversion of FADT to common internal format and FADT validation */
 
  64 typedef struct acpi_fadt_info {
 
  74 #define ACPI_FADT_REQUIRED          1
 
  75 #define ACPI_FADT_SEPARATE_LENGTH   2
 
  77 static struct acpi_fadt_info fadt_info_table[] = {
 
  79          ACPI_FADT_OFFSET(xpm1a_event_block),
 
  80          ACPI_FADT_OFFSET(pm1a_event_block),
 
  81          ACPI_FADT_OFFSET(pm1_event_length),
 
  82          ACPI_PM1_REGISTER_WIDTH * 2,   /* Enable + Status register */
 
  86          ACPI_FADT_OFFSET(xpm1b_event_block),
 
  87          ACPI_FADT_OFFSET(pm1b_event_block),
 
  88          ACPI_FADT_OFFSET(pm1_event_length),
 
  89          ACPI_PM1_REGISTER_WIDTH * 2,   /* Enable + Status register */
 
  93          ACPI_FADT_OFFSET(xpm1a_control_block),
 
  94          ACPI_FADT_OFFSET(pm1a_control_block),
 
  95          ACPI_FADT_OFFSET(pm1_control_length),
 
  96          ACPI_PM1_REGISTER_WIDTH,
 
 100          ACPI_FADT_OFFSET(xpm1b_control_block),
 
 101          ACPI_FADT_OFFSET(pm1b_control_block),
 
 102          ACPI_FADT_OFFSET(pm1_control_length),
 
 103          ACPI_PM1_REGISTER_WIDTH,
 
 107          ACPI_FADT_OFFSET(xpm2_control_block),
 
 108          ACPI_FADT_OFFSET(pm2_control_block),
 
 109          ACPI_FADT_OFFSET(pm2_control_length),
 
 110          ACPI_PM2_REGISTER_WIDTH,
 
 111          ACPI_FADT_SEPARATE_LENGTH},
 
 114          ACPI_FADT_OFFSET(xpm_timer_block),
 
 115          ACPI_FADT_OFFSET(pm_timer_block),
 
 116          ACPI_FADT_OFFSET(pm_timer_length),
 
 121          ACPI_FADT_OFFSET(xgpe0_block),
 
 122          ACPI_FADT_OFFSET(gpe0_block),
 
 123          ACPI_FADT_OFFSET(gpe0_block_length),
 
 125          ACPI_FADT_SEPARATE_LENGTH},
 
 128          ACPI_FADT_OFFSET(xgpe1_block),
 
 129          ACPI_FADT_OFFSET(gpe1_block),
 
 130          ACPI_FADT_OFFSET(gpe1_block_length),
 
 132          ACPI_FADT_SEPARATE_LENGTH}
 
 135 #define ACPI_FADT_INFO_ENTRIES \
 
 136                         (sizeof (fadt_info_table) / sizeof (struct acpi_fadt_info))
 
 138 /* Table used to split Event Blocks into separate status/enable registers */
 
 140 typedef struct acpi_fadt_pm_info {
 
 141         struct acpi_generic_address *target;
 
 147 static struct acpi_fadt_pm_info fadt_pm_info_table[] = {
 
 148         {&acpi_gbl_xpm1a_status,
 
 149          ACPI_FADT_OFFSET(xpm1a_event_block),
 
 152         {&acpi_gbl_xpm1a_enable,
 
 153          ACPI_FADT_OFFSET(xpm1a_event_block),
 
 156         {&acpi_gbl_xpm1b_status,
 
 157          ACPI_FADT_OFFSET(xpm1b_event_block),
 
 160         {&acpi_gbl_xpm1b_enable,
 
 161          ACPI_FADT_OFFSET(xpm1b_event_block),
 
 165 #define ACPI_FADT_PM_INFO_ENTRIES \
 
 166                         (sizeof (fadt_pm_info_table) / sizeof (struct acpi_fadt_pm_info))
 
 168 /*******************************************************************************
 
 170  * FUNCTION:    acpi_tb_init_generic_address
 
 172  * PARAMETERS:  generic_address     - GAS struct to be initialized
 
 173  *              byte_width          - Width of this register
 
 174  *              Address             - Address of the register
 
 178  * DESCRIPTION: Initialize a Generic Address Structure (GAS)
 
 179  *              See the ACPI specification for a full description and
 
 180  *              definition of this structure.
 
 182  ******************************************************************************/
 
 185 acpi_tb_init_generic_address(struct acpi_generic_address *generic_address,
 
 186                              u8 space_id, u8 byte_width, u64 address)
 
 190          * The 64-bit Address field is non-aligned in the byte packed
 
 193         ACPI_MOVE_64_TO_64(&generic_address->address, &address);
 
 195         /* All other fields are byte-wide */
 
 197         generic_address->space_id = space_id;
 
 198         generic_address->bit_width = (u8)ACPI_MUL_8(byte_width);
 
 199         generic_address->bit_offset = 0;
 
 200         generic_address->access_width = 0;      /* Access width ANY */
 
 203 /*******************************************************************************
 
 205  * FUNCTION:    acpi_tb_parse_fadt
 
 207  * PARAMETERS:  table_index         - Index for the FADT
 
 211  * DESCRIPTION: Initialize the FADT, DSDT and FACS tables
 
 212  *              (FADT contains the addresses of the DSDT and FACS)
 
 214  ******************************************************************************/
 
 216 void acpi_tb_parse_fadt(u32 table_index)
 
 219         struct acpi_table_header *table;
 
 222          * The FADT has multiple versions with different lengths,
 
 223          * and it contains pointers to both the DSDT and FACS tables.
 
 225          * Get a local copy of the FADT and convert it to a common format
 
 226          * Map entire FADT, assumed to be smaller than one page.
 
 228         length = acpi_gbl_root_table_list.tables[table_index].length;
 
 231             acpi_os_map_memory(acpi_gbl_root_table_list.tables[table_index].
 
 238          * Validate the FADT checksum before we copy the table. Ignore
 
 239          * checksum error as we want to try to get the DSDT and FACS.
 
 241         (void)acpi_tb_verify_checksum(table, length);
 
 243         /* Create a local copy of the FADT in common ACPI 2.0+ format */
 
 245         acpi_tb_create_local_fadt(table, length);
 
 247         /* All done with the real FADT, unmap it */
 
 249         acpi_os_unmap_memory(table, length);
 
 251         /* Obtain the DSDT and FACS tables via their addresses within the FADT */
 
 253         acpi_tb_install_table((acpi_physical_address) acpi_gbl_FADT.Xdsdt,
 
 254                               ACPI_SIG_DSDT, ACPI_TABLE_INDEX_DSDT);
 
 256         acpi_tb_install_table((acpi_physical_address) acpi_gbl_FADT.Xfacs,
 
 257                               ACPI_SIG_FACS, ACPI_TABLE_INDEX_FACS);
 
 260 /*******************************************************************************
 
 262  * FUNCTION:    acpi_tb_create_local_fadt
 
 264  * PARAMETERS:  Table               - Pointer to BIOS FADT
 
 265  *              Length              - Length of the table
 
 269  * DESCRIPTION: Get a local copy of the FADT and convert it to a common format.
 
 270  *              Performs validation on some important FADT fields.
 
 272  * NOTE:        We create a local copy of the FADT regardless of the version.
 
 274  ******************************************************************************/
 
 276 void acpi_tb_create_local_fadt(struct acpi_table_header *table, u32 length)
 
 280          * Check if the FADT is larger than the largest table that we expect
 
 281          * (the ACPI 2.0/3.0 version). If so, truncate the table, and issue
 
 284         if (length > sizeof(struct acpi_table_fadt)) {
 
 285                 ACPI_WARNING((AE_INFO,
 
 286                               "FADT (revision %u) is longer than ACPI 2.0 version, "
 
 287                               "truncating length 0x%X to 0x%zX",
 
 288                               table->revision, (unsigned)length,
 
 289                               sizeof(struct acpi_table_fadt)));
 
 292         /* Clear the entire local FADT */
 
 294         ACPI_MEMSET(&acpi_gbl_FADT, 0, sizeof(struct acpi_table_fadt));
 
 296         /* Copy the original FADT, up to sizeof (struct acpi_table_fadt) */
 
 298         ACPI_MEMCPY(&acpi_gbl_FADT, table,
 
 299                     ACPI_MIN(length, sizeof(struct acpi_table_fadt)));
 
 301         /* Convert the local copy of the FADT to the common internal format */
 
 303         acpi_tb_convert_fadt();
 
 305         /* Validate FADT values now, before we make any changes */
 
 307         acpi_tb_validate_fadt();
 
 309         /* Initialize the global ACPI register structures */
 
 311         acpi_tb_setup_fadt_registers();
 
 314 /*******************************************************************************
 
 316  * FUNCTION:    acpi_tb_convert_fadt
 
 318  * PARAMETERS:  None, uses acpi_gbl_FADT
 
 322  * DESCRIPTION: Converts all versions of the FADT to a common internal format.
 
 323  *              Expand 32-bit addresses to 64-bit as necessary.
 
 325  * NOTE:        acpi_gbl_FADT must be of size (struct acpi_table_fadt),
 
 326  *              and must contain a copy of the actual FADT.
 
 328  * Notes on 64-bit register addresses:
 
 330  * After this FADT conversion, later ACPICA code will only use the 64-bit "X"
 
 331  * fields of the FADT for all ACPI register addresses.
 
 333  * The 64-bit "X" fields are optional extensions to the original 32-bit FADT
 
 334  * V1.0 fields. Even if they are present in the FADT, they are optional and
 
 335  * are unused if the BIOS sets them to zero. Therefore, we must copy/expand
 
 336  * 32-bit V1.0 fields if the corresponding X field is zero.
 
 338  * For ACPI 1.0 FADTs, all 32-bit address fields are expanded to the
 
 339  * corresponding "X" fields in the internal FADT.
 
 341  * For ACPI 2.0+ FADTs, all valid (non-zero) 32-bit address fields are expanded
 
 342  * to the corresponding 64-bit X fields. For compatibility with other ACPI
 
 343  * implementations, we ignore the 64-bit field if the 32-bit field is valid,
 
 344  * regardless of whether the host OS is 32-bit or 64-bit.
 
 346  ******************************************************************************/
 
 348 static void acpi_tb_convert_fadt(void)
 
 350         struct acpi_generic_address *address64;
 
 354         /* Update the local FADT table header length */
 
 356         acpi_gbl_FADT.header.length = sizeof(struct acpi_table_fadt);
 
 359          * Expand the 32-bit FACS and DSDT addresses to 64-bit as necessary.
 
 360          * Later code will always use the X 64-bit field. Also, check for an
 
 361          * address mismatch between the 32-bit and 64-bit address fields
 
 362          * (FIRMWARE_CTRL/X_FIRMWARE_CTRL, DSDT/X_DSDT) which would indicate
 
 363          * the presence of two FACS or two DSDT tables.
 
 365         if (!acpi_gbl_FADT.Xfacs) {
 
 366                 acpi_gbl_FADT.Xfacs = (u64) acpi_gbl_FADT.facs;
 
 367         } else if (acpi_gbl_FADT.facs &&
 
 368                    (acpi_gbl_FADT.Xfacs != (u64) acpi_gbl_FADT.facs)) {
 
 369                 ACPI_WARNING((AE_INFO,
 
 370                     "32/64 FACS address mismatch in FADT - two FACS tables!"));
 
 373         if (!acpi_gbl_FADT.Xdsdt) {
 
 374                 acpi_gbl_FADT.Xdsdt = (u64) acpi_gbl_FADT.dsdt;
 
 375         } else if (acpi_gbl_FADT.dsdt &&
 
 376                    (acpi_gbl_FADT.Xdsdt != (u64) acpi_gbl_FADT.dsdt)) {
 
 377                 ACPI_WARNING((AE_INFO,
 
 378                     "32/64 DSDT address mismatch in FADT - two DSDT tables!"));
 
 382          * For ACPI 1.0 FADTs (revision 1 or 2), ensure that reserved fields which
 
 383          * should be zero are indeed zero. This will workaround BIOSs that
 
 384          * inadvertently place values in these fields.
 
 386          * The ACPI 1.0 reserved fields that will be zeroed are the bytes located at
 
 387          * offset 45, 55, 95, and the word located at offset 109, 110.
 
 389         if (acpi_gbl_FADT.header.revision < FADT2_REVISION_ID) {
 
 390                 acpi_gbl_FADT.preferred_profile = 0;
 
 391                 acpi_gbl_FADT.pstate_control = 0;
 
 392                 acpi_gbl_FADT.cst_control = 0;
 
 393                 acpi_gbl_FADT.boot_flags = 0;
 
 397          * Expand the ACPI 1.0 32-bit addresses to the ACPI 2.0 64-bit "X"
 
 398          * generic address structures as necessary. Later code will always use
 
 399          * the 64-bit address structures.
 
 402          * We now always use the 32-bit address if it is valid (non-null). This
 
 403          * is not in accordance with the ACPI specification which states that
 
 404          * the 64-bit address supersedes the 32-bit version, but we do this for
 
 405          * compatibility with other ACPI implementations. Most notably, in the
 
 406          * case where both the 32 and 64 versions are non-null, we use the 32-bit
 
 407          * version. This is the only address that is guaranteed to have been
 
 408          * tested by the BIOS manufacturer.
 
 410         for (i = 0; i < ACPI_FADT_INFO_ENTRIES; i++) {
 
 411                 address32 = *ACPI_ADD_PTR(u32,
 
 413                                           fadt_info_table[i].address32);
 
 415                 address64 = ACPI_ADD_PTR(struct acpi_generic_address,
 
 417                                          fadt_info_table[i].address64);
 
 420                  * If both 32- and 64-bit addresses are valid (non-zero),
 
 423                 if (address64->address && address32 &&
 
 424                     (address64->address != (u64) address32)) {
 
 426                                     "32/64X address mismatch in %s: %8.8X/%8.8X%8.8X, using 32",
 
 427                                     fadt_info_table[i].name, address32,
 
 428                                     ACPI_FORMAT_UINT64(address64->address)));
 
 431                 /* Always use 32-bit address if it is valid (non-null) */
 
 435                          * Copy the 32-bit address to the 64-bit GAS structure. The
 
 436                          * Space ID is always I/O for 32-bit legacy address fields
 
 438                         acpi_tb_init_generic_address(address64,
 
 439                                                      ACPI_ADR_SPACE_SYSTEM_IO,
 
 449 /*******************************************************************************
 
 451  * FUNCTION:    acpi_tb_validate_fadt
 
 453  * PARAMETERS:  Table           - Pointer to the FADT to be validated
 
 457  * DESCRIPTION: Validate various important fields within the FADT. If a problem
 
 458  *              is found, issue a message, but no status is returned.
 
 459  *              Used by both the table manager and the disassembler.
 
 461  * Possible additional checks:
 
 462  * (acpi_gbl_FADT.pm1_event_length >= 4)
 
 463  * (acpi_gbl_FADT.pm1_control_length >= 2)
 
 464  * (acpi_gbl_FADT.pm_timer_length >= 4)
 
 465  * Gpe block lengths must be multiple of 2
 
 467  ******************************************************************************/
 
 469 static void acpi_tb_validate_fadt(void)
 
 473         struct acpi_generic_address *address64;
 
 478          * Check for FACS and DSDT address mismatches. An address mismatch between
 
 479          * the 32-bit and 64-bit address fields (FIRMWARE_CTRL/X_FIRMWARE_CTRL and
 
 480          * DSDT/X_DSDT) would indicate the presence of two FACS or two DSDT tables.
 
 482         if (acpi_gbl_FADT.facs &&
 
 483             (acpi_gbl_FADT.Xfacs != (u64) acpi_gbl_FADT.facs)) {
 
 484                 ACPI_WARNING((AE_INFO,
 
 485                               "32/64X FACS address mismatch in FADT - "
 
 486                               "%8.8X/%8.8X%8.8X, using 32",
 
 488                               ACPI_FORMAT_UINT64(acpi_gbl_FADT.Xfacs)));
 
 490                 acpi_gbl_FADT.Xfacs = (u64) acpi_gbl_FADT.facs;
 
 493         if (acpi_gbl_FADT.dsdt &&
 
 494             (acpi_gbl_FADT.Xdsdt != (u64) acpi_gbl_FADT.dsdt)) {
 
 495                 ACPI_WARNING((AE_INFO,
 
 496                               "32/64X DSDT address mismatch in FADT - "
 
 497                               "%8.8X/%8.8X%8.8X, using 32",
 
 499                               ACPI_FORMAT_UINT64(acpi_gbl_FADT.Xdsdt)));
 
 501                 acpi_gbl_FADT.Xdsdt = (u64) acpi_gbl_FADT.dsdt;
 
 504         /* Examine all of the 64-bit extended address fields (X fields) */
 
 506         for (i = 0; i < ACPI_FADT_INFO_ENTRIES; i++) {
 
 508                  * Generate pointers to the 32-bit and 64-bit addresses, get the
 
 509                  * register length (width), and the register name
 
 511                 address64 = ACPI_ADD_PTR(struct acpi_generic_address,
 
 513                                          fadt_info_table[i].address64);
 
 515                     ACPI_ADD_PTR(u32, &acpi_gbl_FADT,
 
 516                                  fadt_info_table[i].address32);
 
 518                     *ACPI_ADD_PTR(u8, &acpi_gbl_FADT,
 
 519                                   fadt_info_table[i].length);
 
 520                 name = fadt_info_table[i].name;
 
 523                  * For each extended field, check for length mismatch between the
 
 524                  * legacy length field and the corresponding 64-bit X length field.
 
 526                 if (address64->address &&
 
 527                     (address64->bit_width != ACPI_MUL_8(length))) {
 
 528                         ACPI_WARNING((AE_INFO,
 
 529                                       "32/64X length mismatch in %s: %d/%d",
 
 530                                       name, ACPI_MUL_8(length),
 
 531                                       address64->bit_width));
 
 534                 if (fadt_info_table[i].type & ACPI_FADT_REQUIRED) {
 
 536                          * Field is required (Pm1a_event, Pm1a_control, pm_timer).
 
 537                          * Both the address and length must be non-zero.
 
 539                         if (!address64->address || !length) {
 
 541                                             "Required field %s has zero address and/or length:"
 
 544                                             ACPI_FORMAT_UINT64(address64->
 
 548                 } else if (fadt_info_table[i].type & ACPI_FADT_SEPARATE_LENGTH) {
 
 550                          * Field is optional (PM2Control, GPE0, GPE1) AND has its own
 
 551                          * length field. If present, both the address and length must
 
 554                         if ((address64->address && !length) ||
 
 555                             (!address64->address && length)) {
 
 556                                 ACPI_WARNING((AE_INFO,
 
 557                                               "Optional field %s has zero address or length: "
 
 560                                               ACPI_FORMAT_UINT64(address64->
 
 568 /*******************************************************************************
 
 570  * FUNCTION:    acpi_tb_setup_fadt_registers
 
 572  * PARAMETERS:  None, uses acpi_gbl_FADT.
 
 576  * DESCRIPTION: Initialize global ACPI PM1 register definitions. Optionally,
 
 577  *              force FADT register definitions to their default lengths.
 
 579  ******************************************************************************/
 
 581 static void acpi_tb_setup_fadt_registers(void)
 
 583         struct acpi_generic_address *target64;
 
 584         struct acpi_generic_address *source64;
 
 585         u8 pm1_register_byte_width;
 
 589          * Optionally check all register lengths against the default values and
 
 590          * update them if they are incorrect.
 
 592         if (acpi_gbl_use_default_register_widths) {
 
 593                 for (i = 0; i < ACPI_FADT_INFO_ENTRIES; i++) {
 
 595                             ACPI_ADD_PTR(struct acpi_generic_address,
 
 597                                          fadt_info_table[i].address64);
 
 600                          * If a valid register (Address != 0) and the (default_length > 0)
 
 601                          * (Not a GPE register), then check the width against the default.
 
 603                         if ((target64->address) &&
 
 604                             (fadt_info_table[i].default_length > 0) &&
 
 605                             (fadt_info_table[i].default_length !=
 
 606                              target64->bit_width)) {
 
 607                                 ACPI_WARNING((AE_INFO,
 
 608                                               "Invalid length for %s: %d, using default %d",
 
 609                                               fadt_info_table[i].name,
 
 614                                 /* Incorrect size, set width to the default */
 
 616                                 target64->bit_width =
 
 617                                     fadt_info_table[i].default_length;
 
 623          * Get the length of the individual PM1 registers (enable and status).
 
 624          * Each register is defined to be (event block length / 2). Extra divide
 
 625          * by 8 converts bits to bytes.
 
 627         pm1_register_byte_width = (u8)
 
 628             ACPI_DIV_16(acpi_gbl_FADT.xpm1a_event_block.bit_width);
 
 631          * Calculate separate GAS structs for the PM1x (A/B) Status and Enable
 
 632          * registers. These addresses do not appear (directly) in the FADT, so it
 
 633          * is useful to pre-calculate them from the PM1 Event Block definitions.
 
 635          * The PM event blocks are split into two register blocks, first is the
 
 636          * PM Status Register block, followed immediately by the PM Enable
 
 637          * Register block. Each is of length (pm1_event_length/2)
 
 639          * Note: The PM1A event block is required by the ACPI specification.
 
 640          * However, the PM1B event block is optional and is rarely, if ever,
 
 644         for (i = 0; i < ACPI_FADT_PM_INFO_ENTRIES; i++) {
 
 646                     ACPI_ADD_PTR(struct acpi_generic_address, &acpi_gbl_FADT,
 
 647                                  fadt_pm_info_table[i].source);
 
 649                 if (source64->address) {
 
 650                         acpi_tb_init_generic_address(fadt_pm_info_table[i].
 
 651                                                      target, source64->space_id,
 
 652                                                      pm1_register_byte_width,
 
 654                                                      (fadt_pm_info_table[i].
 
 656                                                       pm1_register_byte_width));