From 7c831f6cc718c96b86e1350bf4866e71bd4dcd65 Mon Sep 17 00:00:00 2001 From: Felix Fietkau Date: Fri, 13 May 2005 19:12:22 +0000 Subject: [PATCH] add txant and antdiv to wlcompat SVN-Revision: 884 --- openwrt/package/openwrt/include/wlcompat.h | 4 ++ openwrt/package/openwrt/wlcompat.c | 50 +++++++++++++++++++++- 2 files changed, 53 insertions(+), 1 deletion(-) diff --git a/openwrt/package/openwrt/include/wlcompat.h b/openwrt/package/openwrt/include/wlcompat.h index e7ead452044..a4fc13439dd 100644 --- a/openwrt/package/openwrt/include/wlcompat.h +++ b/openwrt/package/openwrt/include/wlcompat.h @@ -28,5 +28,9 @@ #define WLCOMPAT_GET_MONITOR SIOCIWFIRSTPRIV + 1 #define WLCOMPAT_SET_TXPWR_LIMIT SIOCIWFIRSTPRIV + 2 #define WLCOMPAT_GET_TXPWR_LIMIT SIOCIWFIRSTPRIV + 3 +#define WLCOMPAT_SET_ANTDIV SIOCIWFIRSTPRIV + 4 +#define WLCOMPAT_GET_ANTDIV SIOCIWFIRSTPRIV + 5 +#define WLCOMPAT_SET_TXANT SIOCIWFIRSTPRIV + 6 +#define WLCOMPAT_GET_TXANT SIOCIWFIRSTPRIV + 7 #endif diff --git a/openwrt/package/openwrt/wlcompat.c b/openwrt/package/openwrt/wlcompat.c index 1719a67a7eb..18ec93468e1 100644 --- a/openwrt/package/openwrt/wlcompat.c +++ b/openwrt/package/openwrt/wlcompat.c @@ -599,6 +599,34 @@ static int wlcompat_private_ioctl(struct net_device *dev, break; } + case WLCOMPAT_SET_ANTDIV: + { + if (wl_ioctl(dev, WLC_SET_ANTDIV, value, sizeof(int)) < 0) + return -EINVAL; + + break; + } + case WLCOMPAT_GET_ANTDIV: + { + if (wl_ioctl(dev, WLC_GET_ANTDIV, extra, sizeof(int)) < 0) + return -EINVAL; + + break; + } + case WLCOMPAT_SET_TXANT: + { + if (wl_ioctl(dev, WLC_SET_TXANT, value, sizeof(int)) < 0) + return -EINVAL; + + break; + } + case WLCOMPAT_GET_TXANT: + { + if (wl_ioctl(dev, WLC_GET_TXANT, extra, sizeof(int)) < 0) + return -EINVAL; + + break; + } default: { return -EINVAL; @@ -629,7 +657,27 @@ static const struct iw_priv_args wlcompat_private_args[] = 0, IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, "get_txpwr_force" - } + }, + { WLCOMPAT_SET_ANTDIV, + IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, + 0, + "set_antdiv" + }, + { WLCOMPAT_GET_ANTDIV, + 0, + IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, + "get_antdiv" + }, + { WLCOMPAT_SET_TXANT, + IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, + 0, + "set_txant" + }, + { WLCOMPAT_GET_TXANT, + 0, + IW_PRIV_TYPE_INT | IW_PRIV_SIZE_FIXED | 1, + "get_txant" + }, }; static const iw_handler wlcompat_private[] =