Lines Matching +full:non +full:- +full:zero

1 // SPDX-License-Identifier: BSD-3-Clause OR GPL-2.0
4 * Module Name: tbfadt - FADT table utilities
6 * Copyright (C) 2000 - 2022, Intel Corp.
143 * PARAMETERS: generic_address - GAS struct to be initialized
144 * space_id - ACPI Space ID for this register
145 * byte_width - Width of this register
146 * address - Address of the register
147 * register_name - ASCII name of the ACPI register
178 "%s - 32-bit FADT register is too long (%u bytes, %u bits) " in acpi_tb_init_generic_address()
179 "to convert to GAS struct - 255 bits max, truncating", in acpi_tb_init_generic_address()
188 * The 64-bit Address field is non-aligned in the byte packed in acpi_tb_init_generic_address()
191 ACPI_MOVE_64_TO_64(&generic_address->address, &address); in acpi_tb_init_generic_address()
193 /* All other fields are byte-wide */ in acpi_tb_init_generic_address()
195 generic_address->space_id = space_id; in acpi_tb_init_generic_address()
196 generic_address->bit_width = bit_width; in acpi_tb_init_generic_address()
197 generic_address->bit_offset = 0; in acpi_tb_init_generic_address()
198 generic_address->access_width = 0; /* Access width ANY */ in acpi_tb_init_generic_address()
205 * PARAMETERS: register_name - ASCII name of the ACPI register
206 * address32 - 32-bit address of the register
207 * address64 - 64-bit address of the register
209 * RETURN: The resolved 64-bit address
211 * DESCRIPTION: Select between 32-bit and 64-bit versions of addresses within
217 * the 32-bit and 64-bit address fields (FIRMWARE_CTRL/X_FIRMWARE_CTRL and
222 * By default, as per the ACPICA specification, a valid 64-bit address is
223 * used regardless of the value of the 32-bit address. However, this
234 /* 64-bit address is zero, use 32-bit address */ in acpi_tb_select_address()
241 /* Address mismatch between 32-bit and 64-bit versions */ in acpi_tb_select_address()
245 "0x%8.8X/0x%8.8X%8.8X, using %u-bit address", in acpi_tb_select_address()
251 /* 32-bit address override */ in acpi_tb_select_address()
258 /* Default is to use the 64-bit address */ in acpi_tb_select_address()
295 length = fadt_desc->length; in acpi_tb_parse_fadt()
342 * PARAMETERS: table - Pointer to BIOS FADT
343 * length - Length of the table
365 table->revision, ACPI_FADT_CONFORMANCE, in acpi_tb_create_local_fadt()
399 * PARAMETERS: none - acpi_gbl_FADT is used.
404 * Expand 32-bit addresses to 64-bit as necessary. Also validate
408 * contain a copy of the actual BIOS-provided FADT.
410 * Notes on 64-bit register addresses:
412 * After this FADT conversion, later ACPICA code will only use the 64-bit "X"
415 * The 64-bit X fields are optional extensions to the original 32-bit FADT
417 * are unused if the BIOS sets them to zero. Therefore, we must copy/expand
418 * 32-bit V1.0 fields to the 64-bit X fields if the 64-bit X field is originally
419 * zero.
421 * For ACPI 1.0 FADTs (that contain no 64-bit addresses), all 32-bit address
422 * fields are expanded to the corresponding 64-bit X fields in the internal
425 * For ACPI 2.0+ FADTs, all valid (non-zero) 32-bit address fields are expanded
426 * to the corresponding 64-bit X fields, if the 64-bit field is originally
427 * zero. Adhering to the ACPI specification, we completely ignore the 32-bit
428 * field if the 64-bit field is valid, regardless of whether the host OS is
429 * 32-bit or 64-bit.
450 * should be zero are indeed zero. This will workaround BIOSs that in acpi_tb_convert_fadt()
474 * Expand the 32-bit DSDT addresses to 64-bit as necessary. in acpi_tb_convert_fadt()
475 * Later ACPICA code will always use the X 64-bit field. in acpi_tb_convert_fadt()
487 /* Examine all of the 64-bit extended address fields (X fields) */ in acpi_tb_convert_fadt()
491 * Get the 32-bit and 64-bit addresses, as well as the register in acpi_tb_convert_fadt()
510 * Expand the ACPI 1.0 32-bit addresses to the ACPI 2.0 64-bit "X" in acpi_tb_convert_fadt()
512 * the 64-bit address structures. in acpi_tb_convert_fadt()
515 * Now always use the 64-bit address if it is valid (non-zero), in in acpi_tb_convert_fadt()
516 * accordance with the ACPI specification which states that a 64-bit in acpi_tb_convert_fadt()
517 * address supersedes the 32-bit version. This behavior can be in acpi_tb_convert_fadt()
520 * During 64-bit address construction and verification, in acpi_tb_convert_fadt()
523 * Address32 zero, Address64 [don't care] - Use Address64 in acpi_tb_convert_fadt()
526 * Address32 non-zero, Address64 zero - Copy/use Address32 in acpi_tb_convert_fadt()
527 * Address32 non-zero == Address64 non-zero - Use Address64 in acpi_tb_convert_fadt()
528 * Address32 non-zero != Address64 non-zero - Warning, use Address64 in acpi_tb_convert_fadt()
531 * Address32 non-zero, Address64 zero - Copy/use Address32 in acpi_tb_convert_fadt()
532 * Address32 non-zero == Address64 non-zero - Copy/use Address32 in acpi_tb_convert_fadt()
533 * Address32 non-zero != Address64 non-zero - Warning, copy/use Address32 in acpi_tb_convert_fadt()
535 * Note: space_id is always I/O for 32-bit legacy address fields in acpi_tb_convert_fadt()
538 if (address64->address) { in acpi_tb_convert_fadt()
539 if (address64->address != (u64)address32) { in acpi_tb_convert_fadt()
545 "0x%8.8X/0x%8.8X%8.8X, using %u-bit address", in acpi_tb_convert_fadt()
548 (address64->address), in acpi_tb_convert_fadt()
556 * 64-bit X length field. in acpi_tb_convert_fadt()
559 * 64-bit GAS structure can accommodate, 0xFF bits). in acpi_tb_convert_fadt()
562 (address64->bit_width != in acpi_tb_convert_fadt()
568 address64-> in acpi_tb_convert_fadt()
574 * Hardware register access code always uses the 64-bit fields. in acpi_tb_convert_fadt()
575 * So if the 64-bit field is zero or is to be overridden, in acpi_tb_convert_fadt()
576 * initialize it with the 32-bit fields. in acpi_tb_convert_fadt()
577 * Note that when the 32-bit address favor is specified, the in acpi_tb_convert_fadt()
578 * 64-bit fields are always re-initialized so that in acpi_tb_convert_fadt()
580 * configured to the values to trigger a 32-bit compatible in acpi_tb_convert_fadt()
583 if (!address64->address in acpi_tb_convert_fadt()
596 * Both the address and length must be non-zero. in acpi_tb_convert_fadt()
598 if (!address64->address || !length) { in acpi_tb_convert_fadt()
600 "Required FADT field %s has zero address and/or length: " in acpi_tb_convert_fadt()
603 ACPI_FORMAT_UINT64(address64-> in acpi_tb_convert_fadt()
613 if ((address64->address && !length) || in acpi_tb_convert_fadt()
614 (!address64->address && length)) { in acpi_tb_convert_fadt()
616 "Optional FADT field %s has valid %s but zero %s: " in acpi_tb_convert_fadt()
623 (address64->address), in acpi_tb_convert_fadt()
665 if ((target64->address) && in acpi_tb_setup_fadt_registers()
668 target64->bit_width)) { in acpi_tb_setup_fadt_registers()
672 target64->bit_width, in acpi_tb_setup_fadt_registers()
678 target64->bit_width = in acpi_tb_setup_fadt_registers()
695 * is useful to pre-calculate them from the PM1 Event Block definitions. in acpi_tb_setup_fadt_registers()
711 if (source64->address) { in acpi_tb_setup_fadt_registers()
713 target, source64->space_id, in acpi_tb_setup_fadt_registers()
715 source64->address + in acpi_tb_setup_fadt_registers()