diff options
author | John Crispin <blogic@openwrt.org> | 2014-02-18 13:33:16 +0000 |
---|---|---|
committer | John Crispin <blogic@openwrt.org> | 2014-02-18 13:33:16 +0000 |
commit | 1cd43bd4760e9efdb43f02f7718128c69d44ede2 (patch) | |
tree | 3e1baa3b8121ef017ce3d1b15158e98db7e3dd34 /target/linux | |
parent | bed28742bc2a8a93989cd34fbe023743c38537aa (diff) | |
download | master-187ad058-1cd43bd4760e9efdb43f02f7718128c69d44ede2.tar.gz master-187ad058-1cd43bd4760e9efdb43f02f7718128c69d44ede2.tar.bz2 master-187ad058-1cd43bd4760e9efdb43f02f7718128c69d44ede2.zip |
ralink: fix the gpio mode mapping
Signed-off-by: John Crispin <blogic@openwrt.org>
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@39609 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target/linux')
-rw-r--r-- | target/linux/ramips/patches-3.10/999-pinctrl_fixes.patch | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/target/linux/ramips/patches-3.10/999-pinctrl_fixes.patch b/target/linux/ramips/patches-3.10/999-pinctrl_fixes.patch new file mode 100644 index 0000000000..21236b1293 --- /dev/null +++ b/target/linux/ramips/patches-3.10/999-pinctrl_fixes.patch @@ -0,0 +1,35 @@ +Index: linux-3.10.28/drivers/pinctrl/pinctrl-rt2880.c +=================================================================== +--- linux-3.10.28.orig/drivers/pinctrl/pinctrl-rt2880.c 2014-02-14 10:46:06.216549358 +0000 ++++ linux-3.10.28/drivers/pinctrl/pinctrl-rt2880.c 2014-02-14 14:58:18.580040433 +0000 +@@ -204,6 +204,7 @@ + { + struct rt2880_priv *p = pinctrl_dev_get_drvdata(pctrldev); + u32 mode = 0; ++ int i; + + /* dont allow double use */ + if (p->groups[group].enabled) { +@@ -217,16 +218,16 @@ + mode = rt_sysc_r32(SYSC_REG_GPIO_MODE); + mode &= ~(p->groups[group].mask << p->groups[group].shift); + ++ /* mark the pins as gpio */ ++ for (i = 0; i < p->groups[group].func[0].pin_count; i++) ++ p->gpio[p->groups[group].func[0].pins[i]] = 1; ++ + /* function 0 is gpio and needs special handling */ + if (func == 0) { +- int i; +- +- + mode |= p->groups[group].gpio << p->groups[group].shift; +- /* mark the pins as gpio */ +- for (i = 0; i < p->groups[group].func[0].pin_count; i++) +- p->gpio[p->groups[group].func[0].pins[i]] = 1; + } else { ++ for (i = 0; i < p->func[func]->pin_count; i++) ++ p->gpio[p->func[func]->pins[i]] = 0; + mode |= p->func[func]->value << p->groups[group].shift; + } + rt_sysc_w32(mode, SYSC_REG_GPIO_MODE); |