Received: by 2002:a25:1985:0:0:0:0:0 with SMTP id 127csp669639ybz; Wed, 22 Apr 2020 05:55:11 -0700 (PDT) X-Google-Smtp-Source: APiQypJlnn7ByG0mDq2hWvWrIEd5doigmGcW1HUkTjvnRhPljNIMk95aaASOjX3H534XXVD55xTb X-Received: by 2002:a17:906:3492:: with SMTP id g18mr24631899ejb.112.1587560111034; Wed, 22 Apr 2020 05:55:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1587560111; cv=none; d=google.com; s=arc-20160816; b=EwSGCvtopHxiPJOiBaHeo+gmV0U91BRq8u2x+zMTS2Epi0tZrlYfS4TUdHBTxUr8np iUG0r/hzrDVc3yFzWiarz2c4izqFAKGsduR/OYH8uIWrYOf99NiRVEeUwy6luwxiQ+1E rCHQuTvRjkfQDVVP0JJOsJfXSc3XMgFzWKlY7r4HiOeKFFHTeKxlKWXte3b7UFX2seEh tsVieSS5D+EK1Zt51B0Op5e3+uB0w0uGRli0MYE6NUTo6L8KBAFDH8ffzIMJ+/ekTgqy 2Cs4JHPFDZUcDMRavLU3SRA/H8Zd33dk/8nbOy54pJP6ITLeV6kZ1elszmYLKU6MsGnO swyA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from; bh=ipoEr8HUhnvCjOTPtKQsUR/0jB5+IS50RYjhj3j/RlA=; b=BHKMLc9JGp4FI0VCqBp2Lt9urGyXTpKzURXGNpqg/Tz9BQ3Q4wv3ILMazvTGIp27kG 7gSHOISdJy7YJ2hyf1qsasp7RgE791s1D+sPq4+crF7CMcxAyFVJ+vMDkK3yHg8vCWcD darGsgHT7pzYZnf85eKnQqixPW7rLodfuvmmvzIhUGWsv3ebXVNB6p3YpLZlcG5Im37U NPASa6f9wFjkFeKqyzDduBPF50liOleiIP/XC0T1BmOzB//4qV76ThOns79w2TZqkLbk OFWpzh/FdjkOpIDickvrAiIasRKoWen/skuMWwv3ORRHZUikqjAB/UJSvnakMMUdVBf2 V99Q== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id a23si3263483ejv.375.2020.04.22.05.54.48; Wed, 22 Apr 2020 05:55:11 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726445AbgDVM2h (ORCPT + 99 others); Wed, 22 Apr 2020 08:28:37 -0400 Received: from foss.arm.com ([217.140.110.172]:49304 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725968AbgDVM2g (ORCPT ); Wed, 22 Apr 2020 08:28:36 -0400 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id E2F6431B; Wed, 22 Apr 2020 05:28:35 -0700 (PDT) Received: from usa.arm.com (e103737-lin.cambridge.arm.com [10.1.197.49]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPA id 3FA3D3F6CF; Wed, 22 Apr 2020 05:28:35 -0700 (PDT) From: Sudeep Holla To: linux-arm-kernel@lists.infradead.org, James Morse Cc: Sudeep Holla , linux-kernel@vger.kernel.org Subject: [PATCH] firmware: arm_sdei: Drop check for /firmware/ node and always register driver Date: Wed, 22 Apr 2020 13:28:23 +0100 Message-Id: <20200422122823.1390-1-sudeep.holla@arm.com> X-Mailer: git-send-email 2.17.1 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org As with most of the drivers, let us register this driver unconditionally by dropping the checks for presence of firmware nodes(DT) or entries(ACPI). Further, as mentioned in the commit acafce48b07b ("firmware: arm_sdei: Fix DT platform device creation"), the core takes care of creation of platform device when the appropriate device node is found and probe is called accordingly. Let us check only for the presence of ACPI firmware entry before creating the platform device and flag warning if we fail. Cc: James Morse Signed-off-by: Sudeep Holla --- drivers/firmware/arm_sdei.c | 37 ++++++++++++------------------------- 1 file changed, 12 insertions(+), 25 deletions(-) diff --git a/drivers/firmware/arm_sdei.c b/drivers/firmware/arm_sdei.c index 334c8be0c11f..5afd7409e6fa 100644 --- a/drivers/firmware/arm_sdei.c +++ b/drivers/firmware/arm_sdei.c @@ -1079,26 +1079,9 @@ static struct platform_driver sdei_driver = { .probe = sdei_probe, }; -static bool __init sdei_present_dt(void) -{ - struct device_node *np, *fw_np; - - fw_np = of_find_node_by_name(NULL, "firmware"); - if (!fw_np) - return false; - - np = of_find_matching_node(fw_np, sdei_of_match); - if (!np) - return false; - of_node_put(np); - - return true; -} - static bool __init sdei_present_acpi(void) { acpi_status status; - struct platform_device *pdev; struct acpi_table_header *sdei_table_header; if (acpi_disabled) @@ -1113,20 +1096,24 @@ static bool __init sdei_present_acpi(void) if (ACPI_FAILURE(status)) return false; - pdev = platform_device_register_simple(sdei_driver.driver.name, 0, NULL, - 0); - if (IS_ERR(pdev)) - return false; - return true; } static int __init sdei_init(void) { - if (sdei_present_dt() || sdei_present_acpi()) - platform_driver_register(&sdei_driver); + int ret = platform_driver_register(&sdei_driver); - return 0; + if (!ret && sdei_present_acpi()) { + struct platform_device *pdev; + + pdev = platform_device_register_simple(sdei_driver.driver.name, + 0, NULL, 0); + if (IS_ERR(pdev)) + pr_info("Failed to register ACPI:SDEI platform device %ld\n", + PTR_ERR(pdev)); + } + + return ret; } /* -- 2.17.1