some wificonf and wlcompat cleanups/fixes

SVN-Revision: 1631
This commit is contained in:
Felix Fietkau 2005-08-13 15:46:11 +00:00
parent 200f0b3c15
commit a2300375e4
2 changed files with 28 additions and 24 deletions

View file

@ -80,6 +80,7 @@ void set_wext_ssid(int skfd, char *ifname);
char *prefix; char *prefix;
char buffer[128]; char buffer[128];
int wpa_enc = 0;
char *wl_var(char *name) char *wl_var(char *name)
{ {
@ -191,10 +192,9 @@ void setup_bcom(int skfd, char *ifname)
bcom_set_val(skfd, ifname, "afterburner_override", &val, sizeof(val)); bcom_set_val(skfd, ifname, "afterburner_override", &val, sizeof(val));
/* Set other options */ /* Set other options */
if (v = nvram_get(wl_var("lazywds"))) { val = nvram_enabled(wl_var("lazywds"));
val = atoi(v);
bcom_ioctl(skfd, ifname, WLC_SET_LAZYWDS, &val, sizeof(val)); bcom_ioctl(skfd, ifname, WLC_SET_LAZYWDS, &val, sizeof(val));
}
if (v = nvram_get(wl_var("frag"))) { if (v = nvram_get(wl_var("frag"))) {
val = atoi(v); val = atoi(v);
bcom_ioctl(skfd, ifname, WLC_SET_FRAG, &val, sizeof(val)); bcom_ioctl(skfd, ifname, WLC_SET_FRAG, &val, sizeof(val));
@ -316,6 +316,8 @@ void setup_bcom(int skfd, char *ifname)
v = nvram_safe_get(wl_var("auth_mode")); v = nvram_safe_get(wl_var("auth_mode"));
if (strstr(v, "wpa") || strstr(v, "psk")) { if (strstr(v, "wpa") || strstr(v, "psk")) {
wpa_enc = 1;
/* Set up WPA */ /* Set up WPA */
if (nvram_match(wl_var("crypto"), "tkip")) if (nvram_match(wl_var("crypto"), "tkip"))
val = TKIP_ENABLED; val = TKIP_ENABLED;
@ -355,30 +357,29 @@ void setup_bcom(int skfd, char *ifname)
bcom_ioctl(skfd, ifname, WLC_SET_WSEC, &val, sizeof(val)); bcom_ioctl(skfd, ifname, WLC_SET_WSEC, &val, sizeof(val));
bcom_ioctl(skfd, ifname, WLC_SET_WPA_AUTH, &val, sizeof(val)); bcom_ioctl(skfd, ifname, WLC_SET_WPA_AUTH, &val, sizeof(val));
bcom_ioctl(skfd, ifname, WLC_SET_EAP_RESTRICT, &val, sizeof(val));
bcom_set_int(skfd, ifname, "sup_wpa", 0);
} }
} }
void set_wext_ssid(int skfd, char *ifname) void set_wext_ssid(int skfd, char *ifname)
{ {
char *buffer; char *buffer;
char essid[IW_ESSID_MAX_SIZE + 1];
struct iwreq wrq; struct iwreq wrq;
if (buffer = nvram_get(wl_var("ssid"))) { buffer = nvram_get(wl_var("ssid"));
if (strlen(buffer) > IW_ESSID_MAX_SIZE) {
ABORT_ARG_SIZE("Set ESSID", SIOCSIWESSID, IW_ESSID_MAX_SIZE); if (!buffer || (strlen(buffer) > IW_ESSID_MAX_SIZE))
} else { buffer = "OpenWrt";
char essid[IW_ESSID_MAX_SIZE + 1];
wrq.u.essid.flags = 1; wrq.u.essid.flags = 1;
strcpy(essid, buffer); strcpy(essid, buffer);
wrq.u.essid.pointer = (caddr_t) essid; wrq.u.essid.pointer = (caddr_t) essid;
wrq.u.essid.length = strlen(essid) + 1; wrq.u.essid.length = strlen(essid) + 1;
IW_SET_EXT_ERR(skfd, ifname, SIOCSIWESSID, &wrq, "Set ESSID"); IW_SET_EXT_ERR(skfd, ifname, SIOCSIWESSID, &wrq, "Set ESSID");
}
}
} }
void setup_wext_wep(int skfd, char *ifname) void setup_wext_wep(int skfd, char *ifname)
{ {
int i, keylen; int i, keylen;
@ -387,6 +388,7 @@ void setup_wext_wep(int skfd, char *ifname)
char *keyval; char *keyval;
unsigned char key[IW_ENCODING_TOKEN_MAX]; unsigned char key[IW_ENCODING_TOKEN_MAX];
memset(&wrq, 0, sizeof(wrq));
strcpy(keystr, "key1"); strcpy(keystr, "key1");
for (i = 1; i <= 4; i++) { for (i = 1; i <= 4; i++) {
if (keyval = nvram_get(wl_var(keystr))) { if (keyval = nvram_get(wl_var(keystr))) {
@ -402,7 +404,7 @@ void setup_wext_wep(int skfd, char *ifname)
keystr[3]++; keystr[3]++;
} }
memset(&wrq, 0, sizeof(wrq));
i = atoi(nvram_safe_get(wl_var("key"))); i = atoi(nvram_safe_get(wl_var("key")));
if (i > 0 && i < 4) { if (i > 0 && i < 4) {
wrq.u.data.flags = i | IW_ENCODE_RESTRICTED; wrq.u.data.flags = i | IW_ENCODE_RESTRICTED;
@ -452,7 +454,7 @@ void setup_wext(int skfd, char *ifname)
IW_SET_EXT_ERR(skfd, ifname, SIOCSIWTXPOW, &wrq, "Set Tx Power"); IW_SET_EXT_ERR(skfd, ifname, SIOCSIWTXPOW, &wrq, "Set Tx Power");
/* Set up WEP */ /* Set up WEP */
if (nvram_enabled(wl_var("wep"))) if (nvram_enabled(wl_var("wep")) && !wpa_enc)
setup_wext_wep(skfd, ifname); setup_wext_wep(skfd, ifname);
/* Set ESSID */ /* Set ESSID */

View file

@ -360,10 +360,12 @@ static int wlcompat_ioctl(struct net_device *dev,
reg.size = 4; reg.size = 4;
reg.byteoff = 0x184; reg.byteoff = 0x184;
wl_ioctl(dev, WLC_R_REG, &reg, sizeof(reg)); reg.val = bss_force << 16 | bss_force;
wl_ioctl(dev, WLC_W_REG, &reg, sizeof(reg));
reg.val &= 0x0000ffff; reg.byteoff = 0x180;
reg.val |= bss_force << 16; wl_ioctl(dev, WLC_R_REG, &reg, sizeof(reg));
reg.val = bss_force << 16;
wl_ioctl(dev, WLC_W_REG, &reg, sizeof(reg)); wl_ioctl(dev, WLC_W_REG, &reg, sizeof(reg));
} }