Received: by 2002:a25:683:0:0:0:0:0 with SMTP id 125csp311127ybg; Wed, 10 Jun 2020 01:10:57 -0700 (PDT) X-Google-Smtp-Source: ABdhPJzIzdFLxeKkLv3b6NyQEjhpNIwf1rc7sCLIWt1z+0EX6rgLzb95CGWX7RBmgedCwXH/PvD2 X-Received: by 2002:a05:6402:155:: with SMTP id s21mr1415956edu.144.1591776656930; Wed, 10 Jun 2020 01:10:56 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1591776656; cv=none; d=google.com; s=arc-20160816; b=EehBcr69N2L1MTZuKEW8qUR/tYvSafjuIU4vddaiuIPZdMnScl+6QS2F2HS2WVals3 bBLRDrl+ocX8ZjaEet6MiwrNZT/MqeXgRmYEDK5hxeGC38AMUBqu76/Yf442Fvecze1e xBvxXsFCj7R6NcYWEFST8Y3e/hIep7sFXI0nEHBIrD8FKJHCTKfyLVpzXBZ9vAZkkk4C kgrYJppPt2MMkN+kh735giDTCiVVTWxnDZQ5hv2cvw2zT1lXedgopOKTqgfAZB1PHzTM BS8/5JpbEwmq3Vo4oWBVPoICBDpoQzhUrY6FZUuFkPo4H/S0toX9lxnrHFdB3PIJCfL4 JsKQ== 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=C4TfmjTd9d4cEdMCDtWuKDWD3W4LueuZL2ODPaBwu7U=; b=Zm1wbhEW4/5fOh64xyoW12u5X9tkkUhQIQHhxpsq6sXtdfEH4pAD1q01G3nFzOZg+v 7O0bIO+fWqwfE5ZtAXwNESMjRyCxolLE5NpZcqEgGJPG5PRfW5LdFjYOYFE1nsWOzj++ Sc9EgeIJJsps58j4Bt2voyE40QkTR5an1A/IsjcGQ5TH794ItqxuCImo5kUcZmVXH9Nr TXQHHWqYIgigzlt9z6iTX4hlPmwesQhbKJm1sj3I+/jsnUDsvItB8vuzET6k/IxX0MJT oacdOZMT9tDI/ViZmaEV7HuSEx1U97BuJXW2pS7QlyxgH+IjU8dd3+v8iKVAemdXZEk1 WFJg== 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 v22si11828294edy.558.2020.06.10.01.10.33; Wed, 10 Jun 2020 01:10:56 -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 S1726535AbgFJIIo (ORCPT + 99 others); Wed, 10 Jun 2020 04:08:44 -0400 Received: from inva020.nxp.com ([92.121.34.13]:37876 "EHLO inva020.nxp.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726207AbgFJIIn (ORCPT ); Wed, 10 Jun 2020 04:08:43 -0400 Received: from inva020.nxp.com (localhost [127.0.0.1]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id AF6091A1525; Wed, 10 Jun 2020 10:08:41 +0200 (CEST) Received: from invc005.ap-rdc01.nxp.com (invc005.ap-rdc01.nxp.com [165.114.16.14]) by inva020.eu-rdc02.nxp.com (Postfix) with ESMTP id 22E491A1502; Wed, 10 Jun 2020 10:08:37 +0200 (CEST) Received: from localhost.localdomain (shlinux2.ap.freescale.net [10.192.224.44]) by invc005.ap-rdc01.nxp.com (Postfix) with ESMTP id 88B6540307; Wed, 10 Jun 2020 16:08:31 +0800 (SGT) From: Anson Huang To: aisheng.dong@nxp.com, festevam@gmail.com, shawnguo@kernel.org, stefan@agner.ch, kernel@pengutronix.de, linus.walleij@linaro.org, s.hauer@pengutronix.de, linux-gpio@vger.kernel.org, linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Cc: Linux-imx@nxp.com Subject: [PATCH V4 0/9] Support i.MX8 SoCs pinctrl drivers built as module Date: Wed, 10 Jun 2020 15:57:36 +0800 Message-Id: <1591775865-26872-1-git-send-email-Anson.Huang@nxp.com> X-Mailer: git-send-email 2.7.4 X-Virus-Scanned: ClamAV using ClamSMTP Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There are more and mroe requirements that SoC specific modules should be built as module in order to support generic kernel image, such as Android GKI concept. This patch series supports i.MX8 SoCs pinctrl drivers to be built as module, including i.MX8MQ/MM/MN/MP/QXP/QM/DXL SoCs, and it also supports building i.MX common pinctrl driver and i.MX SCU common pinctrl driver as module. Compared to V3, the changes are as below: - change the config dependency back to original; - use function callbacks for SCU related functions, and all drivers using SCU pinctrl driver need to initialize the function callbacks, pinctrl-imx.c will check the SCU function callback and call it when it is valid, then no build issue when PINCTRL_IMX is built in and PINCTRL_IMX_SCU is built as module. Anson Huang (9): pinctrl: imx: Support building SCU pinctrl driver as module pinctrl: imx: Support building i.MX pinctrl driver as module pinctrl: imx8mm: Support building as module pinctrl: imx8mn: Support building as module pinctrl: imx8mq: Support building as module pinctrl: imx8mp: Support building as module pinctrl: imx8qxp: Support building as module pinctrl: imx8qm: Support building as module pinctrl: imx8dxl: Support building as module drivers/pinctrl/freescale/Kconfig | 19 +++++----- drivers/pinctrl/freescale/pinctrl-imx.c | 22 ++++++----- drivers/pinctrl/freescale/pinctrl-imx.h | 57 ++++++++++++----------------- drivers/pinctrl/freescale/pinctrl-imx8dxl.c | 12 +++--- drivers/pinctrl/freescale/pinctrl-imx8mm.c | 10 ++--- drivers/pinctrl/freescale/pinctrl-imx8mn.c | 10 ++--- drivers/pinctrl/freescale/pinctrl-imx8mp.c | 10 ++--- drivers/pinctrl/freescale/pinctrl-imx8mq.c | 9 ++--- drivers/pinctrl/freescale/pinctrl-imx8qm.c | 12 +++--- drivers/pinctrl/freescale/pinctrl-imx8qxp.c | 12 +++--- drivers/pinctrl/freescale/pinctrl-scu.c | 6 +++ 11 files changed, 86 insertions(+), 93 deletions(-) -- 2.7.4