Commit c709135e authored by Claudiu Beznea's avatar Claudiu Beznea Committed by Linus Walleij

pinctrl: at91-pio4: add support for slew-rate

SAMA7G5 supports slew rate configuration. Adapt the driver for this.
For output switching frequencies lower than 50MHz the slew rate needs to
be enabled. Since most of the pins on SAMA7G5 fall into this category
enabled the slew rate by default.
Signed-off-by: default avatarClaudiu Beznea <claudiu.beznea@microchip.com>
Acked-by: default avatarLudovic Desroches <ludovic.desroches@microchip.com>
Link: https://lore.kernel.org/r/1611747945-29960-3-git-send-email-claudiu.beznea@microchip.comSigned-off-by: default avatarLinus Walleij <linus.walleij@linaro.org>
parent aad018aa
...@@ -36,6 +36,7 @@ ...@@ -36,6 +36,7 @@
#define ATMEL_PIO_DIR_MASK BIT(8) #define ATMEL_PIO_DIR_MASK BIT(8)
#define ATMEL_PIO_PUEN_MASK BIT(9) #define ATMEL_PIO_PUEN_MASK BIT(9)
#define ATMEL_PIO_PDEN_MASK BIT(10) #define ATMEL_PIO_PDEN_MASK BIT(10)
#define ATMEL_PIO_SR_MASK BIT(11)
#define ATMEL_PIO_IFEN_MASK BIT(12) #define ATMEL_PIO_IFEN_MASK BIT(12)
#define ATMEL_PIO_IFSCEN_MASK BIT(13) #define ATMEL_PIO_IFSCEN_MASK BIT(13)
#define ATMEL_PIO_OPD_MASK BIT(14) #define ATMEL_PIO_OPD_MASK BIT(14)
...@@ -76,10 +77,12 @@ ...@@ -76,10 +77,12 @@
* @nbanks: number of PIO banks * @nbanks: number of PIO banks
* @last_bank_count: number of lines in the last bank (can be less than * @last_bank_count: number of lines in the last bank (can be less than
* the rest of the banks). * the rest of the banks).
* @slew_rate_support: slew rate support
*/ */
struct atmel_pioctrl_data { struct atmel_pioctrl_data {
unsigned nbanks; unsigned nbanks;
unsigned last_bank_count; unsigned last_bank_count;
unsigned int slew_rate_support;
}; };
struct atmel_group { struct atmel_group {
...@@ -117,6 +120,7 @@ struct atmel_pin { ...@@ -117,6 +120,7 @@ struct atmel_pin {
* @pm_suspend_backup: backup/restore register values on suspend/resume * @pm_suspend_backup: backup/restore register values on suspend/resume
* @dev: device entry for the Atmel PIO controller. * @dev: device entry for the Atmel PIO controller.
* @node: node of the Atmel PIO controller. * @node: node of the Atmel PIO controller.
* @slew_rate_support: slew rate support
*/ */
struct atmel_pioctrl { struct atmel_pioctrl {
void __iomem *reg_base; void __iomem *reg_base;
...@@ -138,6 +142,7 @@ struct atmel_pioctrl { ...@@ -138,6 +142,7 @@ struct atmel_pioctrl {
} *pm_suspend_backup; } *pm_suspend_backup;
struct device *dev; struct device *dev;
struct device_node *node; struct device_node *node;
unsigned int slew_rate_support;
}; };
static const char * const atmel_functions[] = { static const char * const atmel_functions[] = {
...@@ -760,6 +765,13 @@ static int atmel_conf_pin_config_group_get(struct pinctrl_dev *pctldev, ...@@ -760,6 +765,13 @@ static int atmel_conf_pin_config_group_get(struct pinctrl_dev *pctldev,
return -EINVAL; return -EINVAL;
arg = 1; arg = 1;
break; break;
case PIN_CONFIG_SLEW_RATE:
if (!atmel_pioctrl->slew_rate_support)
return -EOPNOTSUPP;
if (!(res & ATMEL_PIO_SR_MASK))
return -EINVAL;
arg = 1;
break;
case ATMEL_PIN_CONFIG_DRIVE_STRENGTH: case ATMEL_PIN_CONFIG_DRIVE_STRENGTH:
if (!(res & ATMEL_PIO_DRVSTR_MASK)) if (!(res & ATMEL_PIO_DRVSTR_MASK))
return -EINVAL; return -EINVAL;
...@@ -793,6 +805,10 @@ static int atmel_conf_pin_config_group_set(struct pinctrl_dev *pctldev, ...@@ -793,6 +805,10 @@ static int atmel_conf_pin_config_group_set(struct pinctrl_dev *pctldev,
dev_dbg(pctldev->dev, "%s: pin=%u, config=0x%lx\n", dev_dbg(pctldev->dev, "%s: pin=%u, config=0x%lx\n",
__func__, pin_id, configs[i]); __func__, pin_id, configs[i]);
/* Keep slew rate enabled by default. */
if (atmel_pioctrl->slew_rate_support)
conf |= ATMEL_PIO_SR_MASK;
switch (param) { switch (param) {
case PIN_CONFIG_BIAS_DISABLE: case PIN_CONFIG_BIAS_DISABLE:
conf &= (~ATMEL_PIO_PUEN_MASK); conf &= (~ATMEL_PIO_PUEN_MASK);
...@@ -850,6 +866,13 @@ static int atmel_conf_pin_config_group_set(struct pinctrl_dev *pctldev, ...@@ -850,6 +866,13 @@ static int atmel_conf_pin_config_group_set(struct pinctrl_dev *pctldev,
ATMEL_PIO_SODR); ATMEL_PIO_SODR);
} }
break; break;
case PIN_CONFIG_SLEW_RATE:
if (!atmel_pioctrl->slew_rate_support)
break;
/* And remove it if explicitly requested. */
if (arg == 0)
conf &= ~ATMEL_PIO_SR_MASK;
break;
case ATMEL_PIN_CONFIG_DRIVE_STRENGTH: case ATMEL_PIN_CONFIG_DRIVE_STRENGTH:
switch (arg) { switch (arg) {
case ATMEL_PIO_DRVSTR_LO: case ATMEL_PIO_DRVSTR_LO:
...@@ -901,6 +924,8 @@ static void atmel_conf_pin_config_dbg_show(struct pinctrl_dev *pctldev, ...@@ -901,6 +924,8 @@ static void atmel_conf_pin_config_dbg_show(struct pinctrl_dev *pctldev,
seq_printf(s, "%s ", "open-drain"); seq_printf(s, "%s ", "open-drain");
if (conf & ATMEL_PIO_SCHMITT_MASK) if (conf & ATMEL_PIO_SCHMITT_MASK)
seq_printf(s, "%s ", "schmitt"); seq_printf(s, "%s ", "schmitt");
if (atmel_pioctrl->slew_rate_support && (conf & ATMEL_PIO_SR_MASK))
seq_printf(s, "%s ", "slew-rate");
if (conf & ATMEL_PIO_DRVSTR_MASK) { if (conf & ATMEL_PIO_DRVSTR_MASK) {
switch ((conf & ATMEL_PIO_DRVSTR_MASK) >> ATMEL_PIO_DRVSTR_OFFSET) { switch ((conf & ATMEL_PIO_DRVSTR_MASK) >> ATMEL_PIO_DRVSTR_OFFSET) {
case ATMEL_PIO_DRVSTR_ME: case ATMEL_PIO_DRVSTR_ME:
...@@ -994,6 +1019,7 @@ static const struct atmel_pioctrl_data atmel_sama5d2_pioctrl_data = { ...@@ -994,6 +1019,7 @@ static const struct atmel_pioctrl_data atmel_sama5d2_pioctrl_data = {
static const struct atmel_pioctrl_data microchip_sama7g5_pioctrl_data = { static const struct atmel_pioctrl_data microchip_sama7g5_pioctrl_data = {
.nbanks = 5, .nbanks = 5,
.last_bank_count = 8, /* sama7g5 has only PE0 to PE7 */ .last_bank_count = 8, /* sama7g5 has only PE0 to PE7 */
.slew_rate_support = 1,
}; };
static const struct of_device_id atmel_pctrl_of_match[] = { static const struct of_device_id atmel_pctrl_of_match[] = {
...@@ -1039,6 +1065,7 @@ static int atmel_pinctrl_probe(struct platform_device *pdev) ...@@ -1039,6 +1065,7 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
atmel_pioctrl->npins -= ATMEL_PIO_NPINS_PER_BANK; atmel_pioctrl->npins -= ATMEL_PIO_NPINS_PER_BANK;
atmel_pioctrl->npins += atmel_pioctrl_data->last_bank_count; atmel_pioctrl->npins += atmel_pioctrl_data->last_bank_count;
} }
atmel_pioctrl->slew_rate_support = atmel_pioctrl_data->slew_rate_support;
atmel_pioctrl->reg_base = devm_platform_ioremap_resource(pdev, 0); atmel_pioctrl->reg_base = devm_platform_ioremap_resource(pdev, 0);
if (IS_ERR(atmel_pioctrl->reg_base)) if (IS_ERR(atmel_pioctrl->reg_base))
......
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