Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp2879551imu; Mon, 17 Dec 2018 09:16:31 -0800 (PST) X-Google-Smtp-Source: AFSGD/WSG5TuZOiVTpwxgAhPxC4chp270I92xKJz7+/P95rKyf9k3TUa5YBRz5BNRPFm/u51KQW9 X-Received: by 2002:a62:3603:: with SMTP id d3mr14050845pfa.146.1545066991418; Mon, 17 Dec 2018 09:16:31 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1545066991; cv=none; d=google.com; s=arc-20160816; b=toyuewt+1oMlCIh4bailTCupxboA/lJ2wnCLz/3Ch5SXZTC4kTXpl82EzoDTqnNr2s +FaPF+1oLbnqiYAm9hnFCR0kENQGYEsden2/Snri9icAz6yHpZqK7UK4YP20+PpiZLvA FFalusVX0t38ecY5wlUNVRizmyJZk/0TuvwF//fNyBeWiJNrtJHVOUy7YgeMAaVbxEAf 0TJrXCy0iKEE6YWs0jZj2tKE7a3DglKlcNmE9JLoeaCAkX2fOisyTosVzJfRtrsXcQ9t wqp9z2bwd3YK8Y69FnE/hXoCgrsA4n57Hf3fZ8aiCia5A+p/BTSBUgs9fhVH5J3Sceya B31Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date; bh=FDu99nkRpNI/495cMiC38iC/wPWov0OF1HwHONknN1s=; b=Yw8KSPlgZExEbEmHXghWH0FCtFwKm5dp6m7jHOVbgX8/zpllxe0X4SiMQ57LhTvFWD BUue7nH6rhQl0LPS70guiz9IkRgbPNDiO9fUjlA2DOhbwB0Tc5HjHRSkZvkv8eaIj0Zz Bw707WMc0zb7w060jTPoDJGW2XD1yEo7gEnaYdYGHF5U+2VUNsTI4O+aQy4SAE+hAWDF d/0wuQd4KXfBwarTnwes/xrjNm6DekJ2ppy5IwFbyTM4nvVbtHn1AEDa/y5rqhrx/OX4 SCySyPiBcmHK0BbzPdWC3dd13X2dqfHt72xDxXgJM+lJtjW3botubYdVZUhStBYuZbrG 3k0A== ARC-Authentication-Results: i=1; mx.google.com; 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 p3si11054436plr.376.2018.12.17.09.16.15; Mon, 17 Dec 2018 09:16:31 -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; 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 S1727474AbeLQM4F (ORCPT + 99 others); Mon, 17 Dec 2018 07:56:05 -0500 Received: from foss.arm.com ([217.140.101.70]:55512 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727031AbeLQM4F (ORCPT ); Mon, 17 Dec 2018 07:56:05 -0500 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.72.51.249]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id 18AD5A78; Mon, 17 Dec 2018 04:56:05 -0800 (PST) Received: from e107981-ln.cambridge.arm.com (e107981-ln.cambridge.arm.com [10.1.197.40]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id B2FB03F6A8; Mon, 17 Dec 2018 04:56:03 -0800 (PST) Date: Mon, 17 Dec 2018 12:55:58 +0000 From: Lorenzo Pieralisi To: Sinan Kaya Cc: linux-acpi@vger.kernel.org, Hanjun Guo , Sudeep Holla , "Rafael J. Wysocki" , Len Brown , open list Subject: Re: [PATCH v10 6/6] ACPI/IORT: Stub out ACS functions when CONFIG_PCI is not set Message-ID: <20181217125558.GA20864@e107981-ln.cambridge.arm.com> References: <20181215010247.26101-1-okaya@kernel.org> <20181215010247.26101-7-okaya@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <20181215010247.26101-7-okaya@kernel.org> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Sat, Dec 15, 2018 at 01:02:47AM +0000, Sinan Kaya wrote: > Remove PCI dependent code out of iort.c when CONFIG_PCI is not defined. > > Signed-off-by: Sinan Kaya > --- > drivers/acpi/arm64/iort.c | 2 ++ > 1 file changed, 2 insertions(+) > > diff --git a/drivers/acpi/arm64/iort.c b/drivers/acpi/arm64/iort.c > index 70f4e80b9246..d0f68607efe6 100644 > --- a/drivers/acpi/arm64/iort.c > +++ b/drivers/acpi/arm64/iort.c > @@ -1437,6 +1437,7 @@ static int __init iort_add_platform_device(struct acpi_iort_node *node, > > static bool __init iort_enable_acs(struct acpi_iort_node *iort_node) > { > +#ifdef CONFIG_PCI > if (iort_node->type == ACPI_IORT_NODE_PCI_ROOT_COMPLEX) { > struct acpi_iort_node *parent; > struct acpi_iort_id_mapping *map; > @@ -1462,6 +1463,7 @@ static bool __init iort_enable_acs(struct acpi_iort_node *iort_node) > } > } > } > +#endif > > return false; > } > -- > 2.19.0 I would prefer the ifdef to wrap the function rather than in the function. Anyway, as an alternative, what about this: -- >8 -- diff --git a/drivers/acpi/arm64/iort.c b/drivers/acpi/arm64/iort.c index 70f4e80b9246..06d4cc888df6 100644 --- a/drivers/acpi/arm64/iort.c +++ b/drivers/acpi/arm64/iort.c @@ -1435,8 +1435,14 @@ static int __init iort_add_platform_device(struct acpi_iort_node *node, return ret; } -static bool __init iort_enable_acs(struct acpi_iort_node *iort_node) +#ifdef CONFIG_PCI +static void __init iort_enable_acs(struct acpi_iort_node *iort_node) { + static bool acs_enabled __initdata = false; + + if (acs_enabled) + return; + if (iort_node->type == ACPI_IORT_NODE_PCI_ROOT_COMPLEX) { struct acpi_iort_node *parent; struct acpi_iort_id_mapping *map; @@ -1458,13 +1464,15 @@ static bool __init iort_enable_acs(struct acpi_iort_node *iort_node) if ((parent->type == ACPI_IORT_NODE_SMMU) || (parent->type == ACPI_IORT_NODE_SMMU_V3)) { pci_request_acs(); - return true; + acs_enabled = true; + return; } } } - - return false; } +#else +static inline void iort_enable_acs(struct acpi_iort_node *iort_node) { } +#endif static void __init iort_init_platform_devices(void) { @@ -1472,7 +1480,6 @@ static void __init iort_init_platform_devices(void) struct acpi_table_iort *iort; struct fwnode_handle *fwnode; int i, ret; - bool acs_enabled = false; const struct iort_dev_config *ops; /* @@ -1493,8 +1500,7 @@ static void __init iort_init_platform_devices(void) return; } - if (!acs_enabled) - acs_enabled = iort_enable_acs(iort_node); + iort_enable_acs(iort_node); ops = iort_get_dev_cfg(iort_node); if (ops) {