From: Dan Williams <dan.j.williams@intel.com>
Date: Mon, 2 Apr 2018 15:28:03 -0700
Subject: nfit, address-range-scrub: add module option to skip initial ars
Patch-mainline: v4.17-rc1
Git-commit: bca811a7fd5a5c1c0644926161c2843322ab74b3
References: bsc#1094119
After attempting to quickly retrieve known errors the kernel proceeds to
kick off a long running ARS. Add a module option to disable this
behavior at initialization time, or at new region discovery time.
Otherwise, ARS can be started manually regardless of the state of this
setting.
Co-developed-by: Dave Jiang <dave.jiang@intel.com>
Signed-off-by: Dave Jiang <dave.jiang@intel.com>
Signed-off-by: Dan Williams <dan.j.williams@intel.com>
Acked-by: Johannes Thumshirn <jthumshirn@suse.de>
---
drivers/acpi/nfit/core.c | 7 +++++++
1 file changed, 7 insertions(+)
--- a/drivers/acpi/nfit/core.c
+++ b/drivers/acpi/nfit/core.c
@@ -50,6 +50,10 @@ module_param(default_dsm_family, int, S_
MODULE_PARM_DESC(default_dsm_family,
"Try this DSM type first when identifying NVDIMM family");
+static bool no_init_ars;
+module_param(no_init_ars, bool, 0644);
+MODULE_PARM_DESC(no_init_ars, "Skip ARS run at nfit init time");
+
LIST_HEAD(acpi_descs);
DEFINE_MUTEX(acpi_desc_lock);
@@ -2789,6 +2793,9 @@ static int ars_register(struct acpi_nfit
{
int rc = *query_rc;
+ if (no_init_ars)
+ return acpi_nfit_register_region(acpi_desc, nfit_spa);
+
set_bit(ARS_REQ, &nfit_spa->ars_state);
set_bit(ARS_SHORT, &nfit_spa->ars_state);