southbridge/intel/lynxpoint: Fix undefined behavior
Fix reports found by undefined behavior sanitizer. Left shifting an int where the right operand is >= the width of the type is undefined. Add UL suffix since it's safe for unsigned types. Change-Id: I755b3c80a8d1b6cb6b6e5f411c6691e5dd17c266 Signed-off-by: Ryan Salsamendi <rsalsamendi@hotmail.com> Reviewed-on: https://review.coreboot.org/20443 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Nico Huber <nico.h@gmx.de> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Paul Menzel <paulepanter@users.sourceforge.net>
This commit is contained in:
parent
0c731b512a
commit
0d9b360b42
|
@ -48,7 +48,7 @@ static void azalia_pch_init(struct device *dev, u8 *base)
|
||||||
u16 reg16;
|
u16 reg16;
|
||||||
u32 reg32;
|
u32 reg32;
|
||||||
|
|
||||||
if (RCBA32(0x2030) & (1 << 31)) {
|
if (RCBA32(0x2030) & (1UL << 31)) {
|
||||||
reg32 = pci_read_config32(dev, 0x120);
|
reg32 = pci_read_config32(dev, 0x120);
|
||||||
reg32 &= 0xf8ffff01;
|
reg32 &= 0xf8ffff01;
|
||||||
reg32 |= (1 << 25);
|
reg32 |= (1 << 25);
|
||||||
|
@ -72,9 +72,9 @@ static void azalia_pch_init(struct device *dev, u8 *base)
|
||||||
(1 << 25) | (1 << 26))) {
|
(1 << 25) | (1 << 26))) {
|
||||||
reg32 = pci_read_config32(dev, 0x120);
|
reg32 = pci_read_config32(dev, 0x120);
|
||||||
if (pch_is_lp())
|
if (pch_is_lp())
|
||||||
reg32 &= ~(1 << 31);
|
reg32 &= ~(1UL << 31);
|
||||||
else
|
else
|
||||||
reg32 |= (1 << 31);
|
reg32 |= (1UL << 31);
|
||||||
pci_write_config32(dev, 0x120, reg32);
|
pci_write_config32(dev, 0x120, reg32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -101,7 +101,7 @@ static void azalia_pch_init(struct device *dev, u8 *base)
|
||||||
|
|
||||||
if (!pch_is_lp()) {
|
if (!pch_is_lp()) {
|
||||||
reg32 = pci_read_config32(dev, 0xd0);
|
reg32 = pci_read_config32(dev, 0xd0);
|
||||||
reg32 &= ~(1 << 31);
|
reg32 &= ~(1UL << 31);
|
||||||
pci_write_config32(dev, 0xd0, reg32);
|
pci_write_config32(dev, 0xd0, reg32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -429,7 +429,7 @@ static void enable_clock_gating(device_t dev)
|
||||||
|
|
||||||
reg32 = RCBA32(CG);
|
reg32 = RCBA32(CG);
|
||||||
reg32 |= (1 << 22); // HDA Dynamic
|
reg32 |= (1 << 22); // HDA Dynamic
|
||||||
reg32 |= (1 << 31); // LPC Dynamic
|
reg32 |= (1UL << 31); // LPC Dynamic
|
||||||
reg32 |= (1 << 16); // PCIe Dynamic
|
reg32 |= (1 << 16); // PCIe Dynamic
|
||||||
reg32 |= (1 << 27); // HPET Dynamic
|
reg32 |= (1 << 27); // HPET Dynamic
|
||||||
reg32 |= (1 << 28); // GPIO Dynamic
|
reg32 |= (1 << 28); // GPIO Dynamic
|
||||||
|
|
|
@ -547,7 +547,7 @@ void pch_enable_lpc(void);
|
||||||
#define RPFN 0x0404 /* 32bit */
|
#define RPFN 0x0404 /* 32bit */
|
||||||
|
|
||||||
/* Root Port configuratinon space hide */
|
/* Root Port configuratinon space hide */
|
||||||
#define RPFN_HIDE(port) (1 << (((port) * 4) + 3))
|
#define RPFN_HIDE(port) (1UL << (((port) * 4) + 3))
|
||||||
/* Get the function number assigned to a Root Port */
|
/* Get the function number assigned to a Root Port */
|
||||||
#define RPFN_FNGET(reg,port) (((reg) >> ((port) * 4)) & 7)
|
#define RPFN_FNGET(reg,port) (((reg) >> ((port) * 4)) & 7)
|
||||||
/* Set the function number for a Root Port */
|
/* Set the function number for a Root Port */
|
||||||
|
|
|
@ -608,7 +608,7 @@ static void pch_pcie_early(struct device *dev)
|
||||||
pci_update_config32(dev, 0x64, ~(1 << 11), (1 << 11));
|
pci_update_config32(dev, 0x64, ~(1 << 11), (1 << 11));
|
||||||
pci_update_config32(dev, 0x68, ~(1 << 10), (1 << 10));
|
pci_update_config32(dev, 0x68, ~(1 << 10), (1 << 10));
|
||||||
|
|
||||||
pci_update_config32(dev, 0x318, ~(0xffff << 16), (0x1414 << 16));
|
pci_update_config32(dev, 0x318, ~(0xffffUL << 16), (0x1414UL << 16));
|
||||||
|
|
||||||
/* Set L1 exit latency in LCAP register. */
|
/* Set L1 exit latency in LCAP register. */
|
||||||
if (!do_aspm && (pci_read_config8(dev, 0xf5) & 0x1))
|
if (!do_aspm && (pci_read_config8(dev, 0xf5) & 0x1))
|
||||||
|
|
|
@ -45,7 +45,7 @@ static void print_status_bits(u32 status, const char *bit_names[])
|
||||||
return;
|
return;
|
||||||
|
|
||||||
for (i=31; i>=0; i--) {
|
for (i=31; i>=0; i--) {
|
||||||
if (status & (1 << i)) {
|
if (status & (1UL << i)) {
|
||||||
if (bit_names[i])
|
if (bit_names[i])
|
||||||
printk(BIOS_DEBUG, "%s ", bit_names[i]);
|
printk(BIOS_DEBUG, "%s ", bit_names[i]);
|
||||||
else
|
else
|
||||||
|
|
|
@ -297,7 +297,7 @@ static void sata_init(struct device *dev)
|
||||||
|
|
||||||
reg32 = pci_read_config32(dev, 0x300);
|
reg32 = pci_read_config32(dev, 0x300);
|
||||||
reg32 |= (1 << 17) | (1 << 16);
|
reg32 |= (1 << 17) | (1 << 16);
|
||||||
reg32 |= (1 << 31) | (1 << 30) | (1 << 29);
|
reg32 |= (1UL << 31) | (1 << 30) | (1 << 29);
|
||||||
pci_write_config32(dev, 0x300, reg32);
|
pci_write_config32(dev, 0x300, reg32);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -342,13 +342,13 @@ static void usb_xhci_init(device_t dev)
|
||||||
|
|
||||||
/* D20:F0:44h[31] = 1 (Access Control Bit) */
|
/* D20:F0:44h[31] = 1 (Access Control Bit) */
|
||||||
reg32 = pci_read_config32(dev, 0x44);
|
reg32 = pci_read_config32(dev, 0x44);
|
||||||
reg32 |= (1 << 31);
|
reg32 |= (1UL << 31);
|
||||||
pci_write_config32(dev, 0x44, reg32);
|
pci_write_config32(dev, 0x44, reg32);
|
||||||
|
|
||||||
/* D20:F0:40h[31,23] = 10b (OC Configuration Done) */
|
/* D20:F0:40h[31,23] = 10b (OC Configuration Done) */
|
||||||
reg32 = pci_read_config32(dev, 0x40);
|
reg32 = pci_read_config32(dev, 0x40);
|
||||||
reg32 &= ~(1 << 23); /* unsupported request */
|
reg32 &= ~(1 << 23); /* unsupported request */
|
||||||
reg32 |= (1 << 31);
|
reg32 |= (1UL << 31);
|
||||||
pci_write_config32(dev, 0x40, reg32);
|
pci_write_config32(dev, 0x40, reg32);
|
||||||
|
|
||||||
if (acpi_is_wakeup_s3()) {
|
if (acpi_is_wakeup_s3()) {
|
||||||
|
|
Loading…
Reference in New Issue