summaryrefslogtreecommitdiffstats
path: root/wifi/wifi.c
diff options
context:
space:
mode:
Diffstat (limited to 'wifi/wifi.c')
-rw-r--r--wifi/wifi.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/wifi/wifi.c b/wifi/wifi.c
index 7418fb1..fc1b400 100644
--- a/wifi/wifi.c
+++ b/wifi/wifi.c
@@ -81,6 +81,7 @@ static struct wpa_ctrl *monitor_conn;
/* socket pair used to exit from a blocking read */
static int exit_sockets[2];
+static int wifi_mode = 0;
static char primary_iface[PROPERTY_VALUE_MAX];
// TODO: use new ANDROID_SOCKET mechanism, once support for multiple
@@ -96,6 +97,9 @@ struct genl_family *nl80211;
#ifndef WIFI_DRIVER_MODULE_ARG
#define WIFI_DRIVER_MODULE_ARG ""
#endif
+#ifndef WIFI_DRIVER_MODULE_AP_ARG
+#define WIFI_DRIVER_MODULE_AP_ARG ""
+#endif
#ifndef WIFI_FIRMWARE_LOADER
#define WIFI_FIRMWARE_LOADER ""
#endif
@@ -123,6 +127,7 @@ static const char DRIVER_MODULE_NAME[] = WIFI_DRIVER_MODULE_NAME;
static const char DRIVER_MODULE_TAG[] = WIFI_DRIVER_MODULE_NAME " ";
static const char DRIVER_MODULE_PATH[] = WIFI_DRIVER_MODULE_PATH;
static const char DRIVER_MODULE_ARG[] = WIFI_DRIVER_MODULE_ARG;
+static const char DRIVER_MODULE_AP_ARG[] = WIFI_DRIVER_MODULE_AP_ARG;
#endif
static const char FIRMWARE_LOADER[] = WIFI_FIRMWARE_LOADER;
static const char DRIVER_PROP_NAME[] = "wlan.driver.status";
@@ -303,8 +308,16 @@ int wifi_load_driver()
char module_arg2[256];
#ifdef SAMSUNG_WIFI
+#ifdef WIFI_DRIVER_MODULE_AP_ARG
+ if (wifi_mode == 1) {
+ snprintf(module_arg2, sizeof(module_arg2), DRIVER_MODULE_AP_ARG);
+ } else {
+ snprintf(module_arg2, sizeof(module_arg2), DRIVER_MODULE_ARG);
+ }
+#else
char* type = get_samsung_wifi_type();
snprintf(module_arg2, sizeof(module_arg2), "%s%s", DRIVER_MODULE_ARG, type == NULL ? "" : type);
+#endif
if (insmod(DRIVER_MODULE_PATH, module_arg2) < 0) {
#else
@@ -1123,3 +1136,8 @@ int wifi_change_fw_path(const char *fwpath)
close(fd);
return ret;
}
+
+int wifi_set_mode(int mode) {
+ wifi_mode = mode;
+ return 0;
+}