]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
PCI: Fix old_size lower bound in calculate_iosize() too
authorIlpo Järvinen <ilpo.jarvinen@linux.intel.com>
Mon, 16 Dec 2024 17:56:12 +0000 (19:56 +0200)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Thu, 29 May 2025 09:13:17 +0000 (11:13 +0200)
[ Upstream commit ff61f380de5652e723168341480cc7adf1dd6213 ]

Commit 903534fa7d30 ("PCI: Fix resource double counting on remove &
rescan") fixed double counting of mem resources because of old_size being
applied too early.

Fix a similar counting bug on the io resource side.

Link: https://lore.kernel.org/r/20241216175632.4175-6-ilpo.jarvinen@linux.intel.com
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@linux.intel.com>
Signed-off-by: Bjorn Helgaas <bhelgaas@google.com>
Tested-by: Xiaochun Lee <lixc17@lenovo.com>
Signed-off-by: Sasha Levin <sashal@kernel.org>
drivers/pci/setup-bus.c

index 8707c5b08cf341c33437efa3114308272a6698d5..477eb07bfbca91cd173abb9715a2ee8ccfe57578 100644 (file)
@@ -814,11 +814,9 @@ static resource_size_t calculate_iosize(resource_size_t size,
        size = (size & 0xff) + ((size & ~0xffUL) << 2);
 #endif
        size = size + size1;
-       if (size < old_size)
-               size = old_size;
 
-       size = ALIGN(max(size, add_size) + children_add_size, align);
-       return size;
+       size = max(size, add_size) + children_add_size;
+       return ALIGN(max(size, old_size), align);
 }
 
 static resource_size_t calculate_memsize(resource_size_t size,