Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753290Ab3IWGPv (ORCPT ); Mon, 23 Sep 2013 02:15:51 -0400 Received: from nm22-vm6.access.bullet.mail.gq1.yahoo.com ([216.39.63.170]:36305 "EHLO nm22-vm6.access.bullet.mail.gq1.yahoo.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751944Ab3IWGPu (ORCPT ); Mon, 23 Sep 2013 02:15:50 -0400 X-Yahoo-Newman-Id: 484410.43093.bm@smtp120.sbc.mail.gq1.yahoo.com X-Yahoo-Newman-Property: ymail-3 X-YMail-OSG: MsM_vnUVM1kpMEVlt1y4X4Ngdp90sO4pPagXMswS53s35lX CseakqPW10y9MbVKxOFm5q7ncyVRzC76wIKVpJ2Ug2qANKLEllgqJ1qlaJLh AdjtemN3SqbUThEkIyrYgrUk9EjesQbjqHt.4L.oWu8ZVfAWLxUK_xlkWSGk DnP0gcWJphAbZTWf73QbBMx.jjWvgCpLn4dujGO5yWAfpg0zfvG_pZWijATl t80CHPfnamKLTVuadKpA0BHXBVQBX_W7rzQRCnMzWmzylsEoGIKcXn43_IIQ o.GILrxMS314qDV4ztG276Q9pHriRPiGIx_Rt0qVuQdckVV5Sc1Ac1cPFGhk 82_.aOUU7FVfTmwtAunF8tNXGrSBsnrIwmiAbDVUTNQehtiZ.l1Vm13Yncj_ hWVF5g242KUV0V8N5miXRvzyj83LDpDpEnW0phaGZJ8lnGi1PaxrMwb_Vq1w 6QwlBGqBZLEvncIi4gMbFE9wceH8HCP_vhlEdts1c.lW8cvux8xYqxADa1hN 6tJRUIY5_IIyxV0RkgeRkIFQ3hIlB_oG84wDiWfwJvsNBKRc1iNc56vpasoe ngJ0- X-Yahoo-SMTP: 0h0Q7euswBD_g.kcEqbzJWRFfrba801gq1M1 X-Rocket-Received: from mistral.localnet (stilor@108.252.240.182 with ) by smtp120.sbc.mail.gq1.yahoo.com with SMTP; 23 Sep 2013 06:15:48 +0000 UTC From: Alexey Neyman To: Thomas Gleixner , Ingo Molnar , "H. Peter Anvin" , Bjorn Helgaas , "Rafael J. Wysocki" , Feng Tang , Yijing Wang Cc: x86@kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH] Fix coalescing host bridge windows in arch/x86/pci/acpi.c Date: Sun, 22 Sep 2013 23:15:46 -0700 Message-ID: <6362938.J7ZtNEOFpc@mistral> User-Agent: KMail/4.10.4 (Linux/3.8.0-25-generic; KDE/4.10.5; x86_64; ; ) MIME-Version: 1.0 Content-Type: multipart/mixed; boundary="nextPart2146602.P7lzYueRtG" Content-Transfer-Encoding: 7Bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2773 Lines: 72 This is a multi-part message in MIME format. --nextPart2146602.P7lzYueRtG Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" [Resending due to no response to the original message in a week] Hi all, I have a board with a BIOS bug that reports the following I/O port regions in _CRS on one of the host bridges: 0x0000-0x03af // #0 0x03e0-0x0cf7 // #1 0x03b0-0x03bb // #2 0x03c0-0x03df // #3 0x0000-0xdfff // #4 0xf000-0xffff // #5 Obviously, region number #4 is erroneous as it overlaps with regions #0..3. The code in coalesce_windows() in arch/x86/pci/acpi.c attempts to recover from such kind of BIOS bugs by merging the overlapping regions. Current code expands region #0 to 0x0000-0xdffff and makes region #4 ignored. As a result, overlap of the expanded region #0 with regions #1..3 remains undetected (as the inner loop already compared them with region #0). As a result, regions #1..3 are inserted into the resource tree even though they overlap with adjusted region #0 - which later results in resource conflicts for PCI devices with IO ports in one of those regions (e.g., for an PCI IDE controller in legacy mode - which has port 0x3f6). The kernel then refuses to initialize these devices. The fix: instead of expanding res1 and ignoring res2, do the opposite. The res2 window is yet to be compared against all windows between res1 and res2 (regions #1..3 in the above example), so the resulting resource map will include just the expanded region - and will ignore any overlapping ones. Signed-off-by: Alexey Neyman --nextPart2146602.P7lzYueRtG Content-Disposition: attachment; filename="acpi.c.diff" Content-Transfer-Encoding: 7Bit Content-Type: text/x-patch; charset="UTF-8"; name="acpi.c.diff" diff --git a/arch/x86/pci/acpi.c b/arch/x86/pci/acpi.c index b30e937..7fb24e5 100644 --- a/arch/x86/pci/acpi.c +++ b/arch/x86/pci/acpi.c @@ -354,12 +354,12 @@ static void coalesce_windows(struct pci_root_info *info, unsigned long type) * the kernel resource tree doesn't allow overlaps. */ if (resource_overlaps(res1, res2)) { - res1->start = min(res1->start, res2->start); - res1->end = max(res1->end, res2->end); + res2->start = min(res1->start, res2->start); + res2->end = max(res1->end, res2->end); dev_info(&info->bridge->dev, "host bridge window expanded to %pR; %pR ignored\n", - res1, res2); - res2->flags = 0; + res2, res1); + res1->flags = 0; } } } --nextPart2146602.P7lzYueRtG-- -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/