some wificonf and wlcompat cleanups/fixes
SVN-Revision: 1631
This commit is contained in:
parent
200f0b3c15
commit
a2300375e4
2 changed files with 28 additions and 24 deletions
|
@ -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 */
|
||||||
|
|
|
@ -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, ®, sizeof(reg));
|
reg.val = bss_force << 16 | bss_force;
|
||||||
|
wl_ioctl(dev, WLC_W_REG, ®, sizeof(reg));
|
||||||
|
|
||||||
reg.val &= 0x0000ffff;
|
reg.byteoff = 0x180;
|
||||||
reg.val |= bss_force << 16;
|
wl_ioctl(dev, WLC_R_REG, ®, sizeof(reg));
|
||||||
|
reg.val = bss_force << 16;
|
||||||
wl_ioctl(dev, WLC_W_REG, ®, sizeof(reg));
|
wl_ioctl(dev, WLC_W_REG, ®, sizeof(reg));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue