diff options
author | Felix Fietkau <nbd@openwrt.org> | 2005-06-01 15:12:20 +0000 |
---|---|---|
committer | Felix Fietkau <nbd@openwrt.org> | 2005-06-01 15:12:20 +0000 |
commit | 43e5060743a5558d435d9f4c7052322039f50c82 (patch) | |
tree | 6b397375c32bdaf57390eea4b27de8e0ccfa4b9f /openwrt/target | |
parent | f1aeb6c8f2cf8555ad3c5b53704108a3a9181465 (diff) | |
download | mtk-20170518-43e5060743a5558d435d9f4c7052322039f50c82.zip mtk-20170518-43e5060743a5558d435d9f4c7052322039f50c82.tar.gz mtk-20170518-43e5060743a5558d435d9f4c7052322039f50c82.tar.bz2 |
add function for enabling/disabling radio in wlcompat
SVN-Revision: 1129
Diffstat (limited to 'openwrt/target')
-rw-r--r-- | openwrt/target/linux/package/wlcompat/wlcompat.c | 34 |
1 files changed, 24 insertions, 10 deletions
diff --git a/openwrt/target/linux/package/wlcompat/wlcompat.c b/openwrt/target/linux/package/wlcompat/wlcompat.c index e39fe68..e3d42f5 100644 --- a/openwrt/target/linux/package/wlcompat/wlcompat.c +++ b/openwrt/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: { |