summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPaul Menzel <pmenzel@molgen.mpg.de>2021-03-05 01:09:07 +0100
committerPaul Fagerburg <pfagerburg@chromium.org>2021-09-20 15:43:26 +0000
commit1a7640dc628c39b3af24983eb90474962c096119 (patch)
tree8e9f9c3aed9893e7230f8d8c993b77ce62a646d3 /src
parentf9080ce6d9eeb3e8622500a0ef9b852a2d0727bc (diff)
vc/amd/sb800: Fix out of bounds shift
Fix the two issues below. SB800: sb_Before_Pci_Init shift out of bounds src/vendorcode/amd/cimx/sb800/PCILIB.c:49:18 ubsan: unrecoverable error. SB800: sb_Before_Pci_Init shift out of bounds src/vendorcode/amd/cimx/sb800/PCILIB.c:66:18 ubsan: unrecoverable error. Found by: UBSAN Change-Id: Id42e62d35f59793bad10998f14422ab7fb4fc029 Signed-off-by: Paul Menzel <pmenzel@molgen.mpg.de> Reviewed-on: https://review.coreboot.org/c/coreboot/+/51283 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Michał Żygowski <michal.zygowski@3mdeb.com>
Diffstat (limited to 'src')
-rw-r--r--src/vendorcode/amd/cimx/sb800/PCILIB.c4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/vendorcode/amd/cimx/sb800/PCILIB.c b/src/vendorcode/amd/cimx/sb800/PCILIB.c
index 01be81a6e5..c34c5b0dc9 100644
--- a/src/vendorcode/amd/cimx/sb800/PCILIB.c
+++ b/src/vendorcode/amd/cimx/sb800/PCILIB.c
@@ -46,7 +46,7 @@ ReadPCI (
if ( (UINT16)Address < 0xff ) {
//Normal Config Access
UINT32 AddrCf8;
- AddrCf8 = (1 << 31) + ((Address >> 8) & 0x0FFFF00) + (Address & 0xFC);
+ AddrCf8 = (1U << 31) + ((Address >> 8) & 0x0FFFF00) + (Address & 0xFC);
WriteIO (0xCf8, AccWidthUint32, &AddrCf8);
ReadIO ((UINT16) (0xCfC + (Address & 0x3)), OpFlag, Value);
}
@@ -63,7 +63,7 @@ WritePCI (
if ( (UINT16)Address < 0xff ) {
//Normal Config Access
UINT32 AddrCf8;
- AddrCf8 = (1 << 31) + ((Address >> 8)&0x0FFFF00) + (Address & 0xFC);
+ AddrCf8 = (1U << 31) + ((Address >> 8)&0x0FFFF00) + (Address & 0xFC);
WriteIO (0xCf8, AccWidthUint32, &AddrCf8);
WriteIO ((UINT16) (0xCfC + (Address & 0x3)), OpFlag, Value);
}