Received: by 2002:a05:6902:102b:0:0:0:0 with SMTP id x11csp2211725ybt; Sun, 28 Jun 2020 11:36:22 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwIFtudZPUJZrhNsaMiaxi+ByIBYMVhY9wQJQtPyfqYVzcGljYJg4AaebVvcRf2WncGJoeW X-Received: by 2002:aa7:d792:: with SMTP id s18mr14273618edq.7.1593369382148; Sun, 28 Jun 2020 11:36:22 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1593369382; cv=none; d=google.com; s=arc-20160816; b=kn2Q0vm/QcaaZNeS0R1Zg+X/vZOBZV9S6lVEKRYH6qYFtN1QJAMEIiciaJFXwLM/1W gvYaaitN17K2I/xyRk5w0px41RIAE8nC9+J7CwMRVF/qJLwfCnWX0cxJC/Mbldi1zyah HIepwDmdcm4FcOgeDOqfYwB+4tpMqk61s0Tdb+ZxflFnMU4muck3WmzxIWseGoziUNax 7xoOJ8N03Jkn0rZkanQlCjuVmb4ZdPaD4giPA+KEBe3NsqMPWRP/kX4Yd03Pt92RXJKd 6Ns9ri/uATgWmMLyAZ9rDB566If3yQGRxfzp2oOkPU8S8ORLOx7ZpNzomdLR5p5iIRKP LZeA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:mime-version:user-agent:date:message-id:cc:to :subject:from:dkim-signature:dkim-signature; bh=UPP6gukaexX7wrM9u2+d3aN4JoGVQpabllHG+ax6iC4=; b=BAM0ZZEuOyo7qpzX1OieNDda8X26zJVOIpSabu3Tezh8LSmKLoxXrYv7ZnIszgT1p9 i4vrOX0ZnWGq/rlUBg0qKlbagTxjGMFRuROSgAhc5zFiIoTQq9oVlQcaWv72jsxX24XQ 0Yeg4+uU3V8cdOxmTZXJlTUzr9NRIJud8g5UxHCbW4f32J4dPhNCjlT7IwO/lv5/dLND 9yoA9dcKxHNneUF6EXm9ZZYjf6LKZ7vjm0egg6q1BDku7sgMA7d4Ad+5ChSxqjCrp0+d 1Z0jc636Su0JSEl9HQr82CZmtPuKFUNcwV3B80PpSdRloifq8lMFjbIFjau9UjjhIrkL uU3g== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@octiron.net header.s=20180214 header.b=P4a9ROh3; dkim=pass header.i=@octiron.net header.s=20180214 header.b="J239Wtw/"; 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=REJECT dis=NONE) header.from=octiron.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id v3si21151916eja.251.2020.06.28.11.35.59; Sun, 28 Jun 2020 11:36:22 -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=fail header.i=@octiron.net header.s=20180214 header.b=P4a9ROh3; dkim=pass header.i=@octiron.net header.s=20180214 header.b="J239Wtw/"; 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=REJECT dis=NONE) header.from=octiron.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726710AbgF1SdE (ORCPT + 99 others); Sun, 28 Jun 2020 14:33:04 -0400 Received: from chalk.uuid.uk ([51.68.227.198]:40200 "EHLO chalk.uuid.uk" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726060AbgF1SdE (ORCPT ); Sun, 28 Jun 2020 14:33:04 -0400 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=octiron.net ; s=20180214; h=Content-Transfer-Encoding:Content-Type:MIME-Version:Date: Message-ID:Cc:To:Subject:From:Sender:Reply-To:Content-ID:Content-Description: Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: In-Reply-To:References:List-Id:List-Help:List-Unsubscribe:List-Subscribe: List-Post:List-Owner:List-Archive; bh=UPP6gukaexX7wrM9u2+d3aN4JoGVQpabllHG+ax6iC4=; b=P4a9ROh3EPZ966cceO9uIr/ws4 cDjT6wFy2mZK16+McYwR6V2meWKZnRos4gDdqFtHHK1NgieFeWY7AcIjwBuuJ+yvQ1cIu6PL6HpxQ 8ccl7drgd1QlDxQ6LTsNBZOO+AWUbKkJUafMCzlgUh6GfyhejyX+Ro+vIjaU6O5PH8zo4zGXd3hVT yTJLgsDhAEiEb6BmRLO7Hhcmnc5wt++BZfK0C4CX7RFJKRnZM6ueidsTGEEk0xwUw+2gMlwu12Spk GfTktW4C0vFrx/Pfy19GAD33MAxwYrdOhgPAoKVW1ezoC1HGXqKqnMqlGWDqSeRSWrwFIBDKiT055 N2DtURQw==; Received: by chalk.uuid.uk with esmtpsa (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.90_1) (envelope-from ) id 1jpc6n-0000Az-GF; Sun, 28 Jun 2020 19:32:54 +0100 DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=octiron.net ; s=20180214; h=Content-Transfer-Encoding:Content-Type:MIME-Version:Date: Message-ID:Cc:To:Subject:From; bh=UPP6gukaexX7wrM9u2+d3aN4JoGVQpabllHG+ax6iC4=; b=J239Wtw/GzbBYC7vjs9SccvUos 55kndDxz5eavZKN9YFL/4IP/RN9xYySYmti/9USnJV3w11a22cDcApC7BsHV6Mmr9lC3j2i1CuiQ8 m9wSZGf04FS+0NZjwkqFTL40sWMFOBLdFbeh+wZe7ujZfTUdEkk91/mvQQA2oSSyZEwAq3a1A9uhB vFzy8a2JSc6PLU+8zYrR1DiCva7SOUrAzyx6HNHN4aeSmy2mh5+JABmTvI4A5hKmIgqu+0y+7auS3 TQdx8RHQeotalH8cuT+e7XUJw/v0LTEaThVprjb3KLBItucosPEmPkt4iv7xQh9wq+BKq7vyBOKqt 28bISPSw==; Received: by tsort.uuid.uk with esmtps (TLS1.2:ECDHE_RSA_AES_128_GCM_SHA256:128) (Exim 4.86_2) (envelope-from ) id 1jpc6l-0007Oy-Kv; Sun, 28 Jun 2020 19:32:52 +0100 From: Simon Arlott Subject: [PATCH (v2)] scsi: sd: add parameter to stop disks before reboot To: "James E.J. Bottomley" , "Martin K. Petersen" , Jonathan Corbet , Linux Kernel Mailing List , linux-scsi@vger.kernel.org, linux-doc@vger.kernel.org Cc: Bart Van Assche , Christoph Hellwig , Damien Le Moal , Pavel Machek , Henrique de Moraes Holschuh Message-ID: Date: Sun, 28 Jun 2020 19:32:51 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.8.0 MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Language: en-GB Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org I need to use "reboot=p" on my desktop because one of the PCIe devices does not appear after a warm boot. This results in a very cold boot because the BIOS turns the PSU off and on. The scsi sd shutdown process does not send a stop command to disks before the reboot happens (stop commands are only sent for a shutdown). The result is that all of my SSDs experience a sudden power loss on every reboot, which is undesirable behaviour because it could cause data to be corrupted. These events are recorded in the SMART attributes. Add a "stop_before_reboot" module parameter that can be used to control the shutdown behaviour of disks before a reboot. The default will be the existing behaviour (disks are not stopped). sd_mod.stop_before_reboot= 0 = disabled (default) 1 = enabled The behaviour on shutdown is unchanged: all disks are unconditionally stopped. Signed-off-by: Simon Arlott --- Documentation/scsi/scsi-parameters.rst | 5 +++++ drivers/scsi/sd.c | 14 +++++++++++--- 2 files changed, 16 insertions(+), 3 deletions(-) diff --git a/Documentation/scsi/scsi-parameters.rst b/Documentation/scsi/scsi-parameters.rst index 9aba897c97ac..324610870de5 100644 --- a/Documentation/scsi/scsi-parameters.rst +++ b/Documentation/scsi/scsi-parameters.rst @@ -101,6 +101,11 @@ parameters may be changed at runtime by the command allowing boot to proceed. none ignores them, expecting user space to do the scan. + sd_mod.stop_before_reboot= + [SCSI] configure stop action for disks before a reboot + Format: + 0 = disabled (default), 1 = enabled + sim710= [SCSI,HW] See header of drivers/scsi/sim710.c. diff --git a/drivers/scsi/sd.c b/drivers/scsi/sd.c index d90fefffe31b..506904bf15da 100644 --- a/drivers/scsi/sd.c +++ b/drivers/scsi/sd.c @@ -98,6 +98,12 @@ MODULE_ALIAS_SCSI_DEVICE(TYPE_MOD); MODULE_ALIAS_SCSI_DEVICE(TYPE_RBC); MODULE_ALIAS_SCSI_DEVICE(TYPE_ZBC); +static unsigned int stop_before_reboot = 0; + +module_param(stop_before_reboot, uint, 0644); +MODULE_PARM_DESC(stop_before_reboot, + "stop disks before reboot"); + #if !defined(CONFIG_DEBUG_BLOCK_EXT_DEVT) #define SD_MINORS 16 #else @@ -3576,9 +3582,11 @@ static void sd_shutdown(struct device *dev) sd_sync_cache(sdkp, NULL); } - if (system_state != SYSTEM_RESTART && sdkp->device->manage_start_stop) { - sd_printk(KERN_NOTICE, sdkp, "Stopping disk\n"); - sd_start_stop_device(sdkp, 0); + if (sdkp->device->manage_start_stop) { + if (system_state != SYSTEM_RESTART || stop_before_reboot) { + sd_printk(KERN_NOTICE, sdkp, "Stopping disk\n"); + sd_start_stop_device(sdkp, 0); + } } } -- 2.17.1 -- Simon Arlott