]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
pci/shpc: fix signed integer overflow
authorMichael S. Tsirkin <mst@redhat.com>
Mon, 9 Mar 2015 14:59:46 +0000 (15:59 +0100)
committerMichael S. Tsirkin <mst@redhat.com>
Wed, 11 Mar 2015 14:59:57 +0000 (15:59 +0100)
clang undefined behaviour sanitizer reports:
> hw/pci/shpc.c:162:27: runtime error: left shift of 1 by 31 places
> cannot be represented in type 'int'

Caused by the usual lack of a 'U' qualifier on a constant 1 being
shifted left. Fix it up.

Reported-by: Peter Maydell <peter.maydell@linaro.org>
Signed-off-by: Michael S. Tsirkin <mst@redhat.com>
hw/pci/shpc.c

index 5fd7f4bbb7fcda404e2c74e28009029a2e61b5ef..759910f79a88c0f53901f3de3104db57762716b7 100644 (file)
@@ -159,7 +159,7 @@ static void shpc_interrupt_update(PCIDevice *d)
     for (slot = 0; slot < shpc->nslots; ++slot) {
         uint8_t event = shpc->config[SHPC_SLOT_EVENT_LATCH(slot)];
         uint8_t disable = shpc->config[SHPC_SLOT_EVENT_SERR_INT_DIS(d, slot)];
-        uint32_t mask = 1 << SHPC_IDX_TO_LOGICAL(slot);
+        uint32_t mask = 1U << SHPC_IDX_TO_LOGICAL(slot);
         if (event & ~disable) {
             int_locator |= mask;
         }