Received: by 2002:a05:6a11:4021:0:0:0:0 with SMTP id ky33csp2319173pxb; Mon, 20 Sep 2021 18:42:05 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwQCvBH3HXrspdSCqhtOhOAl/Ihk4AbVsopEnUXRbyfgPhkRVdMVYzfuNvEqLy8Eq69Ks41 X-Received: by 2002:a92:ca07:: with SMTP id j7mr17140221ils.29.1632188525668; Mon, 20 Sep 2021 18:42:05 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1632188525; cv=none; d=google.com; s=arc-20160816; b=DWUNrhF4y38bFQRPu1pvwRTIMPt/SWSELQIYNUvRnFw/vs620YolC0eUG2VG1Z52Tk YHYOBENFueps80NG1hVt5jbJBTrM8cb/fEmWLEf6g4fnpR5w+ZxxHVQau5GMvDDfhyKq dwhB/66frF+4nhBWqMOh0K5etWZjgqQ/XOlPBaj89DwT7knbAEMgn1fWT/fpd0zXDIRF hl5xOLURblKI/O9HQZUe+PEEXsSb0YzREImVkjzg1tFR1uSy2sDsO6RrgI2VkUlrHS0i x2kz0/M+5wMb1iZqXu6l/gQ7W3gF6Y/0EFjnRpKFMEUO+YqpdTOd4sq7T6WQ/UcKbzqM UYQQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=xKADVVSpzDChUFr3iA681jVdhGm3rNqxp6i1inxpTwg=; b=dI0hUqrZmdHTEyd+kruwx2J1IkXN0unPsdKqDKuN1tqZrEW8Aul+ypmcx4lDV9zJBa YfBnIcPXu5pviTZ1JK70HmthZJILzsXHqZbyYdlQCWUtxLIibw2K5zHH500WZN3jndoR pMnm96GAOEQvfGzFhFW1mafW1EvoOgcmofSAH+tfLLAAgx3DABxTTMR4u8MJIRo9DKLP ImBhXi+Vw37AxYs5O08ilgTRPa6Eg0avOU0jbmuH+AzwzyXIcCK6nYvfJJY+scL1mnf2 cRC0Pecw+SOtebKYT5aQsAdju/+LUC8msIX6Q1wysNZkVbxEhzjacznDHztxZxFqoIzV 1aUg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=QSzLDEsH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id e28si3996831ioc.25.2021.09.20.18.41.53; Mon, 20 Sep 2021 18:42:05 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=QSzLDEsH; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S244970AbhITQvv (ORCPT + 99 others); Mon, 20 Sep 2021 12:51:51 -0400 Received: from mail.kernel.org ([198.145.29.99]:36554 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S243937AbhITQsv (ORCPT ); Mon, 20 Sep 2021 12:48:51 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id B5CCD61351; Mon, 20 Sep 2021 16:47:18 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1632156439; bh=TqIb1t05LlT0ujhsZbYe4i7tkQ4RW9q+xRZBdas8XH4=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=QSzLDEsHN3Qa78B8qOZ2NmmT6u0ZFVlRFlftNoGa/KUWcAPQ29MjVbW0Uty4upxcL meuK+/RhrIp+rVjJ/Iti9jJhvl+xwJQVe4zjG0BNmAd1wrQzVtibe88MxQIHc0qU5k //YPZlJcbpMXlRD48jTxfhVp6UwQOKKLHnXCjam0= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Paul Gortmaker , Thomas Gleixner Subject: [PATCH 4.4 027/133] x86/reboot: Limit Dell Optiplex 990 quirk to early BIOS versions Date: Mon, 20 Sep 2021 18:41:45 +0200 Message-Id: <20210920163913.504635735@linuxfoundation.org> X-Mailer: git-send-email 2.33.0 In-Reply-To: <20210920163912.603434365@linuxfoundation.org> References: <20210920163912.603434365@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Paul Gortmaker commit a729691b541f6e63043beae72e635635abe5dc09 upstream. When this platform was relatively new in November 2011, with early BIOS revisions, a reboot quirk was added in commit 6be30bb7d750 ("x86/reboot: Blacklist Dell OptiPlex 990 known to require PCI reboot") However, this quirk (and several others) are open-ended to all BIOS versions and left no automatic expiry if/when the system BIOS fixed the issue, meaning that nobody is likely to come along and re-test. What is really problematic with using PCI reboot as this quirk does, is that it causes this platform to do a full power down, wait one second, and then power back on. This is less than ideal if one is using it for boot testing and/or bisecting kernels when legacy rotating hard disks are installed. It was only by chance that the quirk was noticed in dmesg - and when disabled it turned out that it wasn't required anymore (BIOS A24), and a default reboot would work fine without the "harshness" of power cycling the machine (and disks) down and up like the PCI reboot does. Doing a bit more research, it seems that the "newest" BIOS for which the issue was reported[1] was version A06, however Dell[2] seemed to suggest only up to and including version A05, with the A06 having a large number of fixes[3] listed. As is typical with a new platform, the initial BIOS updates come frequently and then taper off (and in this case, with a revival for CPU CVEs); a search for O990-A.exe reveals the following dates: A02 16 Mar 2011 A03 11 May 2011 A06 14 Sep 2011 A07 24 Oct 2011 A10 08 Dec 2011 A14 06 Sep 2012 A16 15 Oct 2012 A18 30 Sep 2013 A19 23 Sep 2015 A20 02 Jun 2017 A23 07 Mar 2018 A24 21 Aug 2018 While it's overkill to flash and test each of the above, it would seem likely that the issue was contained within A0x BIOS versions, given the dates above and the dates of issue reports[4] from distros. So rather than just throw out the quirk entirely, limit the scope to just those early BIOS versions, in case people are still running systems from 2011 with the original as-shipped early A0x BIOS versions. [1] https://lore.kernel.org/lkml/1320373471-3942-1-git-send-email-trenn@suse.de/ [2] https://www.dell.com/support/kbdoc/en-ca/000131908/linux-based-operating-systems-stall-upon-reboot-on-optiplex-390-790-990-systems [3] https://www.dell.com/support/home/en-ca/drivers/driversdetails?driverid=85j10 [4] https://bugs.launchpad.net/ubuntu/+source/linux/+bug/768039 Fixes: 6be30bb7d750 ("x86/reboot: Blacklist Dell OptiPlex 990 known to require PCI reboot") Signed-off-by: Paul Gortmaker Signed-off-by: Thomas Gleixner Cc: stable@vger.kernel.org Link: https://lore.kernel.org/r/20210530162447.996461-4-paul.gortmaker@windriver.com Signed-off-by: Greg Kroah-Hartman --- arch/x86/kernel/reboot.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) --- a/arch/x86/kernel/reboot.c +++ b/arch/x86/kernel/reboot.c @@ -337,10 +337,11 @@ static struct dmi_system_id __initdata r }, { /* Handle problems with rebooting on the OptiPlex 990. */ .callback = set_pci_reboot, - .ident = "Dell OptiPlex 990", + .ident = "Dell OptiPlex 990 BIOS A0x", .matches = { DMI_MATCH(DMI_SYS_VENDOR, "Dell Inc."), DMI_MATCH(DMI_PRODUCT_NAME, "OptiPlex 990"), + DMI_MATCH(DMI_BIOS_VERSION, "A0"), }, }, { /* Handle problems with rebooting on Dell 300's */