From 54fa2845dd8b6f6eb8b7d6a95b2e0b4b2d57a13e Mon Sep 17 00:00:00 2001 From: nbd Date: Wed, 1 Jun 2005 15:12:20 +0000 Subject: add function for enabling/disabling radio in wlcompat git-svn-id: svn://svn.openwrt.org/openwrt/trunk/openwrt@1129 3c298f89-4303-0410-b956-a3cf2f4a3e73 --- target/linux/package/wlcompat/wlcompat.c | 34 ++++++++++++++++++++++---------- 1 file changed, 24 insertions(+), 10 deletions(-) (limited to 'target/linux/package') diff --git a/target/linux/package/wlcompat/wlcompat.c b/target/linux/package/wlcompat/wlcompat.c index e39fe6889a..e3d42f5cbe 100644 --- a/target/linux/package/wlcompat/wlcompat.c +++ b/target/linux/package/wlcompat/wlcompat.c @@ -384,30 +384,44 @@ static int wlcompat_ioctl(struct net_device *dev, } case SIOCGIWTXPOW: { + int radio; + + if (wl_ioctl(dev, WLC_GET_RADIO, &radio, sizeof(int)) < 0) + return -EINVAL; + if (wl_get_val(dev, "qtxpower", &(wrqu->txpower.value), sizeof(int)) < 0) return -EINVAL; wrqu->txpower.value &= ~WL_TXPWR_OVERRIDE; wrqu->txpower.fixed = 0; - wrqu->txpower.disabled = 0; + wrqu->txpower.disabled = radio; wrqu->txpower.flags = IW_TXPOW_MWATT; break; } case SIOCSIWTXPOW: { - int override; - - if (wl_get_val(dev, "qtxpower", &override, sizeof(int)) < 0) + /* This is weird: WLC_SET_RADIO with 1 as argument disables the radio */ + int radio = wrqu->txpower.disabled; + + if (wl_ioctl(dev, WLC_SET_RADIO, &radio, sizeof(int)) < 0) return -EINVAL; - wrqu->txpower.value |= override & WL_TXPWR_OVERRIDE; - - if (wrqu->txpower.flags != IW_TXPOW_MWATT) - return -EINVAL; + if (!wrqu->txpower.disabled) { + int override; - if (wl_set_val(dev, "qtxpower", &wrqu->txpower.value, sizeof(int)) < 0) - return -EINVAL; + if (wl_get_val(dev, "qtxpower", &override, sizeof(int)) < 0) + return -EINVAL; + + wrqu->txpower.value |= override & WL_TXPWR_OVERRIDE; + + if (wrqu->txpower.flags != IW_TXPOW_MWATT) + return -EINVAL; + + if (wl_set_val(dev, "qtxpower", &wrqu->txpower.value, sizeof(int)) < 0) + return -EINVAL; + + } } case SIOCGIWENCODE: { -- cgit v1.2.3