wlan_cmd.c 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593
  1. /*
  2. * Copyright (c) 2006-2021, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2018-08-13 tyx the first version
  9. */
  10. #include <rtthread.h>
  11. #include <wlan_mgnt.h>
  12. #include <wlan_cfg.h>
  13. #include <wlan_prot.h>
  14. #if defined(RT_WLAN_MANAGE_ENABLE) && defined(RT_WLAN_MSH_CMD_ENABLE)
  15. struct wifi_cmd_des
  16. {
  17. const char *cmd;
  18. int (*fun)(int argc, char *argv[]);
  19. };
  20. static int wifi_help(int argc, char *argv[]);
  21. static int wifi_scan(int argc, char *argv[]);
  22. static int wifi_status(int argc, char *argv[]);
  23. static int wifi_join(int argc, char *argv[]);
  24. static int wifi_ap(int argc, char *argv[]);
  25. static int wifi_list_sta(int argc, char *argv[]);
  26. static int wifi_disconnect(int argc, char *argv[]);
  27. static int wifi_ap_stop(int argc, char *argv[]);
  28. #ifdef RT_WLAN_CMD_DEBUG
  29. /* just for debug */
  30. static int wifi_debug(int argc, char *argv[]);
  31. static int wifi_debug_save_cfg(int argc, char *argv[]);
  32. static int wifi_debug_dump_cfg(int argc, char *argv[]);
  33. static int wifi_debug_clear_cfg(int argc, char *argv[]);
  34. static int wifi_debug_dump_prot(int argc, char *argv[]);
  35. static int wifi_debug_set_mode(int argc, char *argv[]);
  36. static int wifi_debug_set_prot(int argc, char *argv[]);
  37. static int wifi_debug_set_autoconnect(int argc, char *argv[]);
  38. #endif
  39. /* cmd table */
  40. static const struct wifi_cmd_des cmd_tab[] =
  41. {
  42. {"scan", wifi_scan},
  43. {"help", wifi_help},
  44. {"status", wifi_status},
  45. {"join", wifi_join},
  46. {"ap", wifi_ap},
  47. {"list_sta", wifi_list_sta},
  48. {"disc", wifi_disconnect},
  49. {"ap_stop", wifi_ap_stop},
  50. {"smartconfig", RT_NULL},
  51. #ifdef RT_WLAN_CMD_DEBUG
  52. {"-d", wifi_debug},
  53. #endif
  54. };
  55. #ifdef RT_WLAN_CMD_DEBUG
  56. /* debug cmd table */
  57. static const struct wifi_cmd_des debug_tab[] =
  58. {
  59. {"save_cfg", wifi_debug_save_cfg},
  60. {"dump_cfg", wifi_debug_dump_cfg},
  61. {"clear_cfg", wifi_debug_clear_cfg},
  62. {"dump_prot", wifi_debug_dump_prot},
  63. {"mode", wifi_debug_set_mode},
  64. {"prot", wifi_debug_set_prot},
  65. {"auto", wifi_debug_set_autoconnect},
  66. };
  67. #endif
  68. static int wifi_help(int argc, char *argv[])
  69. {
  70. rt_kprintf("wifi\n");
  71. rt_kprintf("wifi help\n");
  72. rt_kprintf("wifi scan [SSID]\n");
  73. rt_kprintf("wifi join [SSID] [PASSWORD]\n");
  74. rt_kprintf("wifi ap SSID [PASSWORD]\n");
  75. rt_kprintf("wifi disc\n");
  76. rt_kprintf("wifi ap_stop\n");
  77. rt_kprintf("wifi status\n");
  78. rt_kprintf("wifi smartconfig\n");
  79. #ifdef RT_WLAN_CMD_DEBUG
  80. rt_kprintf("wifi -d debug command\n");
  81. #endif
  82. return 0;
  83. }
  84. static int wifi_status(int argc, char *argv[])
  85. {
  86. int rssi;
  87. struct rt_wlan_info info;
  88. if (argc > 2)
  89. return -1;
  90. if (rt_wlan_is_connected() == 1)
  91. {
  92. rssi = rt_wlan_get_rssi();
  93. rt_wlan_get_info(&info);
  94. rt_kprintf("Wi-Fi STA Info\n");
  95. rt_kprintf("SSID : %-.32s\n", &info.ssid.val[0]);
  96. rt_kprintf("MAC Addr: %02x:%02x:%02x:%02x:%02x:%02x\n", info.bssid[0],
  97. info.bssid[1],
  98. info.bssid[2],
  99. info.bssid[3],
  100. info.bssid[4],
  101. info.bssid[5]);
  102. rt_kprintf("Channel: %d\n", info.channel);
  103. rt_kprintf("DataRate: %dMbps\n", info.datarate / 1000000);
  104. rt_kprintf("RSSI: %d\n", rssi);
  105. }
  106. else
  107. {
  108. rt_kprintf("wifi disconnected!\n");
  109. }
  110. if (rt_wlan_ap_is_active() == 1)
  111. {
  112. rt_wlan_ap_get_info(&info);
  113. rt_kprintf("Wi-Fi AP Info\n");
  114. rt_kprintf("SSID : %-.32s\n", &info.ssid.val[0]);
  115. rt_kprintf("MAC Addr: %02x:%02x:%02x:%02x:%02x:%02x\n", info.bssid[0],
  116. info.bssid[1],
  117. info.bssid[2],
  118. info.bssid[3],
  119. info.bssid[4],
  120. info.bssid[5]);
  121. rt_kprintf("Channel: %d\n", info.channel);
  122. rt_kprintf("DataRate: %dMbps\n", info.datarate / 1000000);
  123. rt_kprintf("hidden: %s\n", info.hidden ? "Enable" : "Disable");
  124. }
  125. else
  126. {
  127. rt_kprintf("wifi ap not start!\n");
  128. }
  129. rt_kprintf("Auto Connect status:%s!\n", (rt_wlan_get_autoreconnect_mode() ? "Enable" : "Disable"));
  130. return 0;
  131. }
  132. static int wifi_scan(int argc, char *argv[])
  133. {
  134. struct rt_wlan_scan_result *scan_result = RT_NULL;
  135. struct rt_wlan_info *info = RT_NULL;
  136. struct rt_wlan_info filter;
  137. if (argc > 3)
  138. return -1;
  139. if (argc == 3)
  140. {
  141. INVALID_INFO(&filter);
  142. SSID_SET(&filter, argv[2]);
  143. info = &filter;
  144. }
  145. /* clean scan result */
  146. rt_wlan_scan_result_clean();
  147. /* scan ap info */
  148. scan_result = rt_wlan_scan_with_info(info);
  149. if (scan_result)
  150. {
  151. int index, num;
  152. char *security;
  153. num = scan_result->num;
  154. rt_kprintf(" SSID MAC security rssi chn Mbps\n");
  155. rt_kprintf("------------------------------- ----------------- -------------- ---- --- ----\n");
  156. for (index = 0; index < num; index ++)
  157. {
  158. rt_kprintf("%-32.32s", &scan_result->info[index].ssid.val[0]);
  159. rt_kprintf("%02x:%02x:%02x:%02x:%02x:%02x ",
  160. scan_result->info[index].bssid[0],
  161. scan_result->info[index].bssid[1],
  162. scan_result->info[index].bssid[2],
  163. scan_result->info[index].bssid[3],
  164. scan_result->info[index].bssid[4],
  165. scan_result->info[index].bssid[5]
  166. );
  167. switch (scan_result->info[index].security)
  168. {
  169. case SECURITY_OPEN:
  170. security = "OPEN";
  171. break;
  172. case SECURITY_WEP_PSK:
  173. security = "WEP_PSK";
  174. break;
  175. case SECURITY_WEP_SHARED:
  176. security = "WEP_SHARED";
  177. break;
  178. case SECURITY_WPA_TKIP_PSK:
  179. security = "WPA_TKIP_PSK";
  180. break;
  181. case SECURITY_WPA_AES_PSK:
  182. security = "WPA_AES_PSK";
  183. break;
  184. case SECURITY_WPA2_AES_PSK:
  185. security = "WPA2_AES_PSK";
  186. break;
  187. case SECURITY_WPA2_TKIP_PSK:
  188. security = "WPA2_TKIP_PSK";
  189. break;
  190. case SECURITY_WPA2_MIXED_PSK:
  191. security = "WPA2_MIXED_PSK";
  192. break;
  193. case SECURITY_WPS_OPEN:
  194. security = "WPS_OPEN";
  195. break;
  196. case SECURITY_WPS_SECURE:
  197. security = "WPS_SECURE";
  198. break;
  199. default:
  200. security = "UNKNOWN";
  201. break;
  202. }
  203. rt_kprintf("%-14.14s ", security);
  204. rt_kprintf("%-4d ", scan_result->info[index].rssi);
  205. rt_kprintf("%3d ", scan_result->info[index].channel);
  206. rt_kprintf("%4d\n", scan_result->info[index].datarate / 1000000);
  207. }
  208. rt_wlan_scan_result_clean();
  209. }
  210. else
  211. {
  212. rt_kprintf("wifi scan result is null\n");
  213. }
  214. return 0;
  215. }
  216. static int wifi_join(int argc, char *argv[])
  217. {
  218. const char *ssid = RT_NULL;
  219. const char *key = RT_NULL;
  220. struct rt_wlan_cfg_info cfg_info;
  221. rt_memset(&cfg_info, 0, sizeof(cfg_info));
  222. if (argc == 2)
  223. {
  224. #ifdef RT_WLAN_CFG_ENABLE
  225. /* get info to connect */
  226. if (rt_wlan_cfg_read_index(&cfg_info, 0) == 1)
  227. {
  228. ssid = (char *)(&cfg_info.info.ssid.val[0]);
  229. if (cfg_info.key.len)
  230. key = (char *)(&cfg_info.key.val[0]);
  231. }
  232. else
  233. #endif
  234. {
  235. rt_kprintf("not find connect info\n");
  236. }
  237. }
  238. else if (argc == 3)
  239. {
  240. /* ssid */
  241. ssid = argv[2];
  242. }
  243. else if (argc == 4)
  244. {
  245. ssid = argv[2];
  246. /* password */
  247. key = argv[3];
  248. }
  249. else
  250. {
  251. return -1;
  252. }
  253. rt_wlan_connect(ssid, key);
  254. return 0;
  255. }
  256. static int wifi_ap(int argc, char *argv[])
  257. {
  258. const char *ssid = RT_NULL;
  259. const char *key = RT_NULL;
  260. if (argc == 3)
  261. {
  262. ssid = argv[2];
  263. }
  264. else if (argc == 4)
  265. {
  266. ssid = argv[2];
  267. key = argv[3];
  268. }
  269. else
  270. {
  271. return -1;
  272. }
  273. rt_wlan_start_ap(ssid, key);
  274. return 0;
  275. }
  276. static int wifi_list_sta(int argc, char *argv[])
  277. {
  278. struct rt_wlan_info *sta_info;
  279. int num, i;
  280. if (argc > 2)
  281. return -1;
  282. num = rt_wlan_ap_get_sta_num();
  283. sta_info = rt_malloc(sizeof(struct rt_wlan_info) * num);
  284. if (sta_info == RT_NULL)
  285. {
  286. rt_kprintf("num:%d\n", num);
  287. return 0;
  288. }
  289. rt_wlan_ap_get_sta_info(sta_info, num);
  290. rt_kprintf("num:%d\n", num);
  291. for (i = 0; i < num; i++)
  292. {
  293. rt_kprintf("sta mac %02x:%02x:%02x:%02x:%02x:%02x\n",
  294. sta_info[i].bssid[0], sta_info[i].bssid[1], sta_info[i].bssid[2],
  295. sta_info[i].bssid[3], sta_info[i].bssid[4], sta_info[i].bssid[5]);
  296. }
  297. rt_free(sta_info);
  298. return 0;
  299. }
  300. static int wifi_disconnect(int argc, char *argv[])
  301. {
  302. if (argc != 2)
  303. {
  304. return -1;
  305. }
  306. rt_wlan_disconnect();
  307. return 0;
  308. }
  309. static int wifi_ap_stop(int argc, char *argv[])
  310. {
  311. if (argc != 2)
  312. {
  313. return -1;
  314. }
  315. rt_wlan_ap_stop();
  316. return 0;
  317. }
  318. #ifdef RT_WLAN_CMD_DEBUG
  319. /* just for debug */
  320. static int wifi_debug_help(int argc, char *argv[])
  321. {
  322. rt_kprintf("save_cfg ssid [password]\n");
  323. rt_kprintf("dump_cfg\n");
  324. rt_kprintf("clear_cfg\n");
  325. rt_kprintf("dump_prot\n");
  326. rt_kprintf("mode sta/ap dev_name\n");
  327. rt_kprintf("prot lwip dev_name\n");
  328. rt_kprintf("auto enable/disable\n");
  329. return 0;
  330. }
  331. static int wifi_debug_save_cfg(int argc, char *argv[])
  332. {
  333. struct rt_wlan_cfg_info cfg_info;
  334. int len;
  335. char *ssid = RT_NULL, *password = RT_NULL;
  336. rt_memset(&cfg_info, 0, sizeof(cfg_info));
  337. INVALID_INFO(&cfg_info.info);
  338. if (argc == 2)
  339. {
  340. ssid = argv[1];
  341. }
  342. else if (argc == 3)
  343. {
  344. ssid = argv[1];
  345. password = argv[2];
  346. }
  347. else
  348. {
  349. return -1;
  350. }
  351. if (ssid != RT_NULL)
  352. {
  353. len = rt_strlen(ssid);
  354. if (len > RT_WLAN_SSID_MAX_LENGTH)
  355. {
  356. rt_kprintf("ssid is to long");
  357. return 0;
  358. }
  359. rt_memcpy(&cfg_info.info.ssid.val[0], ssid, len);
  360. cfg_info.info.ssid.len = len;
  361. }
  362. if (password != RT_NULL)
  363. {
  364. len = rt_strlen(password);
  365. if (len > RT_WLAN_PASSWORD_MAX_LENGTH)
  366. {
  367. rt_kprintf("password is to long");
  368. return 0;
  369. }
  370. rt_memcpy(&cfg_info.key.val[0], password, len);
  371. cfg_info.key.len = len;
  372. }
  373. #ifdef RT_WLAN_CFG_ENABLE
  374. rt_wlan_cfg_save(&cfg_info);
  375. #endif
  376. return 0;
  377. }
  378. static int wifi_debug_dump_cfg(int argc, char *argv[])
  379. {
  380. if (argc == 1)
  381. {
  382. #ifdef RT_WLAN_CFG_ENABLE
  383. rt_wlan_cfg_dump();
  384. #endif
  385. }
  386. else
  387. {
  388. return -1;
  389. }
  390. return 0;
  391. }
  392. static int wifi_debug_clear_cfg(int argc, char *argv[])
  393. {
  394. if (argc == 1)
  395. {
  396. #ifdef RT_WLAN_CFG_ENABLE
  397. rt_wlan_cfg_delete_all();
  398. rt_wlan_cfg_cache_save();
  399. #endif
  400. }
  401. else
  402. {
  403. return -1;
  404. }
  405. return 0;
  406. }
  407. static int wifi_debug_dump_prot(int argc, char *argv[])
  408. {
  409. if (argc == 1)
  410. {
  411. rt_wlan_prot_dump();
  412. }
  413. else
  414. {
  415. return -1;
  416. }
  417. return 0;
  418. }
  419. static int wifi_debug_set_mode(int argc, char *argv[])
  420. {
  421. rt_wlan_mode_t mode;
  422. if (argc != 3)
  423. return -1;
  424. if (rt_strcmp("sta", argv[1]) == 0)
  425. {
  426. mode = RT_WLAN_STATION;
  427. }
  428. else if (rt_strcmp("ap", argv[1]) == 0)
  429. {
  430. mode = RT_WLAN_AP;
  431. }
  432. else if (rt_strcmp("none", argv[1]) == 0)
  433. {
  434. mode = RT_WLAN_NONE;
  435. }
  436. else
  437. return -1;
  438. rt_wlan_set_mode(argv[2], mode);
  439. return 0;
  440. }
  441. static int wifi_debug_set_prot(int argc, char *argv[])
  442. {
  443. if (argc != 3)
  444. {
  445. return -1;
  446. }
  447. rt_wlan_prot_attach(argv[2], argv[1]);
  448. return 0;
  449. }
  450. static int wifi_debug_set_autoconnect(int argc, char *argv[])
  451. {
  452. if (argc == 2)
  453. {
  454. if (rt_strcmp(argv[1], "enable") == 0)
  455. rt_wlan_config_autoreconnect(RT_TRUE);
  456. else if (rt_strcmp(argv[1], "disable") == 0)
  457. rt_wlan_config_autoreconnect(RT_FALSE);
  458. }
  459. else
  460. {
  461. return -1;
  462. }
  463. return 0;
  464. }
  465. static int wifi_debug(int argc, char *argv[])
  466. {
  467. int i, result = 0;
  468. const struct wifi_cmd_des *run_cmd = RT_NULL;
  469. if (argc < 3)
  470. {
  471. wifi_debug_help(0, RT_NULL);
  472. return 0;
  473. }
  474. for (i = 0; i < sizeof(debug_tab) / sizeof(debug_tab[0]); i++)
  475. {
  476. if (rt_strcmp(debug_tab[i].cmd, argv[2]) == 0)
  477. {
  478. run_cmd = &debug_tab[i];
  479. break;
  480. }
  481. }
  482. if (run_cmd == RT_NULL)
  483. {
  484. wifi_debug_help(0, RT_NULL);
  485. return 0;
  486. }
  487. if (run_cmd->fun != RT_NULL)
  488. {
  489. result = run_cmd->fun(argc - 2, &argv[2]);
  490. }
  491. if (result)
  492. {
  493. wifi_debug_help(argc - 2, &argv[2]);
  494. }
  495. return 0;
  496. }
  497. #endif
  498. static int wifi_msh(int argc, char *argv[])
  499. {
  500. int i, result = 0;
  501. const struct wifi_cmd_des *run_cmd = RT_NULL;
  502. if (argc == 1)
  503. {
  504. wifi_help(argc, argv);
  505. return 0;
  506. }
  507. /* find fun */
  508. for (i = 0; i < sizeof(cmd_tab) / sizeof(cmd_tab[0]); i++)
  509. {
  510. if (rt_strcmp(cmd_tab[i].cmd, argv[1]) == 0)
  511. {
  512. run_cmd = &cmd_tab[i];
  513. break;
  514. }
  515. }
  516. /* not find fun, print help */
  517. if (run_cmd == RT_NULL)
  518. {
  519. wifi_help(argc, argv);
  520. return 0;
  521. }
  522. /* run fun */
  523. if (run_cmd->fun != RT_NULL)
  524. {
  525. result = run_cmd->fun(argc, argv);
  526. }
  527. if (result)
  528. {
  529. wifi_help(argc, argv);
  530. }
  531. return 0;
  532. }
  533. #if defined(RT_USING_FINSH)
  534. FINSH_FUNCTION_EXPORT_ALIAS(wifi_msh, __cmd_wifi, wifi command.);
  535. #endif
  536. #endif