X-Git-Url: http://git.ozo.com/?a=blobdiff_plain;f=package%2Fopenwrt%2Fwlcompat.c;h=d010e2bc87957a9eb6b49883bb576df4abae6c0e;hb=5fc8b3278edf24dbecf5740930de6fa239901b21;hp=01bfb0b43743a2ccc1ec2ddfcb26fd62c068e95d;hpb=b004f1eb9a8e4b9277cef0f9d6f72a34b663e82d;p=openwrt-10.03%2F.git diff --git a/package/openwrt/wlcompat.c b/package/openwrt/wlcompat.c index 01bfb0b43..d010e2bc8 100644 --- a/package/openwrt/wlcompat.c +++ b/package/openwrt/wlcompat.c @@ -314,10 +314,15 @@ static int wlcompat_ioctl(struct net_device *dev, } case SIOCSIWAP: { + int ap = 0; + if (wrqu->ap_addr.sa_family != ARPHRD_ETHER) return -EINVAL; - if (wl_ioctl(dev,WLC_SET_BSSID,wrqu->ap_addr.sa_data,6) < 0) + if (wl_ioctl(dev, WLC_GET_AP, &ap, sizeof(ap)) < 0) + return -EINVAL; + + if (wl_ioctl(dev, (ap ? WLC_SET_BSSID : WLC_REASSOC), wrqu->ap_addr.sa_data, 6) < 0) return -EINVAL; break;