346dcd0ac662e046492d13ba810f5c84b8f62468
[openwrt.git] / target / linux / ipq806x / patches / 0037-pinctrl-msm-Make-number-of-functions-variable.patch
1 From 1c11b14dd6d740e997919f0bf789bf921548dc0f Mon Sep 17 00:00:00 2001
2 From: Bjorn Andersson <bjorn.andersson@sonymobile.com>
3 Date: Mon, 31 Mar 2014 14:49:55 -0700
4 Subject: [PATCH 037/182] pinctrl: msm: Make number of functions variable
5
6 The various pins may have different number of functions defined, so make this
7 number definable per pin instead of just increasing it to the largest one for
8 all of the platforms.
9
10 Signed-off-by: Bjorn Andersson <bjorn.andersson@sonymobile.com>
11 Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
12 ---
13  drivers/pinctrl/pinctrl-msm.c     |    4 ++--
14  drivers/pinctrl/pinctrl-msm.h     |    3 ++-
15  drivers/pinctrl/pinctrl-msm8x74.c |    3 ++-
16  3 files changed, 6 insertions(+), 4 deletions(-)
17
18 diff --git a/drivers/pinctrl/pinctrl-msm.c b/drivers/pinctrl/pinctrl-msm.c
19 index 706809e..7d67d34 100644
20 --- a/drivers/pinctrl/pinctrl-msm.c
21 +++ b/drivers/pinctrl/pinctrl-msm.c
22 @@ -145,12 +145,12 @@ static int msm_pinmux_enable(struct pinctrl_dev *pctldev,
23         if (WARN_ON(g->mux_bit < 0))
24                 return -EINVAL;
25  
26 -       for (i = 0; i < ARRAY_SIZE(g->funcs); i++) {
27 +       for (i = 0; i < g->nfuncs; i++) {
28                 if (g->funcs[i] == function)
29                         break;
30         }
31  
32 -       if (WARN_ON(i == ARRAY_SIZE(g->funcs)))
33 +       if (WARN_ON(i == g->nfuncs))
34                 return -EINVAL;
35  
36         spin_lock_irqsave(&pctrl->lock, flags);
37 diff --git a/drivers/pinctrl/pinctrl-msm.h b/drivers/pinctrl/pinctrl-msm.h
38 index 6e26f1b..7b2a227 100644
39 --- a/drivers/pinctrl/pinctrl-msm.h
40 +++ b/drivers/pinctrl/pinctrl-msm.h
41 @@ -65,7 +65,8 @@ struct msm_pingroup {
42         const unsigned *pins;
43         unsigned npins;
44  
45 -       unsigned funcs[8];
46 +       unsigned *funcs;
47 +       unsigned nfuncs;
48  
49         s16 ctl_reg;
50         s16 io_reg;
51 diff --git a/drivers/pinctrl/pinctrl-msm8x74.c b/drivers/pinctrl/pinctrl-msm8x74.c
52 index dde5529..57766d5 100644
53 --- a/drivers/pinctrl/pinctrl-msm8x74.c
54 +++ b/drivers/pinctrl/pinctrl-msm8x74.c
55 @@ -341,7 +341,7 @@ static const unsigned int sdc2_data_pins[] = { 151 };
56                 .name = "gpio" #id,                     \
57                 .pins = gpio##id##_pins,                \
58                 .npins = ARRAY_SIZE(gpio##id##_pins),   \
59 -               .funcs = {                              \
60 +               .funcs = (int[]){                       \
61                         MSM_MUX_NA, /* gpio mode */     \
62                         MSM_MUX_##f1,                   \
63                         MSM_MUX_##f2,                   \
64 @@ -351,6 +351,7 @@ static const unsigned int sdc2_data_pins[] = { 151 };
65                         MSM_MUX_##f6,                   \
66                         MSM_MUX_##f7                    \
67                 },                                      \
68 +               .nfuncs = 8,                            \
69                 .ctl_reg = 0x1000 + 0x10 * id,          \
70                 .io_reg = 0x1004 + 0x10 * id,           \
71                 .intr_cfg_reg = 0x1008 + 0x10 * id,     \
72 -- 
73 1.7.10.4
74