aboutsummaryrefslogtreecommitdiffstats
path: root/drivers
diff options
context:
space:
mode:
authorJuuso Oikarinen <juuso.oikarinen@nokia.com>2010-03-18 06:26:32 -0400
committerJohn W. Linville <linville@tuxdriver.com>2010-03-23 16:50:21 -0400
commit7fc3a8647d2eaa8bc2f7ac7e9baff55199da7be6 (patch)
tree983b195e3c084def8784af68d0aba69e33ccf940 /drivers
parenta1dd8187d8d8f565976c9e55374dee520cdc2fa3 (diff)
wl1271: Add sysfs file to control BT co-ex state
Add a sysfs file to control the state of the BT co-ex (enable or disable it.) By default, the BT co-ex is enabled. Signed-off-by: Juuso Oikarinen <juuso.oikarinen@nokia.com> Reviewed-by: Teemu Paasikivi <ext-teemu.3.paasikivi@nokia.com> Signed-off-by: Luciano Coelho <luciano.coelho@nokia.com> Signed-off-by: John W. Linville <linville@tuxdriver.com>
Diffstat (limited to 'drivers')
-rw-r--r--drivers/net/wireless/wl12xx/wl1271.h2
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_acx.c7
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_acx.h2
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_init.c2
-rw-r--r--drivers/net/wireless/wl12xx/wl1271_main.c72
5 files changed, 81 insertions, 4 deletions
diff --git a/drivers/net/wireless/wl12xx/wl1271.h b/drivers/net/wireless/wl12xx/wl1271.h
index 7397999deb19..23a0c7e22939 100644
--- a/drivers/net/wireless/wl12xx/wl1271.h
+++ b/drivers/net/wireless/wl12xx/wl1271.h
@@ -484,6 +484,8 @@ struct wl1271 {
484 /* Current chipset configuration */ 484 /* Current chipset configuration */
485 struct conf_drv_settings conf; 485 struct conf_drv_settings conf;
486 486
487 bool sg_enabled;
488
487 struct list_head list; 489 struct list_head list;
488}; 490};
489 491
diff --git a/drivers/net/wireless/wl12xx/wl1271_acx.c b/drivers/net/wireless/wl12xx/wl1271_acx.c
index e7c22d3c75ac..7e337cea9905 100644
--- a/drivers/net/wireless/wl12xx/wl1271_acx.c
+++ b/drivers/net/wireless/wl12xx/wl1271_acx.c
@@ -534,7 +534,7 @@ out:
534} 534}
535 535
536 536
537int wl1271_acx_sg_enable(struct wl1271 *wl) 537int wl1271_acx_sg_enable(struct wl1271 *wl, bool enable)
538{ 538{
539 struct acx_bt_wlan_coex *pta; 539 struct acx_bt_wlan_coex *pta;
540 int ret; 540 int ret;
@@ -547,7 +547,10 @@ int wl1271_acx_sg_enable(struct wl1271 *wl)
547 goto out; 547 goto out;
548 } 548 }
549 549
550 pta->enable = wl->conf.sg.state; 550 if (enable)
551 pta->enable = wl->conf.sg.state;
552 else
553 pta->enable = CONF_SG_DISABLE;
551 554
552 ret = wl1271_cmd_configure(wl, ACX_SG_ENABLE, pta, sizeof(*pta)); 555 ret = wl1271_cmd_configure(wl, ACX_SG_ENABLE, pta, sizeof(*pta));
553 if (ret < 0) { 556 if (ret < 0) {
diff --git a/drivers/net/wireless/wl12xx/wl1271_acx.h b/drivers/net/wireless/wl12xx/wl1271_acx.h
index dee3c06a717c..8e5870fa9609 100644
--- a/drivers/net/wireless/wl12xx/wl1271_acx.h
+++ b/drivers/net/wireless/wl12xx/wl1271_acx.h
@@ -1005,7 +1005,7 @@ int wl1271_acx_dco_itrim_params(struct wl1271 *wl);
1005int wl1271_acx_beacon_filter_opt(struct wl1271 *wl, bool enable_filter); 1005int wl1271_acx_beacon_filter_opt(struct wl1271 *wl, bool enable_filter);
1006int wl1271_acx_beacon_filter_table(struct wl1271 *wl); 1006int wl1271_acx_beacon_filter_table(struct wl1271 *wl);
1007int wl1271_acx_conn_monit_params(struct wl1271 *wl); 1007int wl1271_acx_conn_monit_params(struct wl1271 *wl);
1008int wl1271_acx_sg_enable(struct wl1271 *wl); 1008int wl1271_acx_sg_enable(struct wl1271 *wl, bool enable);
1009int wl1271_acx_sg_cfg(struct wl1271 *wl); 1009int wl1271_acx_sg_cfg(struct wl1271 *wl);
1010int wl1271_acx_cca_threshold(struct wl1271 *wl); 1010int wl1271_acx_cca_threshold(struct wl1271 *wl);
1011int wl1271_acx_bcn_dtim_options(struct wl1271 *wl); 1011int wl1271_acx_bcn_dtim_options(struct wl1271 *wl);
diff --git a/drivers/net/wireless/wl12xx/wl1271_init.c b/drivers/net/wireless/wl12xx/wl1271_init.c
index d68445c9d333..d9335fc2a575 100644
--- a/drivers/net/wireless/wl12xx/wl1271_init.c
+++ b/drivers/net/wireless/wl12xx/wl1271_init.c
@@ -164,7 +164,7 @@ int wl1271_init_pta(struct wl1271 *wl)
164 if (ret < 0) 164 if (ret < 0)
165 return ret; 165 return ret;
166 166
167 ret = wl1271_acx_sg_enable(wl); 167 ret = wl1271_acx_sg_enable(wl, wl->sg_enabled);
168 if (ret < 0) 168 if (ret < 0)
169 return ret; 169 return ret;
170 170
diff --git a/drivers/net/wireless/wl12xx/wl1271_main.c b/drivers/net/wireless/wl12xx/wl1271_main.c
index ad9c49111678..abf9f22ee968 100644
--- a/drivers/net/wireless/wl12xx/wl1271_main.c
+++ b/drivers/net/wireless/wl12xx/wl1271_main.c
@@ -1982,6 +1982,68 @@ static const struct ieee80211_ops wl1271_ops = {
1982 CFG80211_TESTMODE_CMD(wl1271_tm_cmd) 1982 CFG80211_TESTMODE_CMD(wl1271_tm_cmd)
1983}; 1983};
1984 1984
1985static ssize_t wl1271_sysfs_show_bt_coex_state(struct device *dev,
1986 struct device_attribute *attr,
1987 char *buf)
1988{
1989 struct wl1271 *wl = dev_get_drvdata(dev);
1990 ssize_t len;
1991
1992 /* FIXME: what's the maximum length of buf? page size?*/
1993 len = 500;
1994
1995 mutex_lock(&wl->mutex);
1996 len = snprintf(buf, len, "%d\n\n0 - off\n1 - on\n",
1997 wl->sg_enabled);
1998 mutex_unlock(&wl->mutex);
1999
2000 return len;
2001
2002}
2003
2004static ssize_t wl1271_sysfs_store_bt_coex_state(struct device *dev,
2005 struct device_attribute *attr,
2006 const char *buf, size_t count)
2007{
2008 struct wl1271 *wl = dev_get_drvdata(dev);
2009 unsigned long res;
2010 int ret;
2011
2012 ret = strict_strtoul(buf, 10, &res);
2013
2014 if (ret < 0) {
2015 wl1271_warning("incorrect value written to bt_coex_mode");
2016 return count;
2017 }
2018
2019 mutex_lock(&wl->mutex);
2020
2021 res = !!res;
2022
2023 if (res == wl->sg_enabled)
2024 goto out;
2025
2026 wl->sg_enabled = res;
2027
2028 if (wl->state == WL1271_STATE_OFF)
2029 goto out;
2030
2031 ret = wl1271_ps_elp_wakeup(wl, false);
2032 if (ret < 0)
2033 goto out;
2034
2035 wl1271_acx_sg_enable(wl, wl->sg_enabled);
2036 wl1271_ps_elp_sleep(wl);
2037
2038 out:
2039 mutex_unlock(&wl->mutex);
2040 return count;
2041}
2042
2043static DEVICE_ATTR(bt_coex_state, S_IRUGO | S_IWUSR,
2044 wl1271_sysfs_show_bt_coex_state,
2045 wl1271_sysfs_store_bt_coex_state);
2046
1985int wl1271_register_hw(struct wl1271 *wl) 2047int wl1271_register_hw(struct wl1271 *wl)
1986{ 2048{
1987 int ret; 2049 int ret;
@@ -2073,6 +2135,7 @@ struct ieee80211_hw *wl1271_alloc_hw(void)
2073 wl->band = IEEE80211_BAND_2GHZ; 2135 wl->band = IEEE80211_BAND_2GHZ;
2074 wl->vif = NULL; 2136 wl->vif = NULL;
2075 wl->flags = 0; 2137 wl->flags = 0;
2138 wl->sg_enabled = true;
2076 2139
2077 for (i = 0; i < ACX_TX_DESCRIPTORS; i++) 2140 for (i = 0; i < ACX_TX_DESCRIPTORS; i++)
2078 wl->tx_frames[i] = NULL; 2141 wl->tx_frames[i] = NULL;
@@ -2095,9 +2158,18 @@ struct ieee80211_hw *wl1271_alloc_hw(void)
2095 } 2158 }
2096 dev_set_drvdata(&wl1271_device.dev, wl); 2159 dev_set_drvdata(&wl1271_device.dev, wl);
2097 2160
2161 /* Create sysfs file to control bt coex state */
2162 ret = device_create_file(&wl1271_device.dev, &dev_attr_bt_coex_state);
2163 if (ret < 0) {
2164 wl1271_error("failed to create sysfs file bt_coex_state");
2165 goto err_platform;
2166 }
2098 2167
2099 return hw; 2168 return hw;
2100 2169
2170err_platform:
2171 platform_device_unregister(&wl1271_device);
2172
2101err_hw: 2173err_hw:
2102 ieee80211_unregister_hw(wl->hw); 2174 ieee80211_unregister_hw(wl->hw);
2103 2175