Compare commits

...

7 Commits

Author SHA1 Message Date
Steve Kondik
fc46d223c6 Merge branch 'LA.BF64.1.2.2_rb4.1' of git://codeaurora.org/platform/system/qcom into caf-merge 2015-10-12 09:53:07 -10:00
Skrilax_CZ
a51136993f Implement wifi_qsap_set_tx_power
Used by radio proprietary binaries from Motorola.

Change-Id: I9fd49cbba6001a4c7ddadf5cb88df06d6146f01a
2015-04-12 21:11:14 +02:00
Steve Kondik
595015ac77 qsap: Kill more logspam
Change-Id: I0a32abbf783ffb1534051fd89708d2a49014c6c3
2015-03-15 00:45:15 -07:00
Steve Kondik
69a004c094 qsap: Put files in a sane location
* And set their perms

Change-Id: Ifc61a3504433f6b7e1602432ecea70c37785c895
2015-03-15 00:45:15 -07:00
Steve Kondik
88df07cb5a qsap: Don't log sensitive information
Change-Id: I3ab6d73051d4647941de6eee41c2b5507c5eddc6
2015-03-15 00:45:15 -07:00
Linux Build Service Account
b8a71a5a88 Merge "wlan: Fix for OSS build compilation issue" 2015-02-12 04:39:25 -08:00
Mahesh A Saptasagar
f31a10d2e2 wlan: Fix for OSS build compilation issue
Do not include "wpa_ctrl.h" in qsap.c file to avoid compilation
errors on OSS builds.

Change-Id: Ie3afa0bc564a5b2d9c2245b85f4681b83c1d1644
CRs-Fixed: 758764
2015-01-11 09:05:15 -08:00
4 changed files with 76 additions and 26 deletions

View File

@@ -584,3 +584,45 @@ s32 wifi_qsap_reload_softap()
return eSUCCESS; return eSUCCESS;
} }
s32 wifi_qsap_set_tx_power(s32 tx_power)
{
#define QCSAP_IOCTL_SET_MAX_TX_POWER (SIOCIWFIRSTPRIV + 22)
s32 sock;
s32 ret = eERR_SET_TX_POWER;
s8 interface[128];
s8 *iface;
s32 len = 128;
struct iwreq wrq;
if(NULL == (iface = qsap_get_config_value(CONFIG_FILE, &qsap_str[STR_INTERFACE], interface, (u32*)&len))) {
ALOGE("%s :interface error \n", __func__);
return ret;
}
/* Issue QCSAP_IOCTL_SET_MAX_TX_POWER ioctl */
sock = socket(AF_INET, SOCK_DGRAM, 0);
if (sock < 0) {
ALOGE("%s :socket error \n", __func__);
return eERR_SET_TX_POWER;
}
strlcpy(wrq.ifr_name, iface, sizeof(wrq.ifr_name));
wrq.u.data.length = sizeof(s32);
wrq.u.data.pointer = &tx_power;
wrq.u.data.flags = 0;
ret = ioctl(sock, QCSAP_IOCTL_SET_MAX_TX_POWER, &wrq);
close(sock);
if (ret) {
ALOGE("%s :IOCTL set tx power failed: %ld\n", __func__, ret);
ret = eERR_SET_TX_POWER;
} else {
ALOGD("%s :IOCTL set tx power issued\n", __func__);
ret = eSUCCESS;
}
return ret;
}

View File

@@ -52,6 +52,8 @@ s32 wifi_qsap_start_softap_in_concurrency(void);
s32 wifi_qsap_stop_softap_in_concurrency(void); s32 wifi_qsap_stop_softap_in_concurrency(void);
#endif #endif
s32 wifi_qsap_set_tx_power(s32);
#if __cplusplus #if __cplusplus
}; // extern "C" }; // extern "C"
#endif #endif

View File

