From patchwork Sat Dec 28 01:14:37 2024 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: "Peng Fan (OSS)" X-Patchwork-Id: 13922196 Received: from EUR05-DB8-obe.outbound.protection.outlook.com (mail-db8eur05on2065.outbound.protection.outlook.com [40.107.20.65]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by smtp.subspace.kernel.org (Postfix) with ESMTPS id 12FD41805E; Sat, 28 Dec 2024 01:15:24 +0000 (UTC) Authentication-Results: smtp.subspace.kernel.org; arc=fail smtp.client-ip=40.107.20.65 ARC-Seal: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735348526; cv=fail; b=c7OzZU3kEXwDIrc3OfD8r7JnTicgYp5GrJ9thQ5wIUBc6jI6teeyRug6RsqxzaHywo2ciWm8ba1hyyp6/VhTE1FVjoObU48YTe5wzFYr1LKomClA0dEcbrq/9lVe4Pt5Rdyd0MgTpS/p+Nki2sdOMJ3GzTVJ6ad5Tpw2OO4x/wI= ARC-Message-Signature: i=2; a=rsa-sha256; d=subspace.kernel.org; s=arc-20240116; t=1735348526; c=relaxed/simple; bh=rr4+NY79vHDTao21SuIwtmUb1wnSE8ucvghNGRhzc8o=; h=From:Date:Subject:Content-Type:Message-Id:References:In-Reply-To: To:Cc:MIME-Version; b=kRsMxra/1QUDI6nb1C6Sm9ZaxWIpM8moXldQL8LyDbXJkNkUdddP+9g48zBYC1uPOKzYz2SLEiYsAPtvpHDTc1LO+GJXCpKWMF9WcGbmceznXotFMwqGvvoo9dyb+8oCV9B06hXm7a5W3XTHrHdij3T03Ss8GdSL4PIYnue/cgA= ARC-Authentication-Results: i=2; smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com; spf=pass smtp.mailfrom=oss.nxp.com; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b=G//0vpng; arc=fail smtp.client-ip=40.107.20.65 Authentication-Results: smtp.subspace.kernel.org; dmarc=pass (p=none dis=none) header.from=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; spf=pass smtp.mailfrom=oss.nxp.com Authentication-Results: smtp.subspace.kernel.org; dkim=pass (2048-bit key) header.d=NXP1.onmicrosoft.com header.i=@NXP1.onmicrosoft.com header.b="G//0vpng" ARC-Seal: i=1; a=rsa-sha256; s=arcselector10001; d=microsoft.com; cv=none; b=gVpIBXKGDph7VANcYk4QJZCn4EzewIx7bvYcluc4SZR5svnbJ0byeNPfVc8L9XkqXmlMcYWuzf0/8wARB3oW2cZHpkwL3MYL6g3TsGloe+qFcV1PHpIG3CLqV3n5CRd5xIif53z3VyIR7DcnssS23ma8FwDifqIJVaa8xlV3JUXi0vk0p4ea7GrcXLoV+362g6FJAcjsfezHTEmwNZ2s4emGJ7M4sVEzGffZ+TB4yizfbAKPRtyLBRVC2jt++4yER9QeXh16X0x+L/it5fUF9Du8oofLo6BpzUBNezkEnw2vBxmzkP48/juiOvrr9mQ9LwshaRweIv4Z/CUon/A7HQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=microsoft.com; s=arcselector10001; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-AntiSpam-MessageData-ChunkCount:X-MS-Exchange-AntiSpam-MessageData-0:X-MS-Exchange-AntiSpam-MessageData-1; bh=LXYTp5BoecHg34e+obK9OingrwQWYhGlKmIRTdHjAGw=; b=A81C6fyc7AIg6W2VB5Vw2VbkwxT/TP+PuzuiH18mOJEeR4aHmcMpv9E18WxYob1Yfv+n3UUO+CUqoCLR2xtEVhAnX74Pqkbl7943MofP2Nsavh2wPcuMA80frFnCMhqEdeudC4P1u3ivSNyreD3uz3Xqvh/Dz3BVZxPfK+6+3TYjBS36UygZRwRo261CwcyJiChWgSaxLcKbUZngsRoEJaBHJbeJgc23U9QGEKMbZZtep7b/MR0xRfdPa5ttvbjt+C5kIa+adSXMcRbkAdsqQUv4Ph0/AKfXAttDK/DpWwfV5hbbAaT6Tmkv7DupfUgzr2K46WbhoYWp9blklWLkwg== ARC-Authentication-Results: i=1; mx.microsoft.com 1; spf=pass smtp.mailfrom=oss.nxp.com; dmarc=pass action=none header.from=oss.nxp.com; dkim=pass header.d=oss.nxp.com; arc=none DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=NXP1.onmicrosoft.com; s=selector1-NXP1-onmicrosoft-com; h=From:Date:Subject:Message-ID:Content-Type:MIME-Version:X-MS-Exchange-SenderADCheck; bh=LXYTp5BoecHg34e+obK9OingrwQWYhGlKmIRTdHjAGw=; b=G//0vpngaurqRXrrBO8WtE6q50Gf80d3sz9sYm49MRZdJnU6xl8jFew+90FA3J/eKinN9+jsoZZlXXeHOY8aSG7RVYUdsWt4khMMnFk3aPi1uuoZjOHP6aK2xk6/NYW+x/MK/My23b9gDy2DEhys8LJHWofjNotD+kzjXqJp1ffMUi6htbEgpYFbTHVDOwuKscyJaj+EYRuMuJkOmV3cGbgKjsaFU/7VigC9cwdFgSfu0jb3PIOblh/01023p/CMQzr5afYJ16oOd5rTku+GGbvzJWBY7h/royKHBJBwcH6s3EhI947lqokEQaJV/v8iqrWlsmQu4mdrTRBECS4MTg== Authentication-Results: dkim=none (message not signed) header.d=none;dmarc=none action=none header.from=oss.nxp.com; Received: from PAXPR04MB8459.eurprd04.prod.outlook.com (2603:10a6:102:1da::15) by AM0PR04MB7140.eurprd04.prod.outlook.com (2603:10a6:208:192::20) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_256_GCM_SHA384) id 15.20.8293.15; Sat, 28 Dec 2024 01:15:18 +0000 Received: from PAXPR04MB8459.eurprd04.prod.outlook.com ([fe80::165a:30a2:5835:9630]) by PAXPR04MB8459.eurprd04.prod.outlook.com ([fe80::165a:30a2:5835:9630%5]) with mapi id 15.20.8293.000; Sat, 28 Dec 2024 01:15:18 +0000 From: "Peng Fan (OSS)" Date: Sat, 28 Dec 2024 09:14:37 +0800 Subject: [PATCH 01/12] PM: sleep: wakeirq: Introduce device-managed variant of dev_pm_set_wake_irq Message-Id: <20241228-wake_irq-v1-1-09cfca77cd47@nxp.com> References: <20241228-wake_irq-v1-0-09cfca77cd47@nxp.com> In-Reply-To: <20241228-wake_irq-v1-0-09cfca77cd47@nxp.com> To: "Rafael J. Wysocki" , Len Brown , Pavel Machek , Greg Kroah-Hartman , Dmitry Torokhov , Alexandre Belloni , Maxime Coquelin , Alexandre Torgue , Linus Walleij , Conor Dooley , Daire McNamara Cc: linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, linux-input@vger.kernel.org, linux-rtc@vger.kernel.org, linux-stm32@st-md-mailman.stormreply.com, linux-arm-kernel@lists.infradead.org, linux-arm-msm@vger.kernel.org, linux-riscv@lists.infradead.org, Peng Fan X-Mailer: b4 0.14.2 X-Developer-Signature: v=1; a=ed25519-sha256; t=1735348488; l=2367; i=peng.fan@nxp.com; s=20230812; h=from:subject:message-id; bh=1uWzLxz0ETkHUyA0IoSi0XaXoYut2vJxQmLJwOorGBk=; b=qSMQnYyGM9tDfzHYkMUGmXNyaUzaGa3+ti6BAH9c9FzUsXHbRHcqUk+iAcM38J1RjL8RaqoVX 5f/l7EkwTGjALGnbsV+r7vQCvfEhAsFjc2BLLoZCeIs1xuYV04uru6q X-Developer-Key: i=peng.fan@nxp.com; a=ed25519; pk=I4sJg7atIT1g63H7bb5lDRGR2gJW14RKDD0wFL8TT1g= X-ClientProxiedBy: SG2PR02CA0099.apcprd02.prod.outlook.com (2603:1096:4:92::15) To PAXPR04MB8459.eurprd04.prod.outlook.com (2603:10a6:102:1da::15) Precedence: bulk X-Mailing-List: linux-arm-msm@vger.kernel.org List-Id: List-Subscribe: List-Unsubscribe: MIME-Version: 1.0 X-MS-Exchange-MessageSentRepresentingType: 1 X-MS-PublicTrafficType: Email X-MS-TrafficTypeDiagnostic: PAXPR04MB8459:EE_|AM0PR04MB7140:EE_ X-MS-Office365-Filtering-Correlation-Id: 78ae5531-0393-418c-85f7-08dd26dd1779 X-MS-Exchange-SharedMailbox-RoutingAgent-Processed: True X-MS-Exchange-SenderADCheck: 1 X-MS-Exchange-AntiSpam-Relay: 0 X-Microsoft-Antispam: BCL:0;ARA:13230040|1800799024|52116014|376014|7416014|366016|921020|38350700014; X-Microsoft-Antispam-Message-Info: =?utf-8?q?iw2H2/5LxEvQTdhgFpBNQvR1kkaHZ2S?= =?utf-8?q?UoXgSOmuB02HBKxIwq2aNjfmPbDtgHDVHFVzd/+o8YhDT2uQtEEIClRPenb1to92+?= =?utf-8?q?SsdujO2MR6u1OpAwPlFQSR0EEH7xsas2ZZujBY+ehYjrFAUGHIVirM9fwSp96pk9B?= =?utf-8?q?z/RydD/4D6WAcA5/jVRD71o49tp+AS4wsZkT4r2m6XSx/14lInlzC8HsSruQl1VJd?= =?utf-8?q?+Fb/sqp1dSem02qXVgE+xfRL0q8gbDa08kjscNWxhtk1H1vShZh7vKUTOorDXjuEN?= =?utf-8?q?/xzeQ0NrfrnfW2gXVx1ZHU3eKP0Pk9LHTPgOqZoykGpcShW4IsRbvMEp3pSwQB/Xb?= =?utf-8?q?MExGcUhZkxv7me4t5Q1n0DRwnUJ0b/ctJjpMcHp4BJoP60l9++Dr1A31tbws0mR2p?= =?utf-8?q?CqlnrZgVcspAZXGqBGGAnntashgrah0cYAuI45p+Nzjv3knwUKMc3Uc5anzZ7J7uK?= =?utf-8?q?beOHspl0kSC4E8Yc8WO+Cxhp09ngV5pqkvQ5GQDsIq+QGCYa50qJJcfQODwcCTQQs?= =?utf-8?q?g1sMzy7NQhPOgST7nooFlXDHy+On4UUaEagG0otm/n+PsicIfWKkVIO52mvxBThzS?= =?utf-8?q?1U6YthGsst2AyyHiC59ohRpy1BkY7bH+poEDQ8OEbgVR7g3dB1VCowbmPNqCgJ44a?= =?utf-8?q?TmIhoN83jSDt3+xd1sp0qUo+jMWTh59BRFnYfrxcAVzw4L2g9l2HQO0FuZxU10ffM?= =?utf-8?q?/H6NTwfi4cW3xaCFXMfRWs1Tw7hegqYC/Ugo22l1Freu0rLzJgBXHeiclYJUMccRp?= =?utf-8?q?gCoqW7EndkHHmgrnA/lQFTAACAt3VJkGnfSZ6CV7KpXrZ0dWnTmeSR/BjSZ1AQRyp?= =?utf-8?q?plm7n9poI0jdbMQmaH9goQU7AB5lUwjE1jCrZ/e12p4Ct27q1A1JK+Q1py8GBwGmr?= =?utf-8?q?Z0rHbYN904bF9kKkfdABD/ZKv7G9LXSYgx311n5iYcnZikXWXO6XT05nZZIU1E2Ux?= =?utf-8?q?f4OSNL8/oIK+1j7CiBY/dyMIeD2euJQSQWIBB4+ry+VFwfNA5KACR2u1YepQhs3Gb?= =?utf-8?q?Xt093aVARpVgTCaxtS3jQscoKWuR5O8/2a7YpKUDU15qZRw5jJaHV43FFdAjxniGQ?= =?utf-8?q?JqblFRAS2J3CF2ylrO3FG92KHKUt3L3I1mbv6Ye24IgsvT+RzjLJ2ljQQ7mFGJKtw?= =?utf-8?q?vqwebF5gpoh8q5xDZupizJ8xgCMXfSBU/T1SYcGfT8Um7dgQQ+Qm1XGTwyOrMzxq7?= =?utf-8?q?aggm2pKB1KpNYtdfSVEIROfluEQ6xNAOLmAGcRrkvYE4ozxCkmMaM0Mmnx6naWJAl?= =?utf-8?q?6uNrlz6j9saURkopKRH31mPabxitpc7u3WdAEIsN5DiYKWIBDDHityl0bTqxl+hkM?= =?utf-8?q?Lchq5GVHyT+bsVs8GOIJZfY4oUBq+K/mFeDj2FkkZ6TGYlvrVo0bF/0UQGYetQF8A?= =?utf-8?q?W0R5Lh/9SzdyzsS/Pef+ZaGmQ7yDho9bw=3D=3D?= X-Forefront-Antispam-Report: CIP:255.255.255.255;CTRY:;LANG:en;SCL:1;SRV:;IPV:NLI;SFV:NSPM;H:PAXPR04MB8459.eurprd04.prod.outlook.com;PTR:;CAT:NONE;SFS:(13230040)(1800799024)(52116014)(376014)(7416014)(366016)(921020)(38350700014);DIR:OUT;SFP:1101; X-MS-Exchange-AntiSpam-MessageData-ChunkCount: 1 X-MS-Exchange-AntiSpam-MessageData-0: =?utf-8?q?JZd6IvOf+r9+DAoQAvqZeAyFAj6i?= =?utf-8?q?y0QIchEPZYUSLSiB4ZyMjT+r6qz40El4xQYuqJ173PEydpiWLFBKaB7F25vRhLdiD?= =?utf-8?q?xjNRSPZmdj2359eWnT2Wya/bGN1Esne9hmHH4MVYHWMXylLD+syYA+Jl87g6780oY?= =?utf-8?q?vSrxUUSWYJwz39dChjeApcXuy9CLkW2ZyQz4w+CTGebmZEQZNNt+vkW/7fb01znls?= =?utf-8?q?SMoeJMeTuvSrZ4YGQCUXvuyY4Ztf/u/MTDbD2XFmXL+HUlE6gvBD5Rp4vyPmeEEoo?= =?utf-8?q?fVvLTrrVtYUgfpfLI0cwBKqgUj95thARmVPWbO2QjcyryR/fc7AS/KhFVRITXSMtF?= =?utf-8?q?mnVCQx8v0qlfFRfeaqPdNlYSKy2cm++tyr/lpv/PoW9o7xNNSeqnHd540OcMx1Cy9?= =?utf-8?q?i3JNoAsJ50rFq/EJIwVdDkMgDMHKqXctdZmSHpcc2cBpmkgo/sJCNF7X46k20Vnud?= =?utf-8?q?vk0hNY92xbYp/V/KJpCYg+DQ+SHALeBVsgq6woooaeAeu3mFZPEkM/G5F/hjCuOaB?= =?utf-8?q?qRkuDw6nr4kMbpRbQBRz2i6QU/l6GZmCox9s+757fhI+zgdjLwT2ECMYXXOf278Tv?= =?utf-8?q?t5rLuFK6pHbhZUA8MKJ0YNTX1gtlFKbpX/6u6oWLK1ZnI8oK1bvNzwC6wT5BL/+EA?= =?utf-8?q?tPfTyNXMnAsEgoeH0CXalHOlkfKDFUO7DiFJaiCgQAKPchFNyuImutJDvnPVekKIN?= =?utf-8?q?BAIdLbXo3CVyF25BLt9snx3IFFOQmnB9qhx++239e2s18qghIXtuFSFDmodxIUZ6v?= =?utf-8?q?ZeZOHb3AV7q30dUuyTrnJmOz5evtvQvfNubUwvjUjaOFDqVpOvcvd5J8fqBDnCXQM?= =?utf-8?q?/p7w0pHOJAgevJFErh4RFHckFMh11eavCJXudvTyQjsycFdKIZAo2u/T6ylm5Vgmi?= =?utf-8?q?NWKzk6VREc5QCyAo0SSBNFGfVkOPFO/3L31DaUa3I1mnOa8eBduTYdIvViF9VVbDx?= =?utf-8?q?7ypbenpaoIdjilpzf7o75no3LkKuiyCQecaolLHineed9NgtiewOSN84YcEPMkKaJ?= =?utf-8?q?Y4UX1saGIQ5UhRyMo8Jy0NSigDL5FsM7pMql0ec01Hhd3zY7FadFv4rLy4Yf3G9AC?= =?utf-8?q?+AK9BlXsp6woao6mPPhGTSMhBvLAQ4pPj8IsKDIWIFuTGo09Q/Uuna5HUM1wQDgh0?= =?utf-8?q?5jZEsxQQIJ7SM+dZ30gF4lfjBqX/SFyOIiGZPugeDR7gdj+fG6kvl7zni/UPSDbUO?= =?utf-8?q?knqgc3BtwNd4uTkuQ/scS7wzNml7MLZH35gqTNL+ybxXx3/MUVzS+35b7uQ0vCdG6?= =?utf-8?q?7m8lTqWc3q7+O/+Yev9inFgHjikDerPpDoZRFdfdP/wSBI4jZha09hmvUH75fAMTF?= =?utf-8?q?TVogX130C40OsJr5vKKDnBnHuld1Vh4bBRX5Pb6CSlbDe0vQLvUzfYwyIJePwLuFJ?= =?utf-8?q?ZrWXLIzycotbIRivk8mS5jSHsMqdm6bsl5pO97AyLK/HIQWG/swIDB+HkX8fMuRsM?= =?utf-8?q?ov/Cy7RLDpLCFuCmr6Wk5UvI3BSSosg1NjE8mmkZHcZpxskrJ6DQ0WJEJX5VcbcyP?= =?utf-8?q?jr/Ag/0jS+Tw?= X-OriginatorOrg: oss.nxp.com X-MS-Exchange-CrossTenant-Network-Message-Id: 78ae5531-0393-418c-85f7-08dd26dd1779 X-MS-Exchange-CrossTenant-AuthSource: PAXPR04MB8459.eurprd04.prod.outlook.com X-MS-Exchange-CrossTenant-AuthAs: Internal X-MS-Exchange-CrossTenant-OriginalArrivalTime: 28 Dec 2024 01:15:18.3158 (UTC) X-MS-Exchange-CrossTenant-FromEntityHeader: Hosted X-MS-Exchange-CrossTenant-Id: 686ea1d3-bc2b-4c6f-a92c-d99c5c301635 X-MS-Exchange-CrossTenant-MailboxType: HOSTED X-MS-Exchange-CrossTenant-UserPrincipalName: uZpt2V3s6fjoSeNpK+N8ZCTOW9FTqpcYRuuV2IeIZSIS04XS3WUHC1McTJ1X3lhfLJFZTG8YJNo6dPCNO5MxPA== X-MS-Exchange-Transport-CrossTenantHeadersStamped: AM0PR04MB7140 From: Peng Fan Add device-managed variant of dev_pm_set_wake_irq which automatically clear the wake irq on device destruction to simplify error handling and resource management in drivers. Signed-off-by: Peng Fan --- drivers/base/power/wakeirq.c | 25 +++++++++++++++++++++++++ include/linux/pm_wakeirq.h | 6 ++++++ 2 files changed, 31 insertions(+) diff --git a/drivers/base/power/wakeirq.c b/drivers/base/power/wakeirq.c index 5a5a9e978e85f3fc9d89cb7d43527dc1dd42a9b1..cdc445189f68479c54f85e84be09ae4f488df1b5 100644 --- a/drivers/base/power/wakeirq.c +++ b/drivers/base/power/wakeirq.c @@ -103,6 +103,31 @@ void dev_pm_clear_wake_irq(struct device *dev) } EXPORT_SYMBOL_GPL(dev_pm_clear_wake_irq); +static void devm_pm_clear_wake_irq(void *dev) +{ + dev_pm_clear_wake_irq(dev); +} + +/** + * devm_pm_set_wake_irq - device-managed variant of dev_pm_set_wake_irq + * @dev: Device entry + * @irq: Device IO interrupt + * + * + * Attach a device IO interrupt as a wake IRQ, same with dev_pm_set_wake_irq, + * but the device will be auto clear wake capability on driver detach. + */ +int devm_pm_set_wake_irq(struct device *dev, int irq) +{ + int ret; + + ret = dev_pm_set_wake_irq(dev, irq); + if (ret) + return ret; + + return devm_add_action_or_reset(dev, devm_pm_clear_wake_irq, dev); +} + /** * handle_threaded_wake_irq - Handler for dedicated wake-up interrupts * @irq: Device specific dedicated wake-up interrupt diff --git a/include/linux/pm_wakeirq.h b/include/linux/pm_wakeirq.h index d9642c6cf85211af603ce39e280a5b4de6617ee5..25b63ed51b765c2c6919f259668a12675330835e 100644 --- a/include/linux/pm_wakeirq.h +++ b/include/linux/pm_wakeirq.h @@ -10,6 +10,7 @@ extern int dev_pm_set_wake_irq(struct device *dev, int irq); extern int dev_pm_set_dedicated_wake_irq(struct device *dev, int irq); extern int dev_pm_set_dedicated_wake_irq_reverse(struct device *dev, int irq); extern void dev_pm_clear_wake_irq(struct device *dev); +extern int devm_pm_set_wake_irq(struct device *dev, int irq); #else /* !CONFIG_PM */ @@ -32,5 +33,10 @@ static inline void dev_pm_clear_wake_irq(struct device *dev) { } +static inline int devm_pm_set_wake_irq(struct device *dev, int irq) +{ + return 0; +} + #endif /* CONFIG_PM */ #endif /* _LINUX_PM_WAKEIRQ_H */