Commit 7c3cceda authored by Shenwei Wang's avatar Shenwei Wang Committed by Linus Walleij

pinctrl: freescale: add pad wakeup config

add the logic to configure the pad wakeup function via
the pin_config_set handler.
Signed-off-by: default avatarShenwei Wang <shenwei.wang@nxp.com>
Reported-by: default avatarkernel test robot <lkp@intel.com>
Reviewed-by: default avatarPeng Fan <peng.fan@nxp.com>
Acked-by: default avatarBartosz Golaszewski <bartosz.golaszewski@linaro.org>
Link: https://lore.kernel.org/r/20221027130859.1444412-5-shenwei.wang@nxp.comSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent cdb6f424
...@@ -15,6 +15,11 @@ ...@@ -15,6 +15,11 @@
#include "../core.h" #include "../core.h"
#include "pinctrl-imx.h" #include "pinctrl-imx.h"
#define IMX_SC_PAD_FUNC_GET_WAKEUP 9
#define IMX_SC_PAD_FUNC_SET_WAKEUP 4
#define IMX_SC_IRQ_GROUP_WAKE 3 /* Wakeup interrupts */
#define IMX_SC_IRQ_PAD 2 /* Pad wakeup */
enum pad_func_e { enum pad_func_e {
IMX_SC_PAD_FUNC_SET = 15, IMX_SC_PAD_FUNC_SET = 15,
IMX_SC_PAD_FUNC_GET = 16, IMX_SC_PAD_FUNC_GET = 16,
...@@ -36,10 +41,18 @@ struct imx_sc_msg_resp_pad_get { ...@@ -36,10 +41,18 @@ struct imx_sc_msg_resp_pad_get {
u32 val; u32 val;
} __packed; } __packed;
struct imx_sc_msg_gpio_set_pad_wakeup {
struct imx_sc_rpc_msg hdr;
u16 pad;
u8 wakeup;
} __packed __aligned(4);
static struct imx_sc_ipc *pinctrl_ipc_handle; static struct imx_sc_ipc *pinctrl_ipc_handle;
int imx_pinctrl_sc_ipc_init(struct platform_device *pdev) int imx_pinctrl_sc_ipc_init(struct platform_device *pdev)
{ {
imx_scu_irq_group_enable(IMX_SC_IRQ_GROUP_WAKE,
IMX_SC_IRQ_PAD, true);
return imx_scu_get_handle(&pinctrl_ipc_handle); return imx_scu_get_handle(&pinctrl_ipc_handle);
} }
EXPORT_SYMBOL_GPL(imx_pinctrl_sc_ipc_init); EXPORT_SYMBOL_GPL(imx_pinctrl_sc_ipc_init);
...@@ -81,6 +94,23 @@ int imx_pinconf_set_scu(struct pinctrl_dev *pctldev, unsigned pin_id, ...@@ -81,6 +94,23 @@ int imx_pinconf_set_scu(struct pinctrl_dev *pctldev, unsigned pin_id,
unsigned int val; unsigned int val;
int ret; int ret;
if (num_configs == 1) {
struct imx_sc_msg_gpio_set_pad_wakeup wmsg;
hdr = &wmsg.hdr;
hdr->ver = IMX_SC_RPC_VERSION;
hdr->svc = IMX_SC_RPC_SVC_PAD;
hdr->func = IMX_SC_PAD_FUNC_SET_WAKEUP;
hdr->size = 2;
wmsg.pad = pin_id;
wmsg.wakeup = *configs;
ret = imx_scu_call_rpc(pinctrl_ipc_handle, &wmsg, true);
dev_dbg(ipctl->dev, "wakeup pin_id: %d type: %ld\n",
pin_id, *configs);
return ret;
}
/* /*
* Set mux and conf together in one IPC call * Set mux and conf together in one IPC call
*/ */
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment