pinctrl: imx: add soc specific mux_mode mask and shift property
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>
This commit is contained in:
Родитель
a5cadbbb08
Коммит
5586ee4191
|
@ -197,8 +197,8 @@ static int imx_pmx_set(struct pinctrl_dev *pctldev, unsigned selector,
|
||||||
if (info->flags & SHARE_MUX_CONF_REG) {
|
if (info->flags & SHARE_MUX_CONF_REG) {
|
||||||
u32 reg;
|
u32 reg;
|
||||||
reg = readl(ipctl->base + pin_reg->mux_reg);
|
reg = readl(ipctl->base + pin_reg->mux_reg);
|
||||||
reg &= ~(0x7 << 20);
|
reg &= ~info->mux_mask;
|
||||||
reg |= (pin->mux_mode << 20);
|
reg |= (pin->mux_mode << info->mux_shift);
|
||||||
writel(reg, ipctl->base + pin_reg->mux_reg);
|
writel(reg, ipctl->base + pin_reg->mux_reg);
|
||||||
dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
|
dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
|
||||||
pin_reg->mux_reg, reg);
|
pin_reg->mux_reg, reg);
|
||||||
|
@ -290,7 +290,7 @@ static int imx_pmx_gpio_request_enable(struct pinctrl_dev *pctldev,
|
||||||
|
|
||||||
mux_pin:
|
mux_pin:
|
||||||
reg = readl(ipctl->base + pin_reg->mux_reg);
|
reg = readl(ipctl->base + pin_reg->mux_reg);
|
||||||
reg &= ~(0x7 << 20);
|
reg &= ~info->mux_mask;
|
||||||
reg |= imx_pin->config;
|
reg |= imx_pin->config;
|
||||||
writel(reg, ipctl->base + pin_reg->mux_reg);
|
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);
|
*config = readl(ipctl->base + pin_reg->conf_reg);
|
||||||
|
|
||||||
if (info->flags & SHARE_MUX_CONF_REG)
|
if (info->flags & SHARE_MUX_CONF_REG)
|
||||||
*config &= 0xffff;
|
*config &= ~info->mux_mask;
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -461,7 +461,7 @@ static int imx_pinconf_set(struct pinctrl_dev *pctldev,
|
||||||
if (info->flags & SHARE_MUX_CONF_REG) {
|
if (info->flags & SHARE_MUX_CONF_REG) {
|
||||||
u32 reg;
|
u32 reg;
|
||||||
reg = readl(ipctl->base + pin_reg->conf_reg);
|
reg = readl(ipctl->base + pin_reg->conf_reg);
|
||||||
reg &= ~0xffff;
|
reg &= info->mux_mask;
|
||||||
reg |= configs[i];
|
reg |= configs[i];
|
||||||
writel(reg, ipctl->base + pin_reg->conf_reg);
|
writel(reg, ipctl->base + pin_reg->conf_reg);
|
||||||
dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
|
dev_dbg(ipctl->dev, "write: offset 0x%x val 0x%x\n",
|
||||||
|
|
|
@ -64,6 +64,10 @@ struct imx_pinctrl_soc_info {
|
||||||
const char *gpr_compatible;
|
const char *gpr_compatible;
|
||||||
struct mutex mutex;
|
struct mutex mutex;
|
||||||
|
|
||||||
|
/* MUX_MODE shift and mask in case SHARE_MUX_CONF_REG */
|
||||||
|
unsigned int mux_mask;
|
||||||
|
u8 mux_shift;
|
||||||
|
|
||||||
/* generic pinconf */
|
/* generic pinconf */
|
||||||
bool generic_pinconf;
|
bool generic_pinconf;
|
||||||
const struct pinconf_generic_params *custom_params;
|
const struct pinconf_generic_params *custom_params;
|
||||||
|
|
|
@ -299,6 +299,8 @@ static struct imx_pinctrl_soc_info vf610_pinctrl_info = {
|
||||||
.pins = vf610_pinctrl_pads,
|
.pins = vf610_pinctrl_pads,
|
||||||
.npins = ARRAY_SIZE(vf610_pinctrl_pads),
|
.npins = ARRAY_SIZE(vf610_pinctrl_pads),
|
||||||
.flags = SHARE_MUX_CONF_REG | ZERO_OFFSET_VALID,
|
.flags = SHARE_MUX_CONF_REG | ZERO_OFFSET_VALID,
|
||||||
|
.mux_mask = 0x700000,
|
||||||
|
.mux_shift = 20,
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct of_device_id vf610_pinctrl_of_match[] = {
|
static const struct of_device_id vf610_pinctrl_of_match[] = {
|
||||||
|
|
Загрузка…
Ссылка в новой задаче