soc/intel/common: Check bios_size and window_size after MIN operation

Clang Static Analyzer version 8.0.0 detects that log2_ceil(bios_size)
and log2_ceil(window_size) are garbage or undefined if the value of
bios_size and window_size is zero. Check bios_size and window_size after
MIN operation to prevent error.

TEST=Built and boot up to kernel.

Change-Id: Ifc3f3da52d129ef5d6063a46b045603a236be759
Signed-off-by: John Zhao <john.zhao@intel.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/32924
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Duncan Laurie <dlaurie@chromium.org>
This commit is contained in:
John Zhao 2019-05-21 19:32:51 -07:00 committed by Patrick Georgi
parent 64fb5aa9c3
commit 2bb432ece6
2 changed files with 5 additions and 3 deletions

View File

@ -236,14 +236,13 @@ void fast_spi_cache_bios_region(void)
/* Only the IFD BIOS region is memory mapped (at top of 4G) */ /* Only the IFD BIOS region is memory mapped (at top of 4G) */
fast_spi_get_bios_region(&bios_size); fast_spi_get_bios_region(&bios_size);
if (!bios_size)
return;
/* LOCAL APIC default address is 0xFEE0000, bios_size over 16MB will /* LOCAL APIC default address is 0xFEE0000, bios_size over 16MB will
* cause memory type conflict when setting memory type to write * cause memory type conflict when setting memory type to write
* protection, so limit the cached bios region to be no more than 16MB. * protection, so limit the cached bios region to be no more than 16MB.
* */ * */
bios_size = MIN(bios_size, 16 * MiB); bios_size = MIN(bios_size, 16 * MiB);
if (!bios_size)
return;
/* Round to power of two */ /* Round to power of two */
alignment = 1UL << (log2_ceil(bios_size)); alignment = 1UL << (log2_ceil(bios_size));

View File

@ -80,6 +80,9 @@ void lpc_open_pmio_window(uint16_t base, uint16_t size)
/* Each IO range register can only open a 256-byte window. */ /* Each IO range register can only open a 256-byte window. */
window_size = MIN(size, LPC_LGIR_MAX_WINDOW_SIZE); window_size = MIN(size, LPC_LGIR_MAX_WINDOW_SIZE);
if (!window_size)
return;
/* Window size must be a power of two for the AMASK to work. */ /* Window size must be a power of two for the AMASK to work. */
alignment = 1UL << (log2_ceil(window_size)); alignment = 1UL << (log2_ceil(window_size));
window_size = ALIGN_UP(window_size, alignment); window_size = ALIGN_UP(window_size, alignment);