aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--arch/arm/mach-omap2/mux.c73
1 files changed, 48 insertions, 25 deletions
diff --git a/arch/arm/mach-omap2/mux.c b/arch/arm/mach-omap2/mux.c
index 3d71d93caab2..0fa3d74125bc 100644
--- a/arch/arm/mach-omap2/mux.c
+++ b/arch/arm/mach-omap2/mux.c
@@ -151,12 +151,14 @@ int __init omap_mux_init_gpio(int gpio, int val)
151 return -ENODEV; 151 return -ENODEV;
152} 152}
153 153
154static int __init _omap_mux_init_signal(struct omap_mux_partition *partition, 154static int __init _omap_mux_get_by_name(struct omap_mux_partition *partition,
155 const char *muxname, int val) 155 const char *muxname,
156 struct omap_mux **found_mux)
156{ 157{
158 struct omap_mux *mux = NULL;
157 struct omap_mux_entry *e; 159 struct omap_mux_entry *e;
158 const char *mode_name; 160 const char *mode_name;
159 int found = 0, mode0_len = 0; 161 int found = 0, found_mode, mode0_len = 0;
160 struct list_head *muxmodes = &partition->muxmodes; 162 struct list_head *muxmodes = &partition->muxmodes;
161 163
162 mode_name = strchr(muxname, '.'); 164 mode_name = strchr(muxname, '.');
@@ -168,40 +170,34 @@ static int __init _omap_mux_init_signal(struct omap_mux_partition *partition,
168 } 170 }
169 171
170 list_for_each_entry(e, muxmodes, node) { 172 list_for_each_entry(e, muxmodes, node) {
171 struct omap_mux *m = &e->mux; 173 char *m0_entry;
172 char *m0_entry = m->muxnames[0];
173 int i; 174 int i;
174 175
176 mux = &e->mux;
177 m0_entry = mux->muxnames[0];
178
175 /* First check for full name in mode0.muxmode format */ 179 /* First check for full name in mode0.muxmode format */
176 if (mode0_len && strncmp(muxname, m0_entry, mode0_len)) 180 if (mode0_len && strncmp(muxname, m0_entry, mode0_len))
177 continue; 181 continue;
178 182
179 /* Then check for muxmode only */ 183 /* Then check for muxmode only */
180 for (i = 0; i < OMAP_MUX_NR_MODES; i++) { 184 for (i = 0; i < OMAP_MUX_NR_MODES; i++) {
181 char *mode_cur = m->muxnames[i]; 185 char *mode_cur = mux->muxnames[i];
182 186
183 if (!mode_cur) 187 if (!mode_cur)
184 continue; 188 continue;
185 189
186 if (!strcmp(mode_name, mode_cur)) { 190 if (!strcmp(mode_name, mode_cur)) {
187 u16 old_mode; 191 *found_mux = mux;
188 u16 mux_mode;
189
190 old_mode = omap_mux_read(partition,
191 m->reg_offset);
192 mux_mode = val | i;
193 pr_debug("%s: Setting signal "
194 "%s.%s 0x%04x -> 0x%04x\n", __func__,
195 m0_entry, muxname, old_mode, mux_mode);
196 omap_mux_write(partition, mux_mode,
197 m->reg_offset);
198 found++; 192 found++;
193 found_mode = i;
199 } 194 }
200 } 195 }
201 } 196 }
202 197
203 if (found == 1) 198 if (found == 1) {
204 return 0; 199 return found_mode;
200 }
205 201
206 if (found > 1) { 202 if (found > 1) {
207 pr_err("%s: Multiple signal paths (%i) for %s\n", __func__, 203 pr_err("%s: Multiple signal paths (%i) for %s\n", __func__,
@@ -209,24 +205,51 @@ static int __init _omap_mux_init_signal(struct omap_mux_partition *partition,
209 return -EINVAL; 205 return -EINVAL;
210 } 206 }
211 207
212 pr_err("%s: Could not set signal %s\n", __func__, muxname); 208 pr_err("%s: Could not find signal %s\n", __func__, muxname);
213 209
214 return -ENODEV; 210 return -ENODEV;
215} 211}
216 212
217int __init omap_mux_init_signal(const char *muxname, int val) 213static int __init
214omap_mux_get_by_name(const char *muxname,
215 struct omap_mux_partition **found_partition,
216 struct omap_mux **found_mux)
218{ 217{
219 struct omap_mux_partition *partition; 218 struct omap_mux_partition *partition;
220 int ret;
221 219
222 list_for_each_entry(partition, &mux_partitions, node) { 220 list_for_each_entry(partition, &mux_partitions, node) {
223 ret = _omap_mux_init_signal(partition, muxname, val); 221 struct omap_mux *mux = NULL;
224 if (!ret) 222 int mux_mode = _omap_mux_get_by_name(partition, muxname, &mux);
225 return ret; 223 if (mux_mode < 0)
224 continue;
225
226 *found_partition = partition;
227 *found_mux = mux;
228
229 return mux_mode;
226 } 230 }
227 231
228 return -ENODEV; 232 return -ENODEV;
233}
229 234
235int __init omap_mux_init_signal(const char *muxname, int val)
236{
237 struct omap_mux_partition *partition = NULL;
238 struct omap_mux *mux = NULL;
239 u16 old_mode;
240 int mux_mode;
241
242 mux_mode = omap_mux_get_by_name(muxname, &partition, &mux);
243 if (mux_mode < 0)
244 return mux_mode;
245
246 old_mode = omap_mux_read(partition, mux->reg_offset);
247 mux_mode |= val;
248 pr_debug("%s: Setting signal %s 0x%04x -> 0x%04x\n",
249 __func__, muxname, old_mode, mux_mode);
250 omap_mux_write(partition, mux_mode, mux->reg_offset);
251
252 return 0;
230} 253}
231 254
232#ifdef CONFIG_DEBUG_FS 255#ifdef CONFIG_DEBUG_FS