|
|
|
@ -459,8 +459,15 @@ static int wlcompat_ioctl(struct net_device *dev, |
|
|
|
|
if (index < 0) |
|
|
|
|
index = get_primary_key(dev); |
|
|
|
|
|
|
|
|
|
if (wrqu->data.flags & IW_ENCODE_DISABLED) |
|
|
|
|
if (wrqu->data.flags & IW_ENCODE_DISABLED) { |
|
|
|
|
wep = 0; |
|
|
|
|
if (wl_ioctl(dev, WLC_SET_WSEC, &wep, sizeof(val)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
return 0; |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (wl_ioctl(dev, WLC_SET_WSEC, &wep, sizeof(val)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
|
|
|
|
|
if (wrqu->data.flags & IW_ENCODE_OPEN) |
|
|
|
|
wrestrict = 0; |
|
|
|
@ -479,18 +486,11 @@ static int wlcompat_ioctl(struct net_device *dev, |
|
|
|
|
} |
|
|
|
|
|
|
|
|
|
if (index >= 0) |
|
|
|
|
if (wl_ioctl(dev, WLC_SET_KEY_PRIMARY, &index, sizeof(index)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
wl_ioctl(dev, WLC_SET_KEY_PRIMARY, &index, sizeof(index)); |
|
|
|
|
|
|
|
|
|
if (wl_ioctl(dev, WLC_GET_WSEC, &val, sizeof(val)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
val |= wep; |
|
|
|
|
if (wl_ioctl(dev, WLC_SET_WSEC, &val, sizeof(val)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
|
|
|
|
|
if (wrestrict >= 0) |
|
|
|
|
if (wl_ioctl(dev, WLC_SET_WEP_RESTRICT, &wrestrict, sizeof(wrestrict)) < 0) |
|
|
|
|
return -EINVAL; |
|
|
|
|
wl_ioctl(dev, WLC_SET_WEP_RESTRICT, &wrestrict, sizeof(wrestrict)); |
|
|
|
|
|
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
case SIOCGIWENCODE: |
|
|
|
|