mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-09 23:00:21 +00:00
pinctrl: qcom: ipq4019: add open drain support
[ Brian: adapted from from the Chromium OS kernel used on IPQ4019-based WiFi APs. ] Signed-off-by: Jaiganesh Narayanan <njaigane@codeaurora.org> Signed-off-by: Brian Norris <computersforpeace@gmail.com> Link: https://lore.kernel.org/r/20200703080646.23233-1-computersforpeace@gmail.com Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
This commit is contained in:
parent
13c502c863
commit
13355ca35c
@ -254,6 +254,7 @@ DECLARE_QCA_GPIO_PINS(99);
|
|||||||
.mux_bit = 2, \
|
.mux_bit = 2, \
|
||||||
.pull_bit = 0, \
|
.pull_bit = 0, \
|
||||||
.drv_bit = 6, \
|
.drv_bit = 6, \
|
||||||
|
.od_bit = 12, \
|
||||||
.oe_bit = 9, \
|
.oe_bit = 9, \
|
||||||
.in_bit = 0, \
|
.in_bit = 0, \
|
||||||
.out_bit = 1, \
|
.out_bit = 1, \
|
||||||
|
@ -233,6 +233,10 @@ static int msm_config_reg(struct msm_pinctrl *pctrl,
|
|||||||
*bit = g->pull_bit;
|
*bit = g->pull_bit;
|
||||||
*mask = 3;
|
*mask = 3;
|
||||||
break;
|
break;
|
||||||
|
case PIN_CONFIG_DRIVE_OPEN_DRAIN:
|
||||||
|
*bit = g->od_bit;
|
||||||
|
*mask = 1;
|
||||||
|
break;
|
||||||
case PIN_CONFIG_DRIVE_STRENGTH:
|
case PIN_CONFIG_DRIVE_STRENGTH:
|
||||||
*bit = g->drv_bit;
|
*bit = g->drv_bit;
|
||||||
*mask = 7;
|
*mask = 7;
|
||||||
@ -310,6 +314,12 @@ static int msm_config_group_get(struct pinctrl_dev *pctldev,
|
|||||||
if (!arg)
|
if (!arg)
|
||||||
return -EINVAL;
|
return -EINVAL;
|
||||||
break;
|
break;
|
||||||
|
case PIN_CONFIG_DRIVE_OPEN_DRAIN:
|
||||||
|
/* Pin is not open-drain */
|
||||||
|
if (!arg)
|
||||||
|
return -EINVAL;
|
||||||
|
arg = 1;
|
||||||
|
break;
|
||||||
case PIN_CONFIG_DRIVE_STRENGTH:
|
case PIN_CONFIG_DRIVE_STRENGTH:
|
||||||
arg = msm_regval_to_drive(arg);
|
arg = msm_regval_to_drive(arg);
|
||||||
break;
|
break;
|
||||||
@ -382,6 +392,9 @@ static int msm_config_group_set(struct pinctrl_dev *pctldev,
|
|||||||
else
|
else
|
||||||
arg = MSM_PULL_UP;
|
arg = MSM_PULL_UP;
|
||||||
break;
|
break;
|
||||||
|
case PIN_CONFIG_DRIVE_OPEN_DRAIN:
|
||||||
|
arg = 1;
|
||||||
|
break;
|
||||||
case PIN_CONFIG_DRIVE_STRENGTH:
|
case PIN_CONFIG_DRIVE_STRENGTH:
|
||||||
/* Check for invalid values */
|
/* Check for invalid values */
|
||||||
if (arg > 16 || arg < 2 || (arg % 2) != 0)
|
if (arg > 16 || arg < 2 || (arg % 2) != 0)
|
||||||
|
@ -38,6 +38,7 @@ struct msm_function {
|
|||||||
* @mux_bit: Offset in @ctl_reg for the pinmux function selection.
|
* @mux_bit: Offset in @ctl_reg for the pinmux function selection.
|
||||||
* @pull_bit: Offset in @ctl_reg for the bias configuration.
|
* @pull_bit: Offset in @ctl_reg for the bias configuration.
|
||||||
* @drv_bit: Offset in @ctl_reg for the drive strength configuration.
|
* @drv_bit: Offset in @ctl_reg for the drive strength configuration.
|
||||||
|
* @od_bit: Offset in @ctl_reg for controlling open drain.
|
||||||
* @oe_bit: Offset in @ctl_reg for controlling output enable.
|
* @oe_bit: Offset in @ctl_reg for controlling output enable.
|
||||||
* @in_bit: Offset in @io_reg for the input bit value.
|
* @in_bit: Offset in @io_reg for the input bit value.
|
||||||
* @out_bit: Offset in @io_reg for the output bit value.
|
* @out_bit: Offset in @io_reg for the output bit value.
|
||||||
@ -75,6 +76,7 @@ struct msm_pingroup {
|
|||||||
unsigned pull_bit:5;
|
unsigned pull_bit:5;
|
||||||
unsigned drv_bit:5;
|
unsigned drv_bit:5;
|
||||||
|
|
||||||
|
unsigned od_bit:5;
|
||||||
unsigned oe_bit:5;
|
unsigned oe_bit:5;
|
||||||
unsigned in_bit:5;
|
unsigned in_bit:5;
|
||||||
unsigned out_bit:5;
|
unsigned out_bit:5;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user