From patchwork Mon Jul 17 17:28:11 2023 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Andy Shevchenko X-Patchwork-Id: 12154 Return-Path: Delivered-To: ouuuleilei@gmail.com Received: by 2002:a59:c923:0:b0:3e4:2afc:c1 with SMTP id j3csp1263458vqt; Mon, 17 Jul 2023 11:03:18 -0700 (PDT) X-Google-Smtp-Source: APBJJlFg8rAUewvFRFyvjWqtGr0d33vNDcrmUNtgi++Kp14aBFuAALuign6Qb6U+b8f5vP9xi6c5 X-Received: by 2002:a2e:7c0f:0:b0:2b9:3883:a765 with SMTP id x15-20020a2e7c0f000000b002b93883a765mr3053170ljc.31.1689616998111; Mon, 17 Jul 2023 11:03:18 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1689616998; cv=none; d=google.com; s=arc-20160816; b=qIjNmiG9ollEacV5cnp1SPDMyoA4Y4qolv3S6Z1HMoH9/G9KE01ri8HzhL34TVOo8k CJxJt7/Qpp0ccaOxqjFEhF/q1IJVTEnWQ0z9jSxPeSKHPEcvNMmJW0uz4eRD0NWvlerS ueQieyAybFnZbXS4IU+njR2M1DvtlALaOb3XychUJaShm8CFrvuW7gbk4OJciu1IcaSI 5QbOi5HmEIyCYXIOFVbRRXqSfsns9XtB9jx++8vn1b5RwlYg/jZFj6Ebaf6J21Qgo8CP sTQCNOYHboVNY6Aim5OpR4hIll2ZXG0MAuhNy0Qd5ek7XC1xNomQo2JM3gN+/mqNw7+Q tC4A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :message-id:date:subject:cc:to:from:dkim-signature; bh=x2WnRxUb/Kd3sEy5TsZyd9U2wV/jcq6eDApE3FCgzZI=; fh=BB0GY8bRtFrF5EQ7S2W7nc4ojj3WvWGP74FS8Jyyj9E=; b=ZhBcdqPbeSScK9xiZ9r0Bke0GIg5qi8ry+qLAjBvtD7y2GFkIUTVJ+oRcrskJZqdBs OKVCjrEhd5xus0K4nxK5EqFFH08pFT5ashHEtUuz1R0wTRl0lrVjXvZaRWmstO6GP99y zLJ+/EBbIRPyXtlRiFogOim+BbuiBwk5rT+Zl2d0pLKNX1FudmUeClTZK8EUVviBTa07 WAbiofqKPdIDN4+5tjrApSooYqdfgmFqIPG4DgDDtIWf2IbP/h6P/VS/6JPH9oh647rS snmA5X+4zXrWq3p7zLJoDtRxxr/DAZpBrc7QxzNlC0U1O6qwNt6FWFpzC9BSRwn5AqOs Zm7A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=jUWdOK7r; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id t8-20020a17090616c800b00993692f6b87si6089716ejd.409.2023.07.17.11.02.53; Mon, 17 Jul 2023 11:03:18 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@intel.com header.s=Intel header.b=jUWdOK7r; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231455AbjGQR34 (ORCPT + 99 others); Mon, 17 Jul 2023 13:29:56 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:45898 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S231347AbjGQR3r (ORCPT ); Mon, 17 Jul 2023 13:29:47 -0400 Received: from mga18.intel.com (mga18.intel.com [134.134.136.126]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 40C3F1716; Mon, 17 Jul 2023 10:29:25 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=intel.com; i=@intel.com; q=dns/txt; s=Intel; t=1689614965; x=1721150965; h=from:to:cc:subject:date:message-id:mime-version: content-transfer-encoding; bh=cfXxY8OSt6dnoWrqrmzF+bK5umSU80545NZ+VPDZ5MY=; b=jUWdOK7rZE+3FkhptycuE6fFmLvh1SnUGqEf0Euh9UUpUBsMdsHSBgJP 1rCePC+IjMsA8QdILB6JT7WiOjIOFW57NT8B//JemO6Gwjg0NwvRpnwIm LvxoFEDUNG74rSPNEnrCCX6EjDf7ehY0zijtHmBWdA2zpN1GdVurIqUCT mvEmMOvwq4YPtLzkoNcLMAdEusA+Yy6N7xDdWfnLwhVhjFuQO3vuOQdOE csf5a7wI9885m6xKtt1H0yHyj0kVy5O+wvjr8Mjw3DH5DHpIN5+O4MP8t 1isJggQgjwx7kDc3Sva4qi4z8NtHpElgR8OWqXMLEbiZD5jy9lQqDtnb7 Q==; X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="350854485" X-IronPort-AV: E=Sophos;i="6.01,211,1684825200"; d="scan'208";a="350854485" Received: from fmsmga003.fm.intel.com ([10.253.24.29]) by orsmga106.jf.intel.com with ESMTP/TLS/ECDHE-RSA-AES256-GCM-SHA384; 17 Jul 2023 10:28:40 -0700 X-ExtLoop1: 1 X-IronPort-AV: E=McAfee;i="6600,9927,10774"; a="813426654" X-IronPort-AV: E=Sophos;i="6.01,211,1684825200"; d="scan'208";a="813426654" Received: from black.fi.intel.com ([10.237.72.28]) by FMSMGA003.fm.intel.com with ESMTP; 17 Jul 2023 10:28:33 -0700 Received: by black.fi.intel.com (Postfix, from userid 1003) id CBFC1256; Mon, 17 Jul 2023 20:28:39 +0300 (EEST) From: Andy Shevchenko To: Andy Shevchenko , Mika Westerberg , Linus Walleij , Balsam CHIHI , Claudiu Beznea , Geert Uytterhoeven , Wolfram Sang , Thierry Reding , Paul Cercueil , linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org, linux-mediatek@lists.infradead.org, linux-arm-kernel@lists.infradead.org, linux-renesas-soc@vger.kernel.org, linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org Cc: Andy Shevchenko , Sean Wang , Matthias Brugger , AngeloGioacchino Del Regno , Andrew Lunn , Gregory Clement , Sebastian Hesselbarth , Ludovic Desroches , Nicolas Ferre , Alexandre Belloni , Jonathan Hunter , "Rafael J. Wysocki" , Len Brown , Pavel Machek Subject: [PATCH v2 00/10] pinctrl: Provide NOIRQ PM helper and use it Date: Mon, 17 Jul 2023 20:28:11 +0300 Message-Id: <20230717172821.62827-1-andriy.shevchenko@linux.intel.com> X-Mailer: git-send-email 2.40.0.1.gaa8946217a0b MIME-Version: 1.0 X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_EF,SPF_HELO_NONE,SPF_NONE, T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org X-getmail-retrieved-from-mailbox: INBOX X-GMAIL-THRID: 1771691833369769093 X-GMAIL-MSGID: 1771691833369769093 Intel pin control drivers use NOIRQ variant of the PM callbacks. Besides that several other drivers do similar. Provide a helper to make them smaller and less error prone against different kernel configurations (with possible defined but not used variables). The idea is to have an immutable branch that PM tree can pull as well as main pin control one. We also can do other way around, if Rafael prefers that. Changelog v2: - rewritten commit message in patch 1 (Rafael) - converted non-Intel pin control drivers as well - added couple of kinda related patches to use pm_ptr() Andy Shevchenko (10): pm: Introduce DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: baytrail: Make use of pm_ptr() pinctrl: cherryview: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: intel: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: lynxpoint: Make use of pm_ptr() pinctrl: at91: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: mediatek: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: mvebu: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: renesas: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper pinctrl: tegra: Switch to use DEFINE_NOIRQ_DEV_PM_OPS() helper drivers/pinctrl/intel/pinctrl-baytrail.c | 11 +++-------- drivers/pinctrl/intel/pinctrl-cherryview.c | 9 ++------- drivers/pinctrl/intel/pinctrl-intel.c | 5 +---- drivers/pinctrl/intel/pinctrl-intel.h | 9 ++------- drivers/pinctrl/intel/pinctrl-lynxpoint.c | 7 +++---- drivers/pinctrl/mediatek/pinctrl-mtk-common.c | 5 +---- drivers/pinctrl/mediatek/pinctrl-paris.c | 9 +++------ drivers/pinctrl/mvebu/pinctrl-armada-37xx.c | 14 +++----------- drivers/pinctrl/pinctrl-at91.c | 10 ++++------ drivers/pinctrl/renesas/core.c | 16 +++++++--------- drivers/pinctrl/tegra/pinctrl-tegra.c | 5 +---- include/linux/pm.h | 9 +++++++++ 12 files changed, 39 insertions(+), 70 deletions(-)