Compare commits
60 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| fc46d223c6 | |||
| c46bf72725 | |||
| bb81a3fc87 | |||
| a1c6f1dbe5 | |||
| cc16315997 | |||
| e1bfb737ad | |||
| cddacfa293 | |||
| e629e82bc8 | |||
| 650d036038 | |||
| fddc6bed07 | |||
| a51136993f | |||
| 4659de289b | |||
| 71846207cc | |||
| 595015ac77 | |||
| 69a004c094 | |||
| 88df07cb5a | |||
| b8a71a5a88 | |||
| f31a10d2e2 | |||
| 120aeacf0f | |||
| 64f15fc591 | |||
| d98f57876f | |||
| e9159df711 | |||
| 5620bb1611 | |||
| a9fe9d38bd | |||
| e601816b24 | |||
| 04a6a9712e | |||
| 56710aac73 | |||
| 9b8ed11141 | |||
| 92dd0a5d38 | |||
| f5fecdcc36 | |||
| 587b8b3d67 | |||
| 8e9475b346 | |||
| 00e8d69b78 | |||
| c4bcc0d420 | |||
| 005a67d5ca | |||
| 62ada8bd10 | |||
| e42000db1a | |||
| bcc62d3cca | |||
| 45c32d6e64 | |||
| 124fb55d96 | |||
| 1e7bd66054 | |||
| 8b0be84bab | |||
| 083d51563a | |||
| 87d01a1158 | |||
| e976b492fe | |||
| 0ecf7a3d93 | |||
| 549156b81d | |||
| 4a7a459864 | |||
| d289ef3449 | |||
| 396a3fe49d | |||
| 2addd175cc | |||
| fc7138812d | |||
| 4533339d61 | |||
| 69b91cc907 | |||
| ff6440b26f | |||
| 31088846f0 | |||
| 41f17f12e4 | |||
| bd4051d8ff | |||
| 1c4304379e | |||
| 7a2827f169 |
@@ -11,10 +11,10 @@ LOCAL_MODULE := libQWiFiSoftApCfg
|
|||||||
|
|
||||||
LOCAL_MODULE_TAGS := optional
|
LOCAL_MODULE_TAGS := optional
|
||||||
|
|
||||||
LOCAL_C_INCLUDES := $(KERNEL_HEADERS) \
|
LOCAL_C_INCLUDES += $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr/include \
|
||||||
$(JNI_H_INCLUDE)
|
$(JNI_H_INCLUDE)
|
||||||
|
|
||||||
|
LOCAL_ADDITIONAL_DEPENDENCIES := $(TARGET_OUT_INTERMEDIATES)/KERNEL_OBJ/usr
|
||||||
LOCAL_SHARED_LIBRARIES := libsysutils libcutils libnetutils libcrypto
|
LOCAL_SHARED_LIBRARIES := libsysutils libcutils libnetutils libcrypto
|
||||||
|
|
||||||
include $(BUILD_SHARED_LIBRARY)
|
include $(BUILD_SHARED_LIBRARY)
|
||||||
|
|
||||||
|
|||||||
@@ -319,7 +319,7 @@ JNIEXPORT jstring JNICALL
|
|||||||
char code[32] = {0};
|
char code[32] = {0};
|
||||||
int connect_retry;
|
int connect_retry;
|
||||||
|
|
||||||
strncpy(cmd, "softap qccmd ", sizeof(cmd));
|
strlcpy(cmd, "softap qccmd ", sizeof(cmd));
|
||||||
|
|
||||||
pcmd = (char *) ((*env)->GetStringUTFChars(env, jcmd, NULL));
|
pcmd = (char *) ((*env)->GetStringUTFChars(env, jcmd, NULL));
|
||||||
|
|
||||||
@@ -330,12 +330,12 @@ JNIEXPORT jstring JNICALL
|
|||||||
|
|
||||||
ALOGD("Received Command: %s\n", pcmd);
|
ALOGD("Received Command: %s\n", pcmd);
|
||||||
|
|
||||||
if ((strlen(cmd) + strlen(pcmd)) > sizeof(cmd)) {
|
if ((strlen(cmd) + strlen(pcmd)) >= sizeof(cmd)) {
|
||||||
UPDATE_ERROR_CODE("Command length is larger than MAX_CMD_SIZE", "");
|
UPDATE_ERROR_CODE("Command length is larger than MAX_CMD_SIZE", "");
|
||||||
goto end;
|
goto end;
|
||||||
}
|
}
|
||||||
|
|
||||||
strcat(cmd, pcmd);
|
strlcat(cmd, pcmd, sizeof(cmd));
|
||||||
|
|
||||||
connect_retry = 0;
|
connect_retry = 0;
|
||||||
|
|
||||||
|
|||||||
@@ -12,6 +12,10 @@ LOCAL_MODULE_TAGS := optional
|
|||||||
|
|
||||||
LOCAL_CFLAGS += -DSDK_VERSION=\"0.0.1.0\"
|
LOCAL_CFLAGS += -DSDK_VERSION=\"0.0.1.0\"
|
||||||
|
|
||||||
|
LOCAL_COPY_HEADERS_TO := sdk/softap/include
|
||||||
|
LOCAL_COPY_HEADERS := qsap_api.h
|
||||||
|
LOCAL_COPY_HEADERS += qsap.h
|
||||||
|
|
||||||
ifdef WIFI_DRIVER_MODULE_PATH
|
ifdef WIFI_DRIVER_MODULE_PATH
|
||||||
LOCAL_CFLAGS += -DWIFI_DRIVER_MODULE_PATH=\"$(WIFI_DRIVER_MODULE_PATH)\"
|
LOCAL_CFLAGS += -DWIFI_DRIVER_MODULE_PATH=\"$(WIFI_DRIVER_MODULE_PATH)\"
|
||||||
endif
|
endif
|
||||||
|
|||||||
Executable → Regular
+57
-20
@@ -54,7 +54,6 @@
|
|||||||
|
|
||||||
#include "qsap_api.h"
|
#include "qsap_api.h"
|
||||||
#include "qsap.h"
|
#include "qsap.h"
|
||||||
#include "libwpa_client/wpa_ctrl.h"
|
|
||||||
|
|
||||||
#include <sys/system_properties.h>
|
#include <sys/system_properties.h>
|
||||||
|
|
||||||
@@ -266,12 +265,12 @@ void qsap_send_module_down_indication(void)
|
|||||||
|
|
||||||
/* Equivalent to: iwpriv wlan0 sendModuleInd */
|
/* Equivalent to: iwpriv wlan0 sendModuleInd */
|
||||||
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) >= 0) {
|
if ((s = socket(PF_INET, SOCK_DGRAM, 0)) >= 0) {
|
||||||
strncpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
strlcpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
||||||
wrq.u.data.length = 0; /* No Set arguments */
|
wrq.u.data.length = 0; /* No Set arguments */
|
||||||
wrq.u.mode = 5; /* WE_MODULE_DOWN_IND sub-command */
|
wrq.u.mode = 5; /* WE_MODULE_DOWN_IND sub-command */
|
||||||
ret = ioctl(s, (SIOCIWFIRSTPRIV + 1), &wrq);
|
ret = ioctl(s, (SIOCIWFIRSTPRIV + 1), &wrq);
|
||||||
if (ret < 0 ) {
|
if (ret < 0 ) {
|
||||||
strncpy(wrq.ifr_name, "softap.0", IFNAMSIZ);
|
strlcpy(wrq.ifr_name, "softap.0", IFNAMSIZ);
|
||||||
ret = ioctl(s, (SIOCIWFIRSTPRIV + 1), &wrq);
|
ret = ioctl(s, (SIOCIWFIRSTPRIV + 1), &wrq);
|
||||||
if (ret < 0 ) {
|
if (ret < 0 ) {
|
||||||
ALOGE("ioctl failed: %s", strerror(errno));
|
ALOGE("ioctl failed: %s", strerror(errno));
|
||||||
@@ -295,7 +294,7 @@ s32 qsap_send_init_ap(void)
|
|||||||
|
|
||||||
/* Equivalent to: iwpriv wlan0 initAP */
|
/* Equivalent to: iwpriv wlan0 initAP */
|
||||||
if ((s = socket(AF_INET, SOCK_DGRAM, 0)) >= 0) {
|
if ((s = socket(AF_INET, SOCK_DGRAM, 0)) >= 0) {
|
||||||
strncpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
strlcpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
||||||
wrq.u.data.length = 0; /* No Set arguments */
|
wrq.u.data.length = 0; /* No Set arguments */
|
||||||
wrq.u.data.flags = 2; /* WE_INIT_AP sub-command */
|
wrq.u.data.flags = 2; /* WE_INIT_AP sub-command */
|
||||||
ret = ioctl(s, (SIOCIWFIRSTPRIV + 6), &wrq);
|
ret = ioctl(s, (SIOCIWFIRSTPRIV + 6), &wrq);
|
||||||
@@ -323,7 +322,7 @@ s32 qsap_send_exit_ap(void)
|
|||||||
|
|
||||||
/* Equivalent to: iwpriv wlan0 exitAP */
|
/* Equivalent to: iwpriv wlan0 exitAP */
|
||||||
if ((s = socket(AF_INET, SOCK_DGRAM, 0)) >= 0) {
|
if ((s = socket(AF_INET, SOCK_DGRAM, 0)) >= 0) {
|
||||||
strncpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
strlcpy(wrq.ifr_name, "wlan0", IFNAMSIZ);
|
||||||
wrq.u.data.length = 0; /* No Set arguments */
|
wrq.u.data.length = 0; /* No Set arguments */
|
||||||
wrq.u.data.flags = 3; /*WE_EXIT_AP sub-command */
|
wrq.u.data.flags = 3; /*WE_EXIT_AP sub-command */
|
||||||
|
|
||||||
@@ -409,7 +408,7 @@ s32 wifi_qsap_stop_bss(void)
|
|||||||
return eERR_STOP_BSS;
|
return eERR_STOP_BSS;
|
||||||
}
|
}
|
||||||
|
|
||||||
strncpy(wrq.ifr_name, iface, sizeof(wrq.ifr_name));
|
strlcpy(wrq.ifr_name, iface, sizeof(wrq.ifr_name));
|
||||||
wrq.u.data.length = sizeof(cmd);
|
wrq.u.data.length = sizeof(cmd);
|
||||||
wrq.u.data.pointer = cmd;
|
wrq.u.data.pointer = cmd;
|
||||||
wrq.u.data.flags = 0;
|
wrq.u.data.flags = 0;
|
||||||
@@ -434,26 +433,22 @@ s32 wifi_qsap_stop_bss(void)
|
|||||||
|
|
||||||
s32 is_softap_enabled(void)
|
s32 is_softap_enabled(void)
|
||||||
{
|
{
|
||||||
FILE *fp;
|
s32 mode = 0;
|
||||||
char buf[1024];
|
int ret;
|
||||||
|
|
||||||
fp = popen("ps", "r");
|
ret = qsap_get_mode(&mode);
|
||||||
if (fp == NULL) {
|
if (eSUCCESS != ret) {
|
||||||
ALOGE("Failed to open file");
|
ALOGD("Failed to get the mode of operation\n");
|
||||||
return eERR_UNKNOWN;
|
return eERR_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
|
||||||
while (fgets(buf, sizeof(buf)-1, fp) != NULL) {
|
if (mode == IW_MODE_MASTER) {
|
||||||
if(NULL !=(strstr(buf,"hostapd")))
|
ALOGD("HOSTAPD Enabled\n");
|
||||||
{
|
return ENABLE;
|
||||||
pclose(fp);
|
|
||||||
ALOGD("HOSTAPD enabled\n");
|
|
||||||
return ENABLE;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ALOGD("HOSTAPD disabled\n");
|
ALOGD("HOSTAPD Disabled\n");
|
||||||
pclose(fp);
|
|
||||||
return DISABLE;
|
return DISABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -589,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;
|
||||||
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Executable → Regular
+470
-300
File diff suppressed because it is too large
Load Diff
+15
-6
@@ -39,8 +39,8 @@ typedef unsigned char u8;
|
|||||||
typedef char s8;
|
typedef char s8;
|
||||||
typedef unsigned short int u16;
|
typedef unsigned short int u16;
|
||||||
typedef signed short int s16;
|
typedef signed short int s16;
|
||||||
typedef unsigned long int u32;
|
typedef unsigned int u32;
|
||||||
typedef signed long int s32;
|
typedef signed int s32;
|
||||||
|
|
||||||
/** Success and error messages */
|
/** Success and error messages */
|
||||||
#define SUCCESS "success"
|
#define SUCCESS "success"
|
||||||
@@ -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
|
||||||
@@ -98,19 +99,19 @@ enum error_val {
|
|||||||
#define DEFAULT_ACCEPT_LIST_FILE_PATH "/system/etc/hostapd/hostapd.accept"
|
#define DEFAULT_ACCEPT_LIST_FILE_PATH "/system/etc/hostapd/hostapd.accept"
|
||||||
|
|
||||||
/** Accept list file name */
|
/** Accept list file name */
|
||||||
#define ACCEPT_LIST_FILE "/data/hostapd/hostapd.accept"
|
#define ACCEPT_LIST_FILE "/data/misc/wifi/hostapd.accept"
|
||||||
|
|
||||||
/** Default Deny list file name */
|
/** Default Deny list file name */
|
||||||
#define DEFAULT_DENY_LIST_FILE_PATH "/system/etc/hostapd/hostapd.deny"
|
#define DEFAULT_DENY_LIST_FILE_PATH "/system/etc/hostapd/hostapd.deny"
|
||||||
|
|
||||||
/** Deny list file name */
|
/** Deny list file name */
|
||||||
#define DENY_LIST_FILE "/data/hostapd/hostapd.deny"
|
#define DENY_LIST_FILE "/data/misc/wifi/hostapd.deny"
|
||||||
|
|
||||||
/** Default Ini file */
|
/** Default Ini file */
|
||||||
#define DEFAULT_INI_FILE "/persist/qcom/softap/qcom_cfg_default.ini"
|
#define DEFAULT_INI_FILE "/persist/qcom/softap/qcom_cfg_default.ini"
|
||||||
|
|
||||||
/** SDK control interface path */
|
/** SDK control interface path */
|
||||||
#define SDK_CTRL_IF "/data/hostapd/softap_sdk_ctrl"
|
#define SDK_CTRL_IF "/data/misc/wifi/softap_sdk_ctrl"
|
||||||
|
|
||||||
/** Maximum length of the line in the configuration file */
|
/** Maximum length of the line in the configuration file */
|
||||||
#define MAX_CONF_LINE_LEN (156)
|
#define MAX_CONF_LINE_LEN (156)
|
||||||
@@ -323,6 +324,12 @@ typedef enum esap_cmd {
|
|||||||
eCMD_SET_CHANNEL_RANGE = 62,
|
eCMD_SET_CHANNEL_RANGE = 62,
|
||||||
eCMD_GET_AUTO_CHANNEL = 63,
|
eCMD_GET_AUTO_CHANNEL = 63,
|
||||||
eCMD_IEEE80211W = 64,
|
eCMD_IEEE80211W = 64,
|
||||||
|
eCMD_WPA_KEY_MGMT = 65,
|
||||||
|
eCMD_SET_MAX_CLIENTS = 66,
|
||||||
|
eCMD_IEEE80211AC = 67,
|
||||||
|
eCMD_VHT_OPER_CH_WIDTH = 68,
|
||||||
|
eCMD_ACS_CHAN_LIST = 69,
|
||||||
|
eCMD_HT_CAPAB = 70,
|
||||||
|
|
||||||
eCMD_LAST /** New command numbers should be added above this */
|
eCMD_LAST /** New command numbers should be added above this */
|
||||||
} esap_cmd_t;
|
} esap_cmd_t;
|
||||||
@@ -575,6 +582,7 @@ typedef struct sap_auto_channel_info {
|
|||||||
#define IS_VALID_ENERGY_DETECT_TH(x) ((((x >= AP_ENERGY_DETECT_TH_MIN) && (x <= AP_ENERGY_DETECT_TH_MAX)) ||( x == 128)) ? TRUE : FALSE)
|
#define IS_VALID_ENERGY_DETECT_TH(x) ((((x >= AP_ENERGY_DETECT_TH_MIN) && (x <= AP_ENERGY_DETECT_TH_MAX)) ||( x == 128)) ? TRUE : FALSE)
|
||||||
|
|
||||||
/** Function declartion */
|
/** Function declartion */
|
||||||
|
int qsap_hostd_exec(int argc, char ** argv);
|
||||||
void qsap_hostd_exec_cmd(s8 *pcmd, s8 *presp, u32 *plen);
|
void qsap_hostd_exec_cmd(s8 *pcmd, s8 *presp, u32 *plen);
|
||||||
s8 *qsap_get_config_value(s8 *pfile, struct Command *pcmd, s8 *pbuf, u32 *plen);
|
s8 *qsap_get_config_value(s8 *pfile, struct Command *pcmd, s8 *pbuf, u32 *plen);
|
||||||
int qsapsetSoftap(int argc, char *argv[]);
|
int qsapsetSoftap(int argc, char *argv[]);
|
||||||
@@ -584,6 +592,7 @@ void check_for_configuration_files(void);
|
|||||||
void qsap_set_ini_filename(void);
|
void qsap_set_ini_filename(void);
|
||||||
int qsap_set_channel_range(s8 * cmd);
|
int qsap_set_channel_range(s8 * cmd);
|
||||||
int qsap_get_sap_auto_channel_slection(s32 *pautochan);
|
int qsap_get_sap_auto_channel_slection(s32 *pautochan);
|
||||||
|
int qsap_get_mode(s32 *pmode);
|
||||||
|
|
||||||
#if __cplusplus
|
#if __cplusplus
|
||||||
}; // extern "C"
|
}; // extern "C"
|
||||||
|
|||||||
Reference in New Issue
Block a user