pinctrl: imx: add soc specific mux_mode mask and shift property
authorDong Aisheng <aisheng.dong@nxp.com>
Fri, 19 May 2017 07:05:43 +0000 (15:05 +0800)
committerLinus Walleij <linus.walleij@linaro.org>
Mon, 22 May 2017 09:05:19 +0000 (11:05 +0200)
MX7ULP MUX mode mask and shift bit is different from VF610.
Let's make it a platform specific property for the later easy of
adding MX7ULP support.

One trick in exist code that Vybrid hardcoded the config part
as 0xffff because its mux_config register BIT[15-0] are all configs
part. But it's not true in ULP, so use mux_mask instead to address
the difference.

Cc: Stefan Agner <stefan@agner.ch>
Cc: Bai Ping <ping.bai@nxp.com>
Signed-off-by: Fugang Duan <fugang.duan@nxp.com>
Signed-off-by: Dong Aisheng <aisheng.dong@nxp.com>
Acked-by: Shawn Guo <shawnguo@kernel.org>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/freescale/pinctrl-imx.c
drivers/pinctrl/freescale/pinctrl-imx.h
drivers/pinctrl/freescale/pinctrl-vf610.c

index 328d079b237e6131d37589afd96791167195f52c..72aca758f4c6a0d643ebdcb79d1eea8f9cf5d6ed 100644 (file)
@@ -197,8 +197,8 @@ static int imx_pmx_set(struct pinctrl_dev *pctldev, unsigned selector,
                if (info->flags & SHARE_MUX_CONF_REG) {
                        u32 reg;
                        reg = readl(ipctl->base + pin_reg->mux_reg);
-                       reg &= ~(0x7 << 20);
-                       reg |= (pin->mux_mode << 20);
+                       reg &= ~info->mux_mask;
+                       reg |= (pin->mux_mode << info->mux_shift);
                        writel(reg, ipctl->base + pin_reg->mux_reg);
                        dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
                                pin_reg->mux_reg, reg);
@@ -290,7 +290,7 @@ static int imx_pmx_gpio_request_enable(struct pinctrl_dev *pctldev,
 
 mux_pin:
        reg = readl(ipctl->base + pin_reg->mux_reg);
-       reg &= ~(0x7 << 20);
+       reg &= ~info->mux_mask;
        reg |= imx_pin->config;
        writel(reg, ipctl->base + pin_reg->mux_reg);
 
@@ -434,7 +434,7 @@ static int imx_pinconf_get(struct pinctrl_dev *pctldev,
        *config = readl(ipctl->base + pin_reg->conf_reg);
 
        if (info->flags & SHARE_MUX_CONF_REG)
-               *config &= 0xffff;
+               *config &= ~info->mux_mask;
 
        return 0;
 }
@@ -461,7 +461,7 @@ static int imx_pinconf_set(struct pinctrl_dev *pctldev,
                if (info->flags & SHARE_MUX_CONF_REG) {
                        u32 reg;
                        reg = readl(ipctl->base + pin_reg->conf_reg);
-                       reg &= ~0xffff;
+                       reg &= info->mux_mask;
                        reg |= configs[i];
                        writel(reg, ipctl->base + pin_reg->conf_reg);
                        dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
index 38aa53c671edb6ce1d6eda041839da049152574d..880bba7fd1ab0081d107b0360962699f5b9deff0 100644 (file)
@@ -64,6 +64,10 @@ struct imx_pinctrl_soc_info {
        const char *gpr_compatible;
        struct mutex mutex;
 
+       /* MUX_MODE shift and mask in case SHARE_MUX_CONF_REG */
+       unsigned int mux_mask;
+       u8 mux_shift;
+
        /* generic pinconf */
        bool generic_pinconf;
        const struct pinconf_generic_params *custom_params;
index 2b1e198e30927addc01e623cb2fa3abb4438bc57..3bd85564d1e471a6c8a39b6dc6b02e7d6c47654b 100644 (file)
@@ -299,6 +299,8 @@ static struct imx_pinctrl_soc_info vf610_pinctrl_info = {
        .pins = vf610_pinctrl_pads,
        .npins = ARRAY_SIZE(vf610_pinctrl_pads),
        .flags = SHARE_MUX_CONF_REG | ZERO_OFFSET_VALID,
+       .mux_mask = 0x700000,
+       .mux_shift = 20,
 };
 
 static const struct of_device_id vf610_pinctrl_of_match[] = {