#define INT_ROAMING _("[I] International roaming: ")
#define BEACON_PER _("[B] Beacon period (msec): ")
#define DTIM_I _("[D] DTIM sending interval (beacons): ")
-#define SIFS_T _("[T] SIFS time (msec): ")
+#define SIFS_T _("[T] SIFS time (2nd+ interframe spacing, usec): ")
#define WLAN_HELP _("[key] - set option; W - write conf; Q - quit to menu")
extern short ap_type, ap_vendorext;
char operInterRoaming[] = {
0x2B, 0x06, 0x01, 0x04, 0x01, 0xE0, 0x3E, 0x01, 0x02, 0x01, 0x0D, 0x00
};
- /* These two are ATMEL12350 TELLUS MIB specific. */
+ /* These two are ATMEL12350 GEMTEK MIB specific. */
char operBeaconPeriod[] = {
0x2B, 0x06, 0x01, 0x04, 0x01, 0xE0, 0x3E, 0x01, 0x02, 0x01, 0x0E, 0x00
};
char operDTIM[] = {
0x2B, 0x06, 0x01, 0x04, 0x01, 0xE0, 0x3E, 0x01, 0x02, 0x01, 0x0F, 0x00
};
- /* This one is ATMEL12350 VERNET MIB specific. */
+ /* This one is ATMEL12350 EZYNET MIB specific. */
char operSIFSTIME[] = {
0x2B, 0x06, 0x01, 0x04, 0x01, 0xE0, 0x3E, 0x01, 0x02, 0x01, 0x10, 0x00
};
unsigned char dtim, ch;
char *AuthenticationTypes[3] = { OSYS, SH_KEY, BOTH_TYPE },
message[1024];
- char domain[32], basic_rates[4], AutoRateFallBack, SSIDBroadcasting,
- ap_name[32], PreambleType, AuthenticationType, channel;
+ char domain[33], basic_rates[4], AutoRateFallBack, SSIDBroadcasting,
+ ap_name[33], PreambleType, AuthenticationType, channel;
char m_channel = 0, m_essid = 0, m_broadcast = 0, m_rts = 0,
m_fragment = 0, m_auth = 0, m_ap_name = 0, m_preambule = 0,
m_auto_rate = 0, m_inter_roaming = 0, m_beacon = 0, m_dtim = 0,
short __rates[4] = { 2, 4, 11, 22 };
int i, c = 0, rd_idx;
unsigned short ap_regdomain;
- struct sysDeviceInfo_ATMEL410 str410;
- struct sysDeviceInfo_ATMEL12350 str12350;
+ struct sysDeviceInfo_128 str128;
+ struct sysDeviceInfo_160 str160;
if (ap_type == ATMEL12350) {
varbinds[i++].oid = sysDeviceInfo;
if (ap_type == ATMEL12350) {
varbinds[i++].oid = operInterRoaming;
- if (ap_vendorext == TELLUS || ap_vendorext == VERNET) {
+ if (ap_vendorext == GEMTEK || ap_vendorext == EZYNET) {
varbinds[i++].oid = operBeaconPeriod;
varbinds[i++].oid = operDTIM;
}
- if (ap_vendorext == VERNET)
+ if (ap_vendorext == EZYNET)
varbinds[i++].oid = operSIFSTIME;
}
print_help(WAIT_RET);
- if (snmp(varbinds, i, GET) <= 0) {
+ if (snmp(varbinds, i, GET) < i) {
print_helperr(ERR_RET);
goto exit;
}
channel = *(varbinds[0].value);
c = *(varbinds[1].value);
memcpy(domain, varbinds[2].value, 32);
+ domain[32] = '\0';
SSIDBroadcasting = *(varbinds[3].value);
memcpy(basic_rates, varbinds[4].value, 4);
AutoRateFallBack = *(varbinds[5].value);
PreambleType = *(varbinds[8].value);
AuthenticationType = *(varbinds[9].value);
memcpy(ap_name, varbinds[10].value, 32);
+ ap_name[32] = '\0';
if (ap_type == ATMEL12350) {
InterRoaming = *(varbinds[12].value);
- if (ap_vendorext == TELLUS || ap_vendorext == VERNET) {
+ if (ap_vendorext == GEMTEK || ap_vendorext == EZYNET) {
BeaconPeriod = varbinds[13].len_val == 2 ?
(varbinds[13].value[0] << 8) | varbinds[13].value[1] :
varbinds[13].value[0] < 0x80 ?
varbinds[13].value[0] : 0xff00 | varbinds[13].value[0];
dtim = *(varbinds[14].value);
}
- if (ap_vendorext == VERNET)
+ if (ap_vendorext == EZYNET)
sifs = varbinds[15].len_val == 2 ?
(varbinds[15].value[0] << 8) | varbinds[15].value[1] :
varbinds[15].value[0] < 0x80 ?
varbinds[15].value[0] : 0xff00 | varbinds[15].value[0];
}
- if (ap_type == ATMEL12350) {
- memcpy(&str12350, varbinds[11].value,
- sizeof(struct sysDeviceInfo_ATMEL12350));
- ap_regdomain=str12350.RegulatoryDomain;
- } else /* ATMEL410 */{
- memcpy(&str410, varbinds[11].value,
- sizeof(struct sysDeviceInfo_ATMEL410));
- ap_regdomain = swap4(str410.RegulatoryDomain);
+ if (varbinds[11].len_val == 160) {
+ memcpy(&str160, varbinds[11].value,
+ sizeof(struct sysDeviceInfo_160));
+ ap_regdomain = str160.RegulatoryDomain;
+ } else { /* varbinds[11].len_val == 92 || varbinds[11].len_val == 128 */
+ memcpy(&str128, varbinds[11].value,
+ sizeof(struct sysDeviceInfo_128));
+ ap_regdomain = swap4(str128.RegulatoryDomain);
}
rd_idx = regdom_idx(ap_regdomain);
if (ap_type == ATMEL12350) {
sprintf(message, "%s%s", INT_ROAMING, (InterRoaming == 1) ? ON : OFF);
mvwaddstr(main_sub, 15, 0, message);
- if (ap_vendorext == TELLUS || ap_vendorext == VERNET) {
+ if (ap_vendorext == GEMTEK || ap_vendorext == EZYNET) {
sprintf(message, "%s%u", BEACON_PER, BeaconPeriod);
mvwaddstr(main_sub, 16, 0, message);
sprintf(message, "%s%u", DTIM_I, dtim);
mvwaddstr(main_sub, 17, 0, message);
}
- if (ap_vendorext == VERNET) {
+ if (ap_vendorext == EZYNET) {
sprintf(message, "%s%u", SIFS_T, sifs);
mvwaddstr(main_sub, 18, 0, message);
}
continue;
case 'N':
case 'n':
-// make_field(2, strlen(AP_NAME), 32);
- get_value(ap_name, 2, strlen(AP_NAME), -32, ANY_STRING, 0, 0, NULL);
+// make_field(2, strlen(AP_NAME), 33);
+ get_value(ap_name, 2, strlen(AP_NAME), -33, ANY_STRING, 0, 0, NULL);
m_ap_name = 1;
continue;
case 'E':
case 'e':
-// make_field(1, strlen(ESSID), 32);
- get_value(domain, 1, strlen(ESSID), 32, ANY_STRING, 0, 0, NULL);
+// make_field(1, strlen(ESSID), 33);
+ get_value(domain, 1, strlen(ESSID), 33, ANY_STRING, 0, 0, NULL);
m_essid = 1;
continue;
case 'F':
case 'f':
// make_field(4, strlen(FRG_TR), 6);
- get_value(message, 4, strlen(FRG_TR), 6, INT_STRING, 256, 2346,
+ get_value(message, 4, strlen(FRG_TR), 5, INT_STRING, 256, 2346,
WLAN_HELP);
FragmentationThreshold = atoi(message);
m_fragment = 1;
case 'R':
case 'r':
// make_field(3, strlen(RTS_TR), 6);
- get_value(message, 3, strlen(RTS_TR), 6, INT_STRING, 0, 2347,
+ get_value(message, 3, strlen(RTS_TR), 5, INT_STRING, 0, 2347,
WLAN_HELP);
RTSThreshold = atoi(message);
m_rts = 1;
continue;
case 'B':
case 'b':
- if (ap_vendorext != TELLUS && ap_vendorext != VERNET)
+ if (ap_vendorext != GEMTEK && ap_vendorext != EZYNET)
continue;
get_value(message, 16, strlen(BEACON_PER), 6, INT_STRING, 0, 65535,
WLAN_HELP);
continue;
case 'D':
case 'd':
- if (ap_vendorext != TELLUS && ap_vendorext != VERNET)
+ if (ap_vendorext != GEMTEK && ap_vendorext != EZYNET)
continue;
get_value(message, 17, strlen(DTIM_I), 4, INT_STRING, 0, 255,
WLAN_HELP);
continue;
case 'T':
case 't':
- if (ap_vendorext != VERNET)
+ if (ap_vendorext != EZYNET)
continue;
get_value(message, 18, strlen(SIFS_T), 6, INT_STRING, 0, 65535,
WLAN_HELP);
print_helperr(ERR_SET);
goto exit;
}
+ wbkgd(main_sub, A_NORMAL);
+ wrefresh(main_sub);
print_help(DONE_SET);
goto exit;
}
varbinds[7].oid = operAccessPointName;
varbinds[7].len_oid = sizeof(operAccessPointName);
print_help(WAIT_RET);
- if (snmp(varbinds, 8, GET) <= 0) {
+ if (snmp(varbinds, 8, GET) < 8) {
print_helperr(ERR_RET);
goto exit;
}
varbinds[8].oid = operAccessPointLocation;
varbinds[8].len_oid = sizeof(operAccessPointLocation);
- if (snmp(varbinds, 9, GET) <= 0) {
+ if (snmp(varbinds, 9, GET) < 9) {
print_helperr(ERR_RET);
goto exit;
}
continue;
case 'F':
case 'f':
- get_value(message, 4, strlen(FRG_TR), 6, INT_STRING, 256, 2346,
+ get_value(message, 4, strlen(FRG_TR), 5, INT_STRING, 256, 2346,
WLAN_HELP);
FragmentationThreshold = atoi(message);
m_fragment = 1;
continue;
case 'R':
case 'r':
- get_value(message, 3, strlen(RTS_TR), 6, INT_STRING, 0, 2347,
+ get_value(message, 3, strlen(RTS_TR), 5, INT_STRING, 0, 2347,
WLAN_HELP);
RTSThreshold = atoi(message);
m_rts = 1;
varbinds[i].type = 0x02;
i++;
}
-
if (m_basic_rates) {
varbinds[i].oid = operBasicRates;
varbinds[i].len_oid = sizeof(operBasicRates);
i++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, i, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
- i = 0;
+ print_help(WAIT_SET);
+ if (snmp(varbinds, i, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
+
+ i = 0;
if (m_auth) {
m_auth = (authi == 1) ? 2 : 1;
m_basic_rates = (authi == 0) ? 2 : 1;
varbinds[i].type = INT_VALUE;
i++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, i, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
- i = 0;
+ if (snmp(varbinds, i, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
+
+ i = 0;
if (m_ap_name) {
c = strlen(ap_name);
varbinds[i].oid = operAccessPointName;
varbinds[i].type = STRING_VALUE;
i++;
}
-
if (m_ap_location) {
c = strlen(ap_location);
varbinds[i].oid = operAccessPointLocation;
i++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, i, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
+ if (snmp(varbinds, i, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
i = 0;
if (m_ap_contact) {
varbinds[i].type = 0x02;
i++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, i, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
+
+ if (snmp(varbinds, i, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
+
c = 0;
for (i = 0; i < 4; i++)
if (m_antenna[i]) {
varbinds[c].type = INT_VALUE;
c++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, c, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
+
+ if (snmp(varbinds, c, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
+
c = 0;
for (i = i; i < 6; i++)
if (m_antenna[i]) {
varbinds[c].type = INT_VALUE;
c++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, c, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
+
+ if (snmp(varbinds, c, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
}
+
i = 0;
if (m_essid) {
c = strlen(domain);
varbinds[i].type = 0x04;
i++;
}
- print_help(WAIT_SET);
- if (snmp(varbinds, i, SET) <= 0) {
- print_helperr(ERR_SET);
- goto exit;
- }
+ if (snmp(varbinds, i, SET) <= 0) {
+ print_helperr(ERR_SET);
+ goto exit;
+ }
+
+ wbkgd(main_sub, A_NORMAL);
+ wrefresh(main_sub);
print_help(DONE_SET);
goto exit;
default: