aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Warren <swarren@nvidia.com>2015-02-24 16:00:49 -0500
committerLinus Walleij <linus.walleij@linaro.org>2015-03-09 13:10:58 -0400
commitea623061930ccf6d37b4a09a4e65a26fcf552c22 (patch)
tree9f0b8b54e1eeb73aced4ae5ce25c4a53699a9fff
parent8d4684b39b5865ef5471a256adfcd8d7c3e18d43 (diff)
pinctrl: tegra: some bits move between registers
Some of the pinmux configuration bits that exist in "drive group" registers in Tegra30..Tegra124 move to the "pinmux" registers on future chips. Add a flag to support this. Signed-off-by: Stephen Warren <swarren@nvidia.com> Tested-by: Alexandre Courbot <acourbot@nvidia.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
-rw-r--r--drivers/pinctrl/pinctrl-tegra.c27
-rw-r--r--drivers/pinctrl/pinctrl-tegra.h3
-rw-r--r--drivers/pinctrl/pinctrl-tegra114.c3
-rw-r--r--drivers/pinctrl/pinctrl-tegra124.c3
-rw-r--r--drivers/pinctrl/pinctrl-tegra20.c3
-rw-r--r--drivers/pinctrl/pinctrl-tegra30.c3
6 files changed, 36 insertions, 6 deletions
diff --git a/drivers/pinctrl/pinctrl-tegra.c b/drivers/pinctrl/pinctrl-tegra.c
index e5949d51bc52..6cd651a88398 100644
--- a/drivers/pinctrl/pinctrl-tegra.c
+++ b/drivers/pinctrl/pinctrl-tegra.c
@@ -348,14 +348,24 @@ static int tegra_pinconf_reg(struct tegra_pmx *pmx,
348 *width = 1; 348 *width = 1;
349 break; 349 break;
350 case TEGRA_PINCONF_PARAM_HIGH_SPEED_MODE: 350 case TEGRA_PINCONF_PARAM_HIGH_SPEED_MODE:
351 *bank = g->drv_bank; 351 if (pmx->soc->hsm_in_mux) {
352 *reg = g->drv_reg; 352 *bank = g->mux_bank;
353 *reg = g->mux_reg;
354 } else {
355 *bank = g->drv_bank;
356 *reg = g->drv_reg;
357 }
353 *bit = g->hsm_bit; 358 *bit = g->hsm_bit;
354 *width = 1; 359 *width = 1;
355 break; 360 break;
356 case TEGRA_PINCONF_PARAM_SCHMITT: 361 case TEGRA_PINCONF_PARAM_SCHMITT:
357 *bank = g->drv_bank; 362 if (pmx->soc->schmitt_in_mux) {
358 *reg = g->drv_reg; 363 *bank = g->mux_bank;
364 *reg = g->mux_reg;
365 } else {
366 *bank = g->drv_bank;
367 *reg = g->drv_reg;
368 }
359 *bit = g->schmitt_bit; 369 *bit = g->schmitt_bit;
360 *width = 1; 370 *width = 1;
361 break; 371 break;
@@ -390,8 +400,13 @@ static int tegra_pinconf_reg(struct tegra_pmx *pmx,
390 *width = g->slwr_width; 400 *width = g->slwr_width;
391 break; 401 break;
392 case TEGRA_PINCONF_PARAM_DRIVE_TYPE: 402 case TEGRA_PINCONF_PARAM_DRIVE_TYPE:
393 *bank = g->drv_bank; 403 if (pmx->soc->drvtype_in_mux) {
394 *reg = g->drv_reg; 404 *bank = g->mux_bank;
405 *reg = g->mux_reg;
406 } else {
407 *bank = g->drv_bank;
408 *reg = g->drv_reg;
409 }
395 *bit = g->drvtype_bit; 410 *bit = g->drvtype_bit;
396 *width = 2; 411 *width = 2;
397 break; 412 break;
diff --git a/drivers/pinctrl/pinctrl-tegra.h b/drivers/pinctrl/pinctrl-tegra.h
index 8d94d1332e7b..d54ab9d38792 100644
--- a/drivers/pinctrl/pinctrl-tegra.h
+++ b/drivers/pinctrl/pinctrl-tegra.h
@@ -182,6 +182,9 @@ struct tegra_pinctrl_soc_data {
182 unsigned nfunctions; 182 unsigned nfunctions;
183 const struct tegra_pingroup *groups; 183 const struct tegra_pingroup *groups;
184 unsigned ngroups; 184 unsigned ngroups;
185 bool hsm_in_mux;
186 bool schmitt_in_mux;
187 bool drvtype_in_mux;
185}; 188};
186 189
187int tegra_pinctrl_probe(struct platform_device *pdev, 190int tegra_pinctrl_probe(struct platform_device *pdev,
diff --git a/drivers/pinctrl/pinctrl-tegra114.c b/drivers/pinctrl/pinctrl-tegra114.c
index 0740cdba7508..05e49d5137ab 100644
--- a/drivers/pinctrl/pinctrl-tegra114.c
+++ b/drivers/pinctrl/pinctrl-tegra114.c
@@ -1841,6 +1841,9 @@ static const struct tegra_pinctrl_soc_data tegra114_pinctrl = {
1841 .nfunctions = ARRAY_SIZE(tegra114_functions), 1841 .nfunctions = ARRAY_SIZE(tegra114_functions),
1842 .groups = tegra114_groups, 1842 .groups = tegra114_groups,
1843 .ngroups = ARRAY_SIZE(tegra114_groups), 1843 .ngroups = ARRAY_SIZE(tegra114_groups),
1844 .hsm_in_mux = false,
1845 .schmitt_in_mux = false,
1846 .drvtype_in_mux = false,
1844}; 1847};
1845 1848
1846static int tegra114_pinctrl_probe(struct platform_device *pdev) 1849static int tegra114_pinctrl_probe(struct platform_device *pdev)
diff --git a/drivers/pinctrl/pinctrl-tegra124.c b/drivers/pinctrl/pinctrl-tegra124.c
index b7ba26064dbf..7cd44c7c296d 100644
--- a/drivers/pinctrl/pinctrl-tegra124.c
+++ b/drivers/pinctrl/pinctrl-tegra124.c
@@ -2053,6 +2053,9 @@ static const struct tegra_pinctrl_soc_data tegra124_pinctrl = {
2053 .nfunctions = ARRAY_SIZE(tegra124_functions), 2053 .nfunctions = ARRAY_SIZE(tegra124_functions),
2054 .groups = tegra124_groups, 2054 .groups = tegra124_groups,
2055 .ngroups = ARRAY_SIZE(tegra124_groups), 2055 .ngroups = ARRAY_SIZE(tegra124_groups),
2056 .hsm_in_mux = false,
2057 .schmitt_in_mux = false,
2058 .drvtype_in_mux = false,
2056}; 2059};
2057 2060
2058static int tegra124_pinctrl_probe(struct platform_device *pdev) 2061static int tegra124_pinctrl_probe(struct platform_device *pdev)
diff --git a/drivers/pinctrl/pinctrl-tegra20.c b/drivers/pinctrl/pinctrl-tegra20.c
index d3a5722e4acb..4833db4433d9 100644
--- a/drivers/pinctrl/pinctrl-tegra20.c
+++ b/drivers/pinctrl/pinctrl-tegra20.c
@@ -2221,6 +2221,9 @@ static const struct tegra_pinctrl_soc_data tegra20_pinctrl = {
2221 .nfunctions = ARRAY_SIZE(tegra20_functions), 2221 .nfunctions = ARRAY_SIZE(tegra20_functions),
2222 .groups = tegra20_groups, 2222 .groups = tegra20_groups,
2223 .ngroups = ARRAY_SIZE(tegra20_groups), 2223 .ngroups = ARRAY_SIZE(tegra20_groups),
2224 .hsm_in_mux = false,
2225 .schmitt_in_mux = false,
2226 .drvtype_in_mux = false,
2224}; 2227};
2225 2228
2226static int tegra20_pinctrl_probe(struct platform_device *pdev) 2229static int tegra20_pinctrl_probe(struct platform_device *pdev)
diff --git a/drivers/pinctrl/pinctrl-tegra30.c b/drivers/pinctrl/pinctrl-tegra30.c
index 77c0768d5bd8..47b2fd8bb2e9 100644
--- a/drivers/pinctrl/pinctrl-tegra30.c
+++ b/drivers/pinctrl/pinctrl-tegra30.c
@@ -2476,6 +2476,9 @@ static const struct tegra_pinctrl_soc_data tegra30_pinctrl = {
2476 .nfunctions = ARRAY_SIZE(tegra30_functions), 2476 .nfunctions = ARRAY_SIZE(tegra30_functions),
2477 .groups = tegra30_groups, 2477 .groups = tegra30_groups,
2478 .ngroups = ARRAY_SIZE(tegra30_groups), 2478 .ngroups = ARRAY_SIZE(tegra30_groups),
2479 .hsm_in_mux = false,
2480 .schmitt_in_mux = false,
2481 .drvtype_in_mux = false,
2479}; 2482};
2480 2483
2481static int tegra30_pinctrl_probe(struct platform_device *pdev) 2484static int tegra30_pinctrl_probe(struct platform_device *pdev)