Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp2855223pxk; Tue, 15 Sep 2020 04:16:47 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwMI5NgNEF6wMHy4WsYbYe7OtrSA4v0puo/QdJurdlUNUHvFRgSFbdDF5A364yldKuAwB4h X-Received: by 2002:a17:907:2079:: with SMTP id qp25mr13171987ejb.186.1600168607584; Tue, 15 Sep 2020 04:16:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1600168607; cv=none; d=google.com; s=arc-20160816; b=alcpd5w34S+0I5+SKV6iMNPWCYSwGTPHTfOc2Pq4rDrnGmBV2uaFutWbS/K1RyMtJC ATbwpwgz4v+VYT+ZohcFMhloWHhs0aY/F2r8RkgFyhj5v4tMnFCs5U753us/hm3kOtnG S7fynVsFXUuSeETaXB5b726vHFTIjFFUHYzND4wjlA0cU5yZdD89vMT5kE6Vq3/2NZ3L /b7EzVgOGeKtNd8uiNg4fWIE9iS4ntE4KgyUtuM2WHxnDLmAkBg7DRdGwKt0nq1/FimL VHsF2d0AyVTFarDP2CNhkTMPvCklom6wZj44FZj5U8YHSfeLrsU5Me/uGHeDVbjImbHx cZ8A== 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:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=xY7x55ckPx2xhvNjyeqbynyrmyhcLRhVJMC4lFiC1Oo=; b=015cSGFLyRY7CysKWqlCSS5LkXyOvcO6dskQEuGLXElMsN8k6Li7a56H7ABT4SxfPB 5ML/q3+OK7NgqL23znKwIYR4qLZe2poU/4wng6sa4Zb/AmKCv2IA0qLPYU9SLT04RmQK Hdft4hy/LJTeDnxgzaunS9Ia/wc5R/DjO9kj/awiwBTBmdEEE0lyyk2S/9RDBRSTIUqm +T/d3x/9bxcjpAe0oMyTUv6zL/fbhfkwmhmhKcEUqbBVPPz1bhoz5bcx4IOMz3lm6t94 TMAwVp7fYqmPUJmabCCL92uoLNsa14oZNS8MydcxQep2xEBMGjowtCEK2FTpCIGJnYtj JczA== 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 p23si7102264eju.83.2020.09.15.04.16.24; Tue, 15 Sep 2020 04:16:47 -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 S1726159AbgIOLO4 (ORCPT + 99 others); Tue, 15 Sep 2020 07:14:56 -0400 Received: from foss.arm.com ([217.140.110.172]:33082 "EHLO foss.arm.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726145AbgIOLLK (ORCPT ); Tue, 15 Sep 2020 07:11:10 -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 DD00D101E; Tue, 15 Sep 2020 04:10:35 -0700 (PDT) Received: from [192.168.1.205] (unknown [10.37.8.121]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id 3847B3F718; Tue, 15 Sep 2020 04:10:31 -0700 (PDT) Subject: Re: [PATCH v1] soc: fsl: rcpm: Add ACPI support To: kuldip dwivedi , Li Yang , linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Cc: Ran Wang , Biwen Li , Varun Sethi , Arokia Samy , Samer El-Haj-Mahmoud , Paul Yang , tanveer References: <20200915110647.846-1-kuldip.dwivedi@puresoftware.com> From: Ard Biesheuvel Message-ID: <4e008f0a-69da-d5c2-4dfc-ef8695e17f47@arm.com> Date: Tue, 15 Sep 2020 14:10:29 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.7.0 MIME-Version: 1.0 In-Reply-To: <20200915110647.846-1-kuldip.dwivedi@puresoftware.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 9/15/20 1:06 PM, kuldip dwivedi wrote: > Add ACPI support in fsl RCPM driver. This is required > to support ACPI S3 state. S3 is the ACPI sleep state > that is known as "sleep" or "suspend to RAM". > It essentially turns off most power of the system but > keeps memory powered. > > Signed-off-by: tanveer > Signed-off-by: kuldip dwivedi Why does the OS need to program this device? Can't this be done by firmware? > --- > > Notes: > 1. Add ACPI match table > 2. NXP team members are added for confirming HID changes > 3. There is only one node in ACPI so no need to check for > current device explicitly > 4. These changes are tested on LX2160A and LS1046A platforms > > drivers/soc/fsl/rcpm.c | 22 +++++++++++++++++++--- > 1 file changed, 19 insertions(+), 3 deletions(-) > > diff --git a/drivers/soc/fsl/rcpm.c b/drivers/soc/fsl/rcpm.c > index a093dbe6d2cb..e75a436fb159 100644 > --- a/drivers/soc/fsl/rcpm.c > +++ b/drivers/soc/fsl/rcpm.c > @@ -2,10 +2,12 @@ > // > // rcpm.c - Freescale QorIQ RCPM driver > // > -// Copyright 2019 NXP > +// Copyright 2019-2020 NXP > +// Copyright 2020 Puresoftware Ltd. > // > // Author: Ran Wang > > +#include > #include > #include > #include > @@ -57,8 +59,13 @@ static int rcpm_pm_prepare(struct device *dev) > rcpm->wakeup_cells + 1); > > /* Wakeup source should refer to current rcpm device */ > - if (ret || (np->phandle != value[0])) > - continue; > + if (is_acpi_node(dev->fwnode)) { > + if (ret) > + continue; > + } else { > + if (ret || (np->phandle != value[0])) > + continue; > + } > > /* Property "#fsl,rcpm-wakeup-cells" of rcpm node defines the > * number of IPPDEXPCR register cells, and "fsl,rcpm-wakeup" > @@ -139,10 +146,19 @@ static const struct of_device_id rcpm_of_match[] = { > }; > MODULE_DEVICE_TABLE(of, rcpm_of_match); > > +#ifdef CONFIG_ACPI > +static const struct acpi_device_id rcpm_acpi_match[] = { > + { "NXP0015", }, > + { } > +}; > +MODULE_DEVICE_TABLE(acpi, rcpm_acpi_match); > +#endif > + > static struct platform_driver rcpm_driver = { > .driver = { > .name = "rcpm", > .of_match_table = rcpm_of_match, > + .acpi_match_table = ACPI_PTR(rcpm_acpi_match), > .pm = &rcpm_pm_ops, > }, > .probe = rcpm_probe, >