Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp55663pxf; Wed, 7 Apr 2021 19:59:54 -0700 (PDT) X-Google-Smtp-Source: ABdhPJymoQKLSAn2n5lTAtECL1vHzNg45KOMCUImYSvt0Os3G+e3WDeqHjZPh6sDNw6/77eqyKCe X-Received: by 2002:a65:40c7:: with SMTP id u7mr6082559pgp.29.1617850794551; Wed, 07 Apr 2021 19:59:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1617850794; cv=none; d=google.com; s=arc-20160816; b=D1BANxf3lplxJ7YYXcZr8fwkPmzWtWP390ehZI7lReJOXZ2ncPdeA/FJwB6hrLnaBs qbwRHYHQcytVbMHD6DyqMWxsSmReiroYY18XmuU06vya73KdVNN0dEJLdgl5rm8FcN6B SJoH+GCmVc8riv7RtdgoB56BHPCrkumvqbLIDVcbtHC4cOvBD4OfV9layC3U9BJ2ByKz aTJhSZch+I3VswSSRah4eTSvm5ZUExY8G7M5ZSKetI2a4DtIGjkf6XqFteUR9TKp3Fri zvbwOWxHtuEtIxVjcEp11G+JuUHnpk0xzcjTgqfycwWZfzGLBfglVRO2Kyo13xxtX3/w li1Q== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from; bh=7PqMWauSqCjposhLhYk/tF6ooRiT2AgnbwQ0XRv6RPY=; b=kIERFiZdGo+JYU0XfeKbaD5JvRUsUj+TDcweiZrSXPAFM6e9B63SwqaQYxwDGGLCfO DewQ+xkWIsTVUPicS+on1mud/U9Pw7WDNyucSq0RRXAATcOAGGwrd4EhDp3rJ0H22JLn hoxRuY+Mg1+vZsMjTCvDRAzsZKFlmkz12bZG/SLuNWi8cxQuPu/eNPIBbWVatTym4duO McuUv8TPUmDaILguRBnQYTXd8QVXRE5bSw2AwJoSXVeZ0BBCJy1Qx7CXPBwpylhnnA7/ 49TPHdaV+GvbI9zpH6Z+Z/VPe7B1YefQ+gAw3FU6V7UTshhexZf59wwrvCY4GEKWJQdR xpCw== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id ci6si8078918pjb.17.2021.04.07.19.59.15; Wed, 07 Apr 2021 19:59:54 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=nxp.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S229601AbhDHC53 (ORCPT + 99 others); Wed, 7 Apr 2021 22:57:29 -0400 Received: from inva021.nxp.com ([92.121.34.21]:37028 "EHLO inva021.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229510AbhDHC53 (ORCPT ); Wed, 7 Apr 2021 22:57:29 -0400 Received: from inva021.nxp.com (localhost [127.0.0.1]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id E1C172021D4; Thu, 8 Apr 2021 04:57:17 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva021.eu-rdc02.nxp.com (Postfix) with ESMTP id E65D5200BAB; Thu, 8 Apr 2021 04:57:14 +0200 (CEST) Received: from localhost.localdomain (mega.ap.freescale.net [10.192.208.232]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id D77434032B; Thu, 8 Apr 2021 04:57:10 +0200 (CEST) From: Ran Wang To: Li Yang , Christophe Leroy Cc: linuxppc-dev@lists.ozlabs.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Peng Ma , Ran Wang Subject: [PATCH v7] soc: fsl: enable acpi support in RCPM driver Date: Thu, 8 Apr 2021 11:03:53 +0800 Message-Id: <20210408030353.37193-1-ran.wang_1@nxp.com> X-Mailer: git-send-email 2.17.1 X-Virus-Scanned: ClamAV using ClamSMTP Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Peng Ma This patch enables ACPI support in RCPM driver. Signed-off-by: Peng Ma Signed-off-by: Ran Wang --- Change in v7: - Update comment for checking RCPM node which refferred to Change in v6: - Remove copyright udpate to rebase on latest mainline Change in v5: - Fix panic when dev->of_node is null Change in v4: - Make commit subject more accurate - Remove unrelated new blank line Change in v3: - Add #ifdef CONFIG_ACPI for acpi_device_id - Rename rcpm_acpi_imx_ids to rcpm_acpi_ids Change in v2: - Update acpi_device_id to fix conflict with other driver drivers/soc/fsl/rcpm.c | 24 ++++++++++++++++++++++-- 1 file changed, 22 insertions(+), 2 deletions(-) diff --git a/drivers/soc/fsl/rcpm.c b/drivers/soc/fsl/rcpm.c index 4ace28cab314..90d3f4060b0c 100644 --- a/drivers/soc/fsl/rcpm.c +++ b/drivers/soc/fsl/rcpm.c @@ -13,6 +13,7 @@ #include #include #include +#include #define RCPM_WAKEUP_CELL_MAX_SIZE 7 @@ -78,10 +79,20 @@ static int rcpm_pm_prepare(struct device *dev) "fsl,rcpm-wakeup", value, rcpm->wakeup_cells + 1); - /* Wakeup source should refer to current rcpm device */ - if (ret || (np->phandle != value[0])) + if (ret) continue; + /* + * For DT mode, would handle devices with "fsl,rcpm-wakeup" + * pointing to the current RCPM node. + * + * For ACPI mode, currently we assume there is only one + * RCPM controller existing. + */ + if (is_of_node(dev->fwnode)) + if (np->phandle != value[0]) + continue; + /* Property "#fsl,rcpm-wakeup-cells" of rcpm node defines the * number of IPPDEXPCR register cells, and "fsl,rcpm-wakeup" * of wakeup source IP contains an integer array: