0037-pinctrl-msm-Make-number-of-functions-variable.patch 2.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. From 1c11b14dd6d740e997919f0bf789bf921548dc0f Mon Sep 17 00:00:00 2001
  2. From: Bjorn Andersson <[email protected]>
  3. Date: Mon, 31 Mar 2014 14:49:55 -0700
  4. Subject: [PATCH 037/182] pinctrl: msm: Make number of functions variable
  5. The various pins may have different number of functions defined, so make this
  6. number definable per pin instead of just increasing it to the largest one for
  7. all of the platforms.
  8. Signed-off-by: Bjorn Andersson <[email protected]>
  9. Signed-off-by: Linus Walleij <[email protected]>
  10. ---
  11. drivers/pinctrl/pinctrl-msm.c | 4 ++--
  12. drivers/pinctrl/pinctrl-msm.h | 3 ++-
  13. drivers/pinctrl/pinctrl-msm8x74.c | 3 ++-
  14. 3 files changed, 6 insertions(+), 4 deletions(-)
  15. --- a/drivers/pinctrl/pinctrl-msm.c
  16. +++ b/drivers/pinctrl/pinctrl-msm.c
  17. @@ -145,12 +145,12 @@ static int msm_pinmux_enable(struct pinc
  18. if (WARN_ON(g->mux_bit < 0))
  19. return -EINVAL;
  20. - for (i = 0; i < ARRAY_SIZE(g->funcs); i++) {
  21. + for (i = 0; i < g->nfuncs; i++) {
  22. if (g->funcs[i] == function)
  23. break;
  24. }
  25. - if (WARN_ON(i == ARRAY_SIZE(g->funcs)))
  26. + if (WARN_ON(i == g->nfuncs))
  27. return -EINVAL;
  28. spin_lock_irqsave(&pctrl->lock, flags);
  29. --- a/drivers/pinctrl/pinctrl-msm.h
  30. +++ b/drivers/pinctrl/pinctrl-msm.h
  31. @@ -65,7 +65,8 @@ struct msm_pingroup {
  32. const unsigned *pins;
  33. unsigned npins;
  34. - unsigned funcs[8];
  35. + unsigned *funcs;
  36. + unsigned nfuncs;
  37. s16 ctl_reg;
  38. s16 io_reg;
  39. --- a/drivers/pinctrl/pinctrl-msm8x74.c
  40. +++ b/drivers/pinctrl/pinctrl-msm8x74.c
  41. @@ -341,7 +341,7 @@ static const unsigned int sdc2_data_pins
  42. .name = "gpio" #id, \
  43. .pins = gpio##id##_pins, \
  44. .npins = ARRAY_SIZE(gpio##id##_pins), \
  45. - .funcs = { \
  46. + .funcs = (int[]){ \
  47. MSM_MUX_NA, /* gpio mode */ \
  48. MSM_MUX_##f1, \
  49. MSM_MUX_##f2, \
  50. @@ -351,6 +351,7 @@ static const unsigned int sdc2_data_pins
  51. MSM_MUX_##f6, \
  52. MSM_MUX_##f7 \
  53. }, \
  54. + .nfuncs = 8, \
  55. .ctl_reg = 0x1000 + 0x10 * id, \
  56. .io_reg = 0x1004 + 0x10 * id, \
  57. .intr_cfg_reg = 0x1008 + 0x10 * id, \