aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/net
diff options
context:
space:
mode:
authorLuciano Coelho <luciano.coelho@nokia.com>2009-12-11 08:40:52 -0500
committerJohn W. Linville <linville@tuxdriver.com>2009-12-28 16:31:32 -0500
commit98b2a68473ae975bc4abdeb66cd719ccfdad9d4a (patch)
tree7120acfc475d9a5e9b62d7ab3394829cf4bde733 /drivers/net
parent1b38ea8858fd169064683e27add43511308e521a (diff)
wl1271: add gpio_power file in debugfs to power the chip on and off
Some debugging tools require the chip to be powered on before they can work. With these tools, we shouldn't upload the firmware nor boot the firmware ourselves, so this debufs file is provided. It always contains the gpio power setting (0 = off, 1 = on). To change the power setting, just write 0 or 1 to the file. Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com> Reviewed-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Reviewed-by: Kalle Valo <kalle.valo@nokia.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers/net')
-rw-r--r--drivers/net/wireless/wl12xx/wl1271.h3
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_debugfs.c55
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_main.c3
3 files changed, 61 insertions, 0 deletions
diff --git a/drivers/net/wireless/wl12xx/wl1271.h b/drivers/net/wireless/wl12xx/wl1271.h
index 94359b1a861..3bec6f3b1c7 100644
--- a/drivers/net/wireless/wl12xx/wl1271.h
+++ b/drivers/net/wireless/wl12xx/wl1271.h
@@ -276,6 +276,7 @@ struct wl1271_debugfs {
276 276
277 struct dentry *retry_count; 277 struct dentry *retry_count;
278 struct dentry *excessive_retries; 278 struct dentry *excessive_retries;
279 struct dentry *gpio_power;
279}; 280};
280 281
281#define NUM_TX_QUEUES 4 282#define NUM_TX_QUEUES 4
@@ -442,6 +443,8 @@ struct wl1271 {
442 struct conf_drv_settings conf; 443 struct conf_drv_settings conf;
443 444
444 struct list_head list; 445 struct list_head list;
446
447 bool gpio_power;
445}; 448};
446 449
447int wl1271_plt_start(struct wl1271 *wl); 450int wl1271_plt_start(struct wl1271 *wl);
diff --git a/drivers/net/wireless/wl12xx/wl1271_debugfs.c b/drivers/net/wireless/wl12xx/wl1271_debugfs.c
index c1805e5f896..4eaf40c5756 100644
--- a/drivers/net/wireless/wl12xx/wl1271_debugfs.c
+++ b/drivers/net/wireless/wl12xx/wl1271_debugfs.c
@@ -237,6 +237,57 @@ static const struct file_operations tx_queue_len_ops = {
237 .open = wl1271_open_file_generic, 237 .open = wl1271_open_file_generic,
238}; 238};
239 239
240static ssize_t gpio_power_read(struct file *file, char __user *user_buf,
241 size_t count, loff_t *ppos)
242{
243 struct wl1271 *wl = file->private_data;
244 int res;
245 char buf[10];
246
247 res = scnprintf(buf, sizeof(buf), "%d\n", wl->gpio_power);
248
249 return simple_read_from_buffer(user_buf, count, ppos, buf, res);
250}
251
252static ssize_t gpio_power_write(struct file *file,
253 const char __user *user_buf,
254 size_t count, loff_t *ppos)
255{
256 struct wl1271 *wl = file->private_data;
257 char buf[10];
258 size_t len;
259 unsigned long value;
260 int ret;
261
262 mutex_lock(&wl->mutex);
263
264 len = min(count, sizeof(buf) - 1);
265 if (copy_from_user(buf, user_buf, len)) {
266 ret = -EFAULT;
267 goto out;
268 }
269 buf[len] = '\0';
270
271 ret = strict_strtoul(buf, 0, &value);
272 if (ret < 0) {
273 wl1271_warning("illegal value in gpio_power");
274 goto out;
275 }
276
277 wl->set_power(!!value);
278 wl->gpio_power = !!value;
279
280out:
281 mutex_unlock(&wl->mutex);
282 return count;
283}
284
285static const struct file_operations gpio_power_ops = {
286 .read = gpio_power_read,
287 .write = gpio_power_write,
288 .open = wl1271_open_file_generic
289};
290
240static void wl1271_debugfs_delete_files(struct wl1271 *wl) 291static void wl1271_debugfs_delete_files(struct wl1271 *wl)
241{ 292{
242 DEBUGFS_FWSTATS_DEL(tx, internal_desc_overflow); 293 DEBUGFS_FWSTATS_DEL(tx, internal_desc_overflow);
@@ -333,6 +384,8 @@ static void wl1271_debugfs_delete_files(struct wl1271 *wl)
333 DEBUGFS_DEL(tx_queue_len); 384 DEBUGFS_DEL(tx_queue_len);
334 DEBUGFS_DEL(retry_count); 385 DEBUGFS_DEL(retry_count);
335 DEBUGFS_DEL(excessive_retries); 386 DEBUGFS_DEL(excessive_retries);
387
388 DEBUGFS_DEL(gpio_power);
336} 389}
337 390
338static int wl1271_debugfs_add_files(struct wl1271 *wl) 391static int wl1271_debugfs_add_files(struct wl1271 *wl)
@@ -434,6 +487,8 @@ static int wl1271_debugfs_add_files(struct wl1271 *wl)
434 DEBUGFS_ADD(retry_count, wl->debugfs.rootdir); 487 DEBUGFS_ADD(retry_count, wl->debugfs.rootdir);
435 DEBUGFS_ADD(excessive_retries, wl->debugfs.rootdir); 488 DEBUGFS_ADD(excessive_retries, wl->debugfs.rootdir);
436 489
490 DEBUGFS_ADD(gpio_power, wl->debugfs.rootdir);
491
437out: 492out:
438 if (ret < 0) 493 if (ret < 0)
439 wl1271_debugfs_delete_files(wl); 494 wl1271_debugfs_delete_files(wl);
diff --git a/drivers/net/wireless/wl12xx/wl1271_main.c b/drivers/net/wireless/wl12xx/wl1271_main.c
index 147aab22235..b33bdcc1eb4 100644
--- a/drivers/net/wireless/wl12xx/wl1271_main.c
+++ b/drivers/net/wireless/wl12xx/wl1271_main.c
@@ -399,11 +399,13 @@ static void wl1271_disable_interrupts(struct wl1271 *wl)
399static void wl1271_power_off(struct wl1271 *wl) 399static void wl1271_power_off(struct wl1271 *wl)
400{ 400{
401 wl->set_power(false); 401 wl->set_power(false);
402 wl->gpio_power = false;
402} 403}
403 404
404static void wl1271_power_on(struct wl1271 *wl) 405static void wl1271_power_on(struct wl1271 *wl)
405{ 406{
406 wl->set_power(true); 407 wl->set_power(true);
408 wl->gpio_power = true;
407} 409}
408 410
409static void wl1271_fw_status(struct wl1271 *wl, 411static void wl1271_fw_status(struct wl1271 *wl,
@@ -1923,6 +1925,7 @@ static int __devinit wl1271_probe(struct spi_device *spi)
1923 wl->band = IEEE80211_BAND_2GHZ; 1925 wl->band = IEEE80211_BAND_2GHZ;
1924 wl->vif = NULL; 1926 wl->vif = NULL;
1925 wl->joined = false; 1927 wl->joined = false;
1928 wl->gpio_power = false;
1926 1929
1927 for (i = 0; i < ACX_TX_DESCRIPTORS; i++) 1930 for (i = 0; i < ACX_TX_DESCRIPTORS; i++)
1928 wl->tx_frames[i] = NULL; 1931 wl->tx_frames[i] = NULL;