softap: Add channel configuration parameter
Bug: 9372353
Change-Id: Id85a8a41f644195519f1635e4ab73806b5e1738e
Signed-off-by: Dmitry Shmidt <dimitrysh@google.com>
diff --git a/SoftapController.cpp b/SoftapController.cpp
index ad5721e..825a376 100644
--- a/SoftapController.cpp
+++ b/SoftapController.cpp
@@ -107,8 +107,9 @@
* argv[2] - wlan interface
* argv[3] - SSID
* argv[4] - Broadcast/Hidden
- * argv[5] - Security
- * argv[6] - Key
+ * argv[5] - Channel
+ * argv[6] - Security
+ * argv[7] - Key
*/
int SoftapController::setSoftap(int argc, char *argv[]) {
char psk_str[2*SHA256_DIGEST_LENGTH+1];
@@ -116,35 +117,42 @@
int i = 0;
int fd;
int hidden = 0;
+ int channel = AP_CHANNEL_DEFAULT;
char *wbuf = NULL;
char *fbuf = NULL;
if (argc < 5) {
ALOGE("Softap set is missing arguments. Please use:");
- ALOGE("softap <wlan iface> <SSID> <hidden/broadcast> <wpa2?-psk|open> <passphrase>");
+ ALOGE("softap <wlan iface> <SSID> <hidden/broadcast> <channel> <wpa2?-psk|open> <passphrase>");
return ResponseCode::CommandSyntaxError;
}
if (!strcasecmp(argv[4], "hidden"))
hidden = 1;
- asprintf(&wbuf, "interface=%s\ndriver=nl80211\nctrl_interface="
- "/data/misc/wifi/hostapd\nssid=%s\nchannel=6\nieee80211n=1\n"
- "hw_mode=g\nignore_broadcast_ssid=%d\n",
- argv[2], argv[3], hidden);
+ if (argc >= 5) {
+ channel = atoi(argv[5]);
+ if (channel <= 0)
+ channel = AP_CHANNEL_DEFAULT;
+ }
- if (argc > 6) {
- if (!strcmp(argv[5], "wpa-psk")) {
- generatePsk(argv[3], argv[6], psk_str);
+ asprintf(&wbuf, "interface=%s\ndriver=nl80211\nctrl_interface="
+ "/data/misc/wifi/hostapd\nssid=%s\nchannel=%d\nieee80211n=1\n"
+ "hw_mode=g\nignore_broadcast_ssid=%d\n",
+ argv[2], argv[3], channel, hidden);
+
+ if (argc > 7) {
+ if (!strcmp(argv[6], "wpa-psk")) {
+ generatePsk(argv[3], argv[7], psk_str);
asprintf(&fbuf, "%swpa=1\nwpa_pairwise=TKIP CCMP\nwpa_psk=%s\n", wbuf, psk_str);
- } else if (!strcmp(argv[5], "wpa2-psk")) {
- generatePsk(argv[3], argv[6], psk_str);
+ } else if (!strcmp(argv[6], "wpa2-psk")) {
+ generatePsk(argv[3], argv[7], psk_str);
asprintf(&fbuf, "%swpa=2\nrsn_pairwise=CCMP\nwpa_psk=%s\n", wbuf, psk_str);
- } else if (!strcmp(argv[5], "open")) {
+ } else if (!strcmp(argv[6], "open")) {
asprintf(&fbuf, "%s", wbuf);
}
- } else if (argc > 5) {
- if (!strcmp(argv[5], "open")) {
+ } else if (argc > 6) {
+ if (!strcmp(argv[6], "open")) {
asprintf(&fbuf, "%s", wbuf);
}
} else {