@@ -310,7 +310,7 @@ static s32 qsap_write_cfg(s8 *pfile, struct Command * pcmd, s8 *pVal, s8 *presp,
s8 buf[MAX_CONF_LINE_LEN+1]; s8 buf[MAX_CONF_LINE_LEN+1];
s16 len, result = FALSE; s16 len, result = FALSE;
ALOGD("cmd=%s, Val:%s, INI:%ld \n", pcmd->name, pVal, inifile); ALOGV("cmd=%s, Val:%s, INI:%ld \n", pcmd->name, pVal, inifile);
/** Open the configuration file */ /** Open the configuration file */
fcfg = fopen(pfile, "r"); fcfg = fopen(pfile, "r");
@@ -345,7 +345,7 @@ static s32 qsap_write_cfg(s8 *pfile, struct Command * pcmd, s8 *pVal, s8 *presp,
if(pline[len] == '=') { if(pline[len] == '=') {
qsap_scnprintf(buf, sizeof(buf), "%s=%s\n", pcmd->name, pVal); qsap_scnprintf(buf, sizeof(buf), "%s=%s\n", pcmd->name, pVal);
result = TRUE; result = TRUE;
ALOGD("Updated:%s\n", buf); ALOGV("Updated:%s\n", buf);
} }
} }
@@ -360,7 +360,7 @@ static s32 qsap_write_cfg(s8 *pfile, struct Command * pcmd, s8 *pVal, s8 *presp,
/* Add the new line at the end of file */ /* Add the new line at the end of file */
qsap_scnprintf(buf, sizeof(buf), "%s=%s\n", pcmd->name, pVal); qsap_scnprintf(buf, sizeof(buf), "%s=%s\n", pcmd->name, pVal);
fprintf(ftmp, "%s", buf); fprintf(ftmp, "%s", buf);
ALOGD("Adding a new line in %s file: [%s] \n", inifile ? "inifile" : "hostapd.conf", buf); ALOGV("Adding a new line in %s file: [%s] \n", inifile ? "inifile" : "hostapd.conf", buf);
} }
if(inifile) { if(inifile) {
@@ -972,7 +972,7 @@ static void qsap_remove_from_file(s8 *pfile, s8 *pVal, s8 *presp, u32 *plen)
*/ */
static void qsap_update_mac_list(s8 *pfile, esap_cmd_t cNum, s8 *pVal, s8 *presp, u32 *plen) static void qsap_update_mac_list(s8 *pfile, esap_cmd_t cNum, s8 *pVal, s8 *presp, u32 *plen)
{ {
ALOGD("%s : Updating file %s \n", __func__, pfile); ALOGV("%s : Updating file %s \n", __func__, pfile);
switch(cNum) { switch(cNum) {
case eCMD_ADD_TO_ALLOW: case eCMD_ADD_TO_ALLOW:
@@ -1127,7 +1127,7 @@ static int qsap_read_mac_address(s8 *presp, u32 *plen)
ptr++; ptr++;
ALOGD("MAC :%s \n", ptr); ALOGV("MAC :%s \n", ptr);
if(TRUE == isValid_MAC_address(ptr)) { if(TRUE == isValid_MAC_address(ptr)) {
nRet = eSUCCESS; nRet = eSUCCESS;
} }
@@ -1163,7 +1163,7 @@ static void qsap_read_wps_state(s8 *presp, u32 *plen)
if(NULL == (pstate = qsap_get_config_value(pconffile, &cmd_list[eCMD_WPS_STATE], presp, &tlen))) { if(NULL == (pstate = qsap_get_config_value(pconffile, &cmd_list[eCMD_WPS_STATE], presp, &tlen))) {
/** unable to read the wps configuration, WPS is disabled !*/ /** unable to read the wps configuration, WPS is disabled !*/
ALOGD("%s :wps_state not in cfg file \n", __func__); ALOGV("%s :wps_state not in cfg file \n", __func__);
status = DISABLE; status = DISABLE;
} }
else { else {
@@ -1218,9 +1218,9 @@ int qsap_get_operating_channel(s32 *pchan)
goto error; goto error;
} }
ALOGE("Recv len :%d \n", wrq.u.data.length); ALOGV("Recv len :%d \n", wrq.u.data.length);
*pchan = *(int *)(&wrq.u.name[0]); *pchan = *(int *)(&wrq.u.name[0]);
ALOGE("Operating channel :%ld \n", *pchan); ALOGV("Operating channel :%ld \n", *pchan);
close(sock); close(sock);
return eSUCCESS; return eSUCCESS;
@@ -1251,7 +1251,7 @@ int qsap_get_sap_auto_channel_selection(s32 *pautochan)
if(NULL == (pif = qsap_get_config_value(pconffile, if(NULL == (pif = qsap_get_config_value(pconffile,
&qsap_str[STR_INTERFACE], interface, &len))) { &qsap_str[STR_INTERFACE], interface, &len))) {
ALOGD("%s :interface error \n", __func__); ALOGV("%s :interface error \n", __func__);
goto error; goto error;
} }
@@ -1259,7 +1259,7 @@ int qsap_get_sap_auto_channel_selection(s32 *pautochan)
sock = socket(AF_INET, SOCK_DGRAM, 0); sock = socket(AF_INET, SOCK_DGRAM, 0);
if(sock < 0) { if(sock < 0) {
ALOGD("%s :socket error \n", __func__); ALOGV("%s :socket error \n", __func__);
goto error; goto error;
} }
@@ -1282,9 +1282,9 @@ int qsap_get_sap_auto_channel_selection(s32 *pautochan)
goto error; goto error;
} }
ALOGD("Recv len :%d \n", wrq.u.data.length); ALOGV("Recv len :%d \n", wrq.u.data.length);
*pautochan = *(int *)(&wrq.u.name[0]); *pautochan = *(int *)(&wrq.u.name[0]);
ALOGD("Sap auto channel selection pautochan=%ld \n", *pautochan); ALOGV("Sap auto channel selection pautochan=%ld \n", *pautochan);
close(sock); close(sock);
return eSUCCESS; return eSUCCESS;
@@ -1312,7 +1312,7 @@ int qsap_get_mode(s32 *pmode)
*pmode = -1; *pmode = -1;
if(NULL == (pif = qsap_get_config_value(pconffile, if(NULL == (pif = qsap_get_config_value(pconffile,
&qsap_str[STR_INTERFACE], interface, &len))) { &qsap_str[STR_INTERFACE], interface, &len))) {
ALOGD("%s :interface error \n", __func__); ALOGV("%s :interface error \n", __func__);
goto error; goto error;
} }
@@ -1320,7 +1320,7 @@ int qsap_get_mode(s32 *pmode)
sock = socket(AF_INET, SOCK_DGRAM, 0); sock = socket(AF_INET, SOCK_DGRAM, 0);
if(sock < 0) { if(sock < 0) {
ALOGD("%s :socket error \n", __func__); ALOGV("%s :socket error \n", __func__);
goto error; goto error;
} }
@@ -1424,7 +1424,7 @@ int qsap_set_channel_range(s8 *buf)
goto error; goto error;
} }
ALOGE("Recv len :%d\n", wrq.u.data.length); ALOGV("Recv len :%d\n", wrq.u.data.length);
close(sock); close(sock);
return eSUCCESS; return eSUCCESS;
@@ -1442,7 +1442,7 @@ int qsap_read_channel(s8 *pfile, struct Command *pcmd, s8 *presp, u32 *plen, s8
if(eSUCCESS == qsap_get_operating_channel(&chan)) { if(eSUCCESS == qsap_get_operating_channel(&chan)) {
*plen = qsap_scnprintf(presp, len, "%s %s=%lu", SUCCESS, pcmd->name, chan); *plen = qsap_scnprintf(presp, len, "%s %s=%lu", SUCCESS, pcmd->name, chan);
ALOGD("presp :%s\n", presp); ALOGV("presp :%s\n", presp);
} else { } else {
*plen = qsap_scnprintf(presp, len, "%s", ERR_UNKNOWN); *plen = qsap_scnprintf(presp, len, "%s", ERR_UNKNOWN);
} }
@@ -1922,7 +1922,7 @@ static s16 is_valid_wep_key(s8 *pwep, s8 *pkey, s16 len)
weplen--; weplen--;
while(weplen--) { while(weplen--) {
if(0 == isascii(pwep[weplen])) { if(0 == isascii(pwep[weplen])) {
ALOGD("%c not ascii \n", pwep[weplen]); ALOGV("%c not ascii \n", pwep[weplen]);
return FALSE; return FALSE;
} }
} }
@@ -1981,6 +1981,11 @@ s16 wifi_qsap_reset_to_default(s8 *pcfgfile, s8 *pdefault)
if(eERR_UNKNOWN == rename(buf, pcfgfile)) if(eERR_UNKNOWN == rename(buf, pcfgfile))
status = eERR_CONF_FILE; status = eERR_CONF_FILE;
if (chown(pcfgfile, AID_WIFI, AID_WIFI) < 0) {
ALOGE("Error changing group ownership of %s to %d: %s",
pcfgfile, AID_WIFI, strerror(errno));
}
/** Remove the temporary file. Dont care the return value */ /** Remove the temporary file. Dont care the return value */
unlink(buf); unlink(buf);
@@ -2063,7 +2068,7 @@ static int qsap_send_cmd_to_hostapd(s8 *pcmd)
goto error; goto error;
} }
ALOGD("Connect to :%s\n", ptr); ALOGV("Connect to :%s\n", ptr);
sock = socket(PF_UNIX, SOCK_DGRAM, 0); sock = socket(PF_UNIX, SOCK_DGRAM, 0);
if(sock < 0) { if(sock < 0) {
@@ -2083,7 +2088,7 @@ static int qsap_send_cmd_to_hostapd(s8 *pcmd)
ser.sun_family = AF_UNIX; ser.sun_family = AF_UNIX;
qsap_scnprintf(ser.sun_path, sizeof(ser.sun_path), "%s", ptr); qsap_scnprintf(ser.sun_path, sizeof(ser.sun_path), "%s", ptr);
ALOGD("Connect to: %s,(%d)\n", ser.sun_path, sock); ALOGV("Connect to: %s,(%d)\n", ser.sun_path, sock);
ret = connect(sock, (struct sockaddr *)&ser, sizeof(ser)); ret = connect(sock, (struct sockaddr *)&ser, sizeof(ser));
if(ret < 0) { if(ret < 0) {
@@ -2238,7 +2243,7 @@ static void qsap_config_wps_method(s8 *pVal, s8 *presp, u32 *plen)
qsap_scnprintf(buf, sizeof(buf), "WPS_PBC"); qsap_scnprintf(buf, sizeof(buf), "WPS_PBC");
else { else {
if(strlen(ptr) < WPS_KEY_LEN) { if(strlen(ptr) < WPS_KEY_LEN) {
ALOGD("%s :Invalid WPS key length\n", __func__); ALOGV("%s :Invalid WPS key length\n", __func__);
*plen = qsap_scnprintf(presp, *plen, "%s", ERR_INVALID_PARAM); *plen = qsap_scnprintf(presp, *plen, "%s", ERR_INVALID_PARAM);
return; return;
} }
@@ -3022,7 +3027,7 @@ static void qsap_handle_set_request(s8 *pcmd, s8 *presp, u32 *plen)
} }
if(ini == INI_CONF_FILE) { if(ini == INI_CONF_FILE) {
ALOGD("WRITE TO INI FILE :%s\n", qsap_str[cNum].name); ALOGV("WRITE TO INI FILE :%s\n", qsap_str[cNum].name);
qsap_write_cfg(fIni, &qsap_str[cNum], pVal, presp, plen, ini); qsap_write_cfg(fIni, &qsap_str[cNum], pVal, presp, plen, ini);
} }
else { else {
@@ -3051,7 +3056,7 @@ error:
*/ */
void qsap_hostd_exec_cmd(s8 *pcmd, s8 *presp, u32 *plen) void qsap_hostd_exec_cmd(s8 *pcmd, s8 *presp, u32 *plen)
{ {
ALOGD("CMD INPUT [%s][%lu]\n", pcmd, *plen); ALOGV("CMD INPUT [%s][%lu]\n", pcmd, *plen);
/* Skip any blank spaces */ /* Skip any blank spaces */
SKIP_BLANK_SPACE(pcmd); SKIP_BLANK_SPACE(pcmd);
@@ -3071,7 +3076,7 @@ void qsap_hostd_exec_cmd(s8 *pcmd, s8 *presp, u32 *plen)
*plen = qsap_scnprintf(presp, *plen, "%s", ERR_INVALIDREQ); *plen = qsap_scnprintf(presp, *plen, "%s", ERR_INVALIDREQ);
} }
ALOGD("CMD OUTPUT [%s]\nlen :%lu\n\n", presp, *plen); ALOGV("CMD OUTPUT [%s]\nlen :%lu\n\n", presp, *plen);
return; return;
} }
@@ -3100,10 +3105,10 @@ int qsapsetSoftap(int argc, char *argv[])
int hidden = 0; int hidden = 0;
int sec = SEC_MODE_NONE; int sec = SEC_MODE_NONE;
ALOGD("%s, %s, %s, %d\n", __FUNCTION__, argv[0], argv[1], argc); ALOGV("%s, %s, %s, %d\n", __FUNCTION__, argv[0], argv[1], argc);
for ( i=0; i<argc;i++) { for ( i=0; i<argc;i++) {
ALOGD("ARG: %d - %s\n", i+1, argv[i]); ALOGV("ARG: %d - %s\n", i+1, argv[i]);
} }
/** set SSID */ /** set SSID */

View File

@@ -77,7 +77,8 @@ enum error_val {
eERR_LOAD_FAILED_SDIOIF, eERR_LOAD_FAILED_SDIOIF,
eERR_LOAD_FAILED_SOFTAP, eERR_LOAD_FAILED_SOFTAP,
eERR_SET_CHAN_RANGE, eERR_SET_CHAN_RANGE,
eERR_GET_AUTO_CHAN eERR_GET_AUTO_CHAN,
eERR_SET_TX_POWER
}; };
#ifndef WIFI_DRIVER_CONF_FILE #ifndef WIFI_DRIVER_CONF_FILE