Received: by 2002:a17:90a:88:0:0:0:0 with SMTP id a8csp14835pja; Fri, 22 Nov 2019 02:50:00 -0800 (PST) X-Google-Smtp-Source: APXvYqyDH2e9P5QDFCg74jLndNW5GcdZ/x4Zmm5mWjY0A+y128L4IT6qMzxh0kbafXr93iXGaKf3 X-Received: by 2002:a50:ec97:: with SMTP id e23mr247716edr.111.1574419800452; Fri, 22 Nov 2019 02:50:00 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1574419800; cv=none; d=google.com; s=arc-20160816; b=jOhENrQ2yBvrR4xDDp5gbWFyone+bUW+4dHHf9OzTx9euLgmes4oaKyhv1wHIWS2y3 C5yG7MConoaegfEf/P1D+rRWa2W24+HpWtiJ82jxp8b3GOsrYsoD0eWWMTvu31teaGlL 7M57cl0MnpBpxwhBhGXsMdsaX0SZH2DjEmq4gIHDAaDsFu/TL43OLYukEwju/IR+F5KH +oEUmEE2Nsm2ve6xn2e26fIKo52HuJNW2z+fhyCfJkUX2SXnhvMbnG3IyApwoSJuTOR2 bvIe5wX0XsYEs/MazOihHK2MceXuUb8AZ6BsGcVjusQysqVwmW9BPOVh1GACCY1s9wvw Lybw== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=s5sr1jVPBQg8nHDkK8G9n5MlUQFcMiWKZ+xVHic+/Q0=; b=TpQt5YPfztMoZQXYJ7vDHS6TmhFtqKYoaAewA7z/mcL+dyINUYGsXE5L6q8rv6oQLp 7XJDMv70+a4XkvWnbtvOKI5oEzXDnRRvpyhxp8HdIxSgaHAaUBAy/aJ56ahduYNkX2k8 qKGNg2YYOXgMBG2qidHcIMfLoTK/t0wdMkSdXRcdCsdpFHtFDfgTFlWGt3E1KkD1DBuo V2uYPodSxG7/ZEH+sHuuub/I4nMWif1kjkHK1v5Vls5k2Xvgt8xR/Abqd4zduow+GckY nLJWD3ZZZW6B5gbGovHUEQpwnijE8GoDIS9h4rnVOpKU68E9LWuAG8u6TKJZDaYP3UHN pMjQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OrxK6Qou; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id mh20si617693ejb.268.2019.11.22.02.49.36; Fri, 22 Nov 2019 02:50:00 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=OrxK6Qou; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1728776AbfKVKrK (ORCPT + 99 others); Fri, 22 Nov 2019 05:47:10 -0500 Received: from mail.kernel.org ([198.145.29.99]:54822 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729738AbfKVKrH (ORCPT ); Fri, 22 Nov 2019 05:47:07 -0500 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 27CC720637; Fri, 22 Nov 2019 10:47:05 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1574419626; bh=0lcDox0pzW+j0DkcAwN8jvU/lx22Ypx2/yL4h5meA2Q=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=OrxK6QouQMVtccrSz7NT6yrgzpafdVX3dx69OaxrTRtCtym2dXFrNazImINIzNInL 9e/vGocx6ri1H5Gr3a8nU0JlXHrrCp+MpAjIo33rjh6AJiocj724Loqx/IG9tYzRyI PjhQXuYMmw7XFaBs0NR8PXpLuc83Ei1Y85mCHlNY= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Bob Moore , Erik Schmauss , "Rafael J. Wysocki" , Sasha Levin Subject: [PATCH 4.9 178/222] ACPICA: Never run _REG on system_memory and system_IO Date: Fri, 22 Nov 2019 11:28:38 +0100 Message-Id: <20191122100915.272238040@linuxfoundation.org> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191122100830.874290814@linuxfoundation.org> References: <20191122100830.874290814@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Bob Moore [ Upstream commit 8b1cafdcb4b75c5027c52f1e82b47ebe727ad7ed ] These address spaces are defined by the ACPI spec to be "always available", and thus _REG should never be run on them. Provides compatibility with other ACPI implementations. Signed-off-by: Bob Moore Signed-off-by: Erik Schmauss Signed-off-by: Rafael J. Wysocki Signed-off-by: Sasha Levin --- drivers/acpi/acpica/acevents.h | 2 ++ drivers/acpi/acpica/aclocal.h | 2 +- drivers/acpi/acpica/evregion.c | 17 +++++++++++++++-- drivers/acpi/acpica/evrgnini.c | 6 +----- drivers/acpi/acpica/evxfregn.c | 1 - 5 files changed, 19 insertions(+), 9 deletions(-) diff --git a/drivers/acpi/acpica/acevents.h b/drivers/acpi/acpica/acevents.h index 92fa47c6498cd..20fd17aaa9189 100644 --- a/drivers/acpi/acpica/acevents.h +++ b/drivers/acpi/acpica/acevents.h @@ -247,6 +247,8 @@ acpi_status acpi_ev_initialize_region(union acpi_operand_object *region_obj, u8 acpi_ns_locked); +u8 acpi_ev_is_pci_root_bridge(struct acpi_namespace_node *node); + /* * evsci - SCI (System Control Interrupt) handling/dispatch */ diff --git a/drivers/acpi/acpica/aclocal.h b/drivers/acpi/acpica/aclocal.h index dff1207a60788..219bc576d1270 100644 --- a/drivers/acpi/acpica/aclocal.h +++ b/drivers/acpi/acpica/aclocal.h @@ -428,9 +428,9 @@ struct acpi_simple_repair_info { /* Info for running the _REG methods */ struct acpi_reg_walk_info { - acpi_adr_space_type space_id; u32 function; u32 reg_run_count; + acpi_adr_space_type space_id; }; /***************************************************************************** diff --git a/drivers/acpi/acpica/evregion.c b/drivers/acpi/acpica/evregion.c index 4c6f795140402..9cb60fdc77e50 100644 --- a/drivers/acpi/acpica/evregion.c +++ b/drivers/acpi/acpica/evregion.c @@ -677,6 +677,19 @@ acpi_ev_execute_reg_methods(struct acpi_namespace_node *node, ACPI_FUNCTION_TRACE(ev_execute_reg_methods); + /* + * These address spaces do not need a call to _REG, since the ACPI + * specification defines them as: "must always be accessible". Since + * they never change state (never become unavailable), no need to ever + * call _REG on them. Also, a data_table is not a "real" address space, + * so do not call _REG. September 2018. + */ + if ((space_id == ACPI_ADR_SPACE_SYSTEM_MEMORY) || + (space_id == ACPI_ADR_SPACE_SYSTEM_IO) || + (space_id == ACPI_ADR_SPACE_DATA_TABLE)) { + return_VOID; + } + info.space_id = space_id; info.function = function; info.reg_run_count = 0; @@ -738,8 +751,8 @@ acpi_ev_reg_run(acpi_handle obj_handle, } /* - * We only care about regions.and objects that are allowed to have address - * space handlers + * We only care about regions and objects that are allowed to have + * address space handlers */ if ((node->type != ACPI_TYPE_REGION) && (node != acpi_gbl_root_node)) { return (AE_OK); diff --git a/drivers/acpi/acpica/evrgnini.c b/drivers/acpi/acpica/evrgnini.c index 75ddd160a716f..c8646c3977865 100644 --- a/drivers/acpi/acpica/evrgnini.c +++ b/drivers/acpi/acpica/evrgnini.c @@ -50,9 +50,6 @@ #define _COMPONENT ACPI_EVENTS ACPI_MODULE_NAME("evrgnini") -/* Local prototypes */ -static u8 acpi_ev_is_pci_root_bridge(struct acpi_namespace_node *node); - /******************************************************************************* * * FUNCTION: acpi_ev_system_memory_region_setup @@ -67,7 +64,6 @@ static u8 acpi_ev_is_pci_root_bridge(struct acpi_namespace_node *node); * DESCRIPTION: Setup a system_memory operation region * ******************************************************************************/ - acpi_status acpi_ev_system_memory_region_setup(acpi_handle handle, u32 function, @@ -347,7 +343,7 @@ acpi_ev_pci_config_region_setup(acpi_handle handle, * ******************************************************************************/ -static u8 acpi_ev_is_pci_root_bridge(struct acpi_namespace_node *node) +u8 acpi_ev_is_pci_root_bridge(struct acpi_namespace_node *node) { acpi_status status; struct acpi_pnp_device_id *hid; diff --git a/drivers/acpi/acpica/evxfregn.c b/drivers/acpi/acpica/evxfregn.c index d2743067126af..f87d59a05c681 100644 --- a/drivers/acpi/acpica/evxfregn.c +++ b/drivers/acpi/acpica/evxfregn.c @@ -227,7 +227,6 @@ acpi_remove_address_space_handler(acpi_handle device, */ region_obj = handler_obj->address_space.region_list; - } /* Remove this Handler object from the list */ -- 2.20.1