本文來(lái)源電子發(fā)燒友社區(qū),作者:ouxiaolong, 帖子地址:https://bbs.elecfans.com/jishu_2287628_1_1.html
開(kāi)發(fā)環(huán)境:
開(kāi)發(fā)環(huán)境:
開(kāi)發(fā)系統(tǒng):Ubuntu 20.04
開(kāi)發(fā)板:Pegasus物聯(lián)網(wǎng)開(kāi)發(fā)板
MCU:Hi3861
OpenHarmony版本:3.0.1-LTS
HI3861默認(rèn)已經(jīng)初始化了WiFi,因此這里講解如何使用WiFi聯(lián)網(wǎng)。
串口終端上執(zhí)行相應(yīng)的AT命令,即可使Hi3861 WLAN模組聯(lián)網(wǎng),依次執(zhí)行如下AT命令,啟動(dòng)STA模式,連接指定路由器,并開(kāi)啟DHCP功能配置IP地址。
AT+STARTSTA # 啟動(dòng)STA模式
AT+SCAN # 掃描周邊AP
AT+SCANRESULT # 顯示掃描結(jié)果
AT+CONN="SSID",,2,"PASSWORD" # 連接指定AP,其中SSID/PASSWORD為待連接的熱點(diǎn)名稱和密碼
AT+STASTAT # 查看連接結(jié)果
AT+DHCP=wlan0,1 # 通過(guò)DHCP向AP請(qǐng)求wlan0的IP地址
查看Hi3861 WLAN模組與網(wǎng)關(guān)聯(lián)通是否正常,如下所示。
AT+IFCFG # 查看模組接口IP
AT+PING=X.X.X.X # 檢查模組與網(wǎng)關(guān)的聯(lián)通性,其中X.X.X.X需替換為實(shí)際的網(wǎng)關(guān)地址
下面具體演示:
有上圖可知Hi3861 WLAN模組聯(lián)網(wǎng)成功。
當(dāng)然也可在同一個(gè)局域網(wǎng)中ping HI3861。
說(shuō)明網(wǎng)絡(luò)是連通的。
關(guān)于Wifi聯(lián)網(wǎng)的AT命令有很多,所有的AT指令都是通過(guò)函數(shù)hi_at_sys_cmd_register()函數(shù)注冊(cè)的,其中調(diào)用了hi_at_register_cmd()函數(shù)注冊(cè)AT。
重點(diǎn)介紹三個(gè)函數(shù)。
1.啟動(dòng)WiFi STA模式, AT+STARTSTA
hi_u32 cmd_sta_start_adv(hi_s32argc, const hi_char *argv[])
{
hi_s32 ret;
hi_wifi_bw bw = HI_WIFI_BW_LEGACY_20M;
return HI_ERR_FAILURE;
}
ret = (hi_s32)sta_start_adv_param(argc,argv, &bw);
if (ret != HI_ERR_SUCCESS) {
return HI_ERR_FAILURE;
}
#ifndef CONFIG_FACTORY_TEST_MODE
hi_char ifname[WIFI_IFNAME_MAX_SIZE + 1] ={0};
hi_s32 len = sizeof(ifname);
ret = hi_wifi_sta_start(ifname, &len);
if (ret != HISI_OK) {
return HI_ERR_FAILURE;
}
#endif
ret =hi_wifi_set_bandwidth(DEFAULT_IFNAME_STA, strlen(DEFAULT_IFNAME_STA) + 1, bw);
if (ret != HI_ERR_SUCCESS) {
#ifndef CONFIG_FACTORY_TEST_MODE
hi_wifi_sta_stop();
#endif
return HI_ERR_FAILURE;
}
hi_at_printf("OKrn");
return HI_ERR_SUCCESS;
}
該函數(shù)的核心就是hi_wifi_sta_start()函數(shù)。
2.連接WiFi ,AT+CONN
/*****************************************************************************
* Func description: stationconnect network
* example:AT+CONN="hisilicon",,3,"123456789"
*****************************************************************************/
hi_u32 cmd_sta_connect(hi_s32argc, const hi_char *argv[])
{
hi_wifi_assoc_request assoc_req = {0};
if ((argc < 3) || (argc > 4)) { /* argc 3/4 */
return HI_ERR_FAILURE;
}
/* get ssid */
if ((argv[0] != HI_NULL) &&(cmd_sta_connect_get_ssid(argv, &assoc_req, HI_NULL, 0) != HI_ERR_SUCCESS)){
return HI_ERR_FAILURE;
}
/* get bssid */
if (argv[1] == HI_NULL) {
memset_s(assoc_req.bssid,sizeof(assoc_req.bssid), 0, sizeof(assoc_req.bssid));
} else if (strlen(argv[1]) ==HI_WIFI_TXT_ADDR_LEN) {
if (cmd_strtoaddr(argv[1],assoc_req.bssid, HI_WIFI_MAC_LEN) != HISI_OK) {
return HI_ERR_FAILURE;
}
} else {
return HI_ERR_FAILURE;
}
/* get auth_type */
if ((integer_check(argv[2]) !=HI_ERR_SUCCESS) || (atoi(argv[2]) < HI_WIFI_SECURITY_OPEN) ||? ? /* argc 2 */
(atoi(argv[2]) == HI_WIFI_SECURITY_WPA)|| (atoi(argv[2]) == HI_WIFI_SECURITY_WPA2) || /* argc 2 */
(atoi(argv[2]) ==HI_WIFI_SECURITY_WPAPSK) || (atoi(argv[2]) >= HI_WIFI_SECURITY_UNKNOWN) ||/* argc 2 */
((atoi(argv[2]) ==HI_WIFI_SECURITY_OPEN) && (argc != 3)) || /* argc 2/3/4 */
((atoi(argv[2]) !=HI_WIFI_SECURITY_OPEN) && (argc != 4))) { /* argc 2/3/4 */
return HI_ERR_FAILURE;
}
assoc_req.auth = (hi_wifi_auth_mode)atoi(argv[2]);/* 2 */
assoc_req.pairwise =HI_WIFI_PARIWISE_UNKNOWN;
/* get key */
if (argc == 4) { /* argc 4 */
const hi_char *buf = argv[3]; /* argc 3 */
if (buf == HI_NULL) {
return HI_ERR_FAILURE;
}
size_t len = strlen(argv[3]); /* 3:key*/
if ((atoi(argv[2]) ==HI_WIFI_SECURITY_WEP) && (len != 9) && (len != 17) &&/* argc 2, len 9/17 */
(len != 12) && (len !=28)){ /* 12 28: password len */
return HI_ERR_FAILURE;
} else if ((atoi(argv[2]) !=HI_WIFI_SECURITY_WEP) && ((len > HI_WIFI_AP_KEY_LEN_MAX + 2) || /* argc 2 */
(len < HI_WIFI_AP_KEY_LEN_MIN +2))) {??/* len plus 2 */
return HI_ERR_FAILURE;
}
if ((*buf != '"') || (*(buf +strlen(argv[3]) - 1) != '"') || /* argc 3 */
(memcpy_s(assoc_req.key,HI_WIFI_MAX_KEY_LEN + 1, buf + 1, strlen(argv[3]) - 2) != EOK)) { /* 3 2 */
return HI_ERR_FAILURE;
}
}
if (hi_wifi_sta_connect(&assoc_req) !=HISI_OK) {
return HI_ERR_FAILURE;
}
hi_at_printf("OKrn");
return HI_ERR_SUCCESS;
}
該函數(shù)主要用于解析AT+CONN指令,核心是hi_wifi_sta_connect()函數(shù)。
3.獲取IP地址, AT+DHCP
hi_u32 at_setup_dhcp(hi_s32argc, const hi_char **argv)
{
hi_s32 ret = 0;
if (at_param_null_check(argc, argv) ==HI_ERR_FAILURE) {
return HI_ERR_FAILURE;
}
if (argc != 2) { /* at+dhcp cmd length equl2 */
return HI_ERR_FAILURE;
}
#ifndef CONFIG_FACTORY_TEST_MODE
struct netif *netif_p = netifapi_netif_find(argv[0]);
if (netif_p == NULL) {
return HI_ERR_FAILURE;
}
if (strcmp(argv[1], "1") == 0) {
ret = netifapi_dhcp_start(netif_p);
} else if (strcmp(argv[1], "0")== 0) {
ret = netifapi_dhcp_stop(netif_p);
} else if (strcmp(argv[1], "2")== 0) {
ret = netifapi_netif_common(netif_p,dhcp_clients_info_show, NULL);
} else {
return HI_ERR_FAILURE;
}
#endif
if (ret == LOS_OK) {
hi_at_printf("OKrn");
}
return ret;
}
其中netifapi_netif_find()函數(shù)通過(guò)DHCP向AP請(qǐng)求wlan0的IP地址,然后就調(diào)用netifapi_dhcp_start()函數(shù)獲取IP。
使用AT比較麻煩,接下來(lái)筆者將通過(guò)程序來(lái)聯(lián)網(wǎng)。
編程自動(dòng)聯(lián)網(wǎng),其本質(zhì)和使用AT指令一樣,最終都是調(diào)用了相同的API,只是通過(guò)加載應(yīng)用的方式去實(shí)現(xiàn)了,聯(lián)網(wǎng)流程和使用AP一樣的,編寫應(yīng)用的方式參看上一章內(nèi)容,本文將在wifi-iot目錄下新建應(yīng)用,這樣可以簡(jiǎn)化步驟。
1.新建目錄
在./applications/sample/wifi-iot/app路徑下新建一個(gè)目錄,用于存放WiFi應(yīng)用的源碼文件。
在app下新增業(yè)務(wù)wifi_connect,其中wifi_app.c為應(yīng)用代碼,BUILD.gn為編譯腳本,目錄結(jié)構(gòu)如下:
2.編寫應(yīng)用代碼
新建./applications/sample/wifi-iot/app/wifi_app下的wifi_app.c文件,在wifi_app.c中新建映月宮入口函數(shù)wifi_task,并實(shí)現(xiàn)業(yè)務(wù)邏輯。并在代碼最下方,使用OpenHarmony啟動(dòng)模塊接口SYS_RUN()啟動(dòng)業(yè)務(wù)。
從上一節(jié)內(nèi)容得到,連接WiFi核心就三個(gè):?jiǎn)?dòng)STA模式,連接WiFi,設(shè)置IP。
因此,最終的wifi_app.c的函數(shù)代碼如下:
/**
******************************************************************************
*@file wifi_app.c
*@author BruceOu
*@version V1.0
* @date 2022-06-18
*@blog https://blog.bruceou.cn/
******************************************************************************
*/
#include
#include
#include "ohos_init.h"
#include "cmsis_os2.h"
#include
#include"hi_wifi_api.h"
#include"lwip/ip_addr.h"
#include "lwip/netifapi.h"
#define SSID "media"
#define PASSWORD"12345678"
static struct netif*g_lwip_netif = NULL;
/**
* @briefSet netif's ip, gatewayand netmask
*@parampst_lwip_netif
* @retval None
*/
void hi_sta_set_addr(structnetif *pst_lwip_netif)
{
ip4_addr_t st_gw;
ip4_addr_t st_ipaddr;
ip4_addr_t st_netmask;
if (pst_lwip_netif == NULL)
{
printf("hisi_reset_addr::Nullparam of netdevrn");
return;
}
IP4_ADDR(&st_gw, 192, 168, 101, 1);
IP4_ADDR(&st_ipaddr, 192, 168, 101,100);
IP4_ADDR(&st_netmask, 255, 255, 255,0);
netifapi_netif_set_addr(pst_lwip_netif,&st_ipaddr, &st_netmask, &st_gw);
}
/**
* @briefWifi connect
* @paramNone
* @retval None
*/
int hi_wifi_start_connect(void)
{
int ret;
errno_t rc;
hi_wifi_assoc_request assoc_req = {0};
// Copy SSID to assoc_req
rc = memcpy_s(assoc_req.ssid,HI_WIFI_MAX_SSID_LEN + 1, SSID, strlen(PASSWORD));
if (rc != EOK)
{
printf("[Wifi Connnect]hi_wifi_sta_connect fail");
printf("%s %d rn",__FILE__, __LINE__);
return -1;
}
//Set encryption method
assoc_req.auth = HI_WIFI_SECURITY_WPA2PSK;
// Wifi password
memcpy(assoc_req.key, PASSWORD,strlen(PASSWORD));
ret = hi_wifi_sta_connect(&assoc_req);
if (ret != HISI_OK)
{
printf("[WifiConnnect] hi_wifi_sta_connect fail");
printf("%s %d rn",__FILE__, __LINE__);
return -1;
}
return0;
}
/**
* @briefwifi task
* @paramNone
* @retval None
*/
void wifi_task(void)
{
int ret;
char ifname[WIFI_IFNAME_MAX_SIZE + 1] ={0};
int len = sizeof(ifname);
unsigned intnum = WIFI_SCAN_AP_LIMIT;
//Step 1: Start STA mode, AT+STARTSTA
ret = hi_wifi_sta_start(ifname, &len);
if (ret != HISI_OK)
{
printf("[Wifi Connnect]hi_wifi_sta_start fail");
printf("%s %d rn",__FILE__, __LINE__);
return;
}
// Step 2: Connect to the specified AP:,AT+CONN="SSID", ,2,"PASSWORD"
ret = hi_wifi_start_connect();
if (ret != 0)
{
printf("[Wifi Connnect]hi_wifi_start_connect fail");
printf("%s %d rn",__FILE__, __LINE__);
return ;
}
// Step 3: DHCP requests the IP address ofwlan0 from the AP, AT+DHCP=wlan0,1
g_lwip_netif = netifapi_netif_find(ifname);
if(NULL == g_lwip_netif)
{
printf("[Wifi Connnect]netifapi_netif_find fail");
printf("%s %d rn",__FILE__, __LINE__);
return;
}
//DHCP automatically assigns IP
if(ret !=netifapi_dhcp_start(g_lwip_netif))
{
printf("[Wifi Connnect]netifapi_dhcp_start fail");
return;
}
printf("[Wifi Connnect] Connect towifi successfullyn");
}
SYS_RUN(wifi_task);
3.新建編譯組織文件
新建./applications/sample/wifi-iot/app/wifi_connect/BUILD.gn文件,內(nèi)容如下所示:
static_library(wifiapp") {
sources = [
"wifi_app.c"
include_dirs = [
"http://utils/native/lite/include"
}
static_library中指定業(yè)務(wù)模塊的編譯結(jié)果,為靜態(tài)庫(kù)文件libwifiapp.a,開(kāi)發(fā)者根據(jù)實(shí)際情況完成填寫。
sources中指定靜態(tài)庫(kù).a所依賴的.c文件及其路徑,若路徑中包含"http://"則表示絕對(duì)路徑(此處為代碼根路徑),若不包含"http://"則表示相對(duì)路徑。
include_dirs中指定source所需要依賴的.h文件路徑。
最后,編譯下載固件,我們就可以自動(dòng)連接Wifi了。
接下來(lái)ping下網(wǎng)絡(luò):
說(shuō)明自動(dòng)連接網(wǎng)絡(luò)成功。
官網(wǎng)手冊(cè):
https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-ide-lite-steps-hi3861-netconfig.md
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場(chǎng)。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問(wèn)題,請(qǐng)聯(lián)系本站處理。
舉報(bào)投訴
-
wi-fi
+關(guān)注
關(guān)注
14文章
2162瀏覽量
124789 -
HarmonyOS
+關(guān)注
關(guān)注
79文章
1980瀏覽量
30395 -
HiSpark
+關(guān)注
關(guān)注
1文章
156瀏覽量
6943
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
華為海思正式進(jìn)入Wi-Fi FEM賽道?
產(chǎn)品和技術(shù)交流。
2017年是國(guó)產(chǎn)Wi-Fi FEM元年,銳迪科(RDA)是中國(guó)大陸第一家推出和量產(chǎn)Wi-Fi5 FEM的公司,也是第一家導(dǎo)入H公司的Wi-Fi FEM廠商。
也是在這一年,我頻繁地跟H
發(fā)表于 12-11 17:42
摩爾斯微電子發(fā)布Wi-Fi HaLow評(píng)估套件,加速物聯(lián)網(wǎng)開(kāi)發(fā)
近日,全球領(lǐng)先的Wi-Fi HaLow解決方案提供商摩爾斯微電子正式推出一款開(kāi)創(chuàng)性的評(píng)估套件——MM6108-EKH05。這款完全整合的開(kāi)發(fā)平臺(tái),旨在推動(dòng)各行業(yè)物聯(lián)網(wǎng)解決方案的快速發(fā)展
從Wi-Fi 4到Wi-Fi 7:網(wǎng)速飆升40倍的無(wú)線革命
Wi-Fi 4首次引入MIMO和40 MHz頻寬,是基礎(chǔ)的高效無(wú)線網(wǎng)絡(luò)標(biāo)準(zhǔn)。 ? Wi-Fi 5 Wi-Fi 5擁有更高的數(shù)據(jù)速率,專注于
IR615如何配置Wi-Fi STA模式聯(lián)網(wǎng)?
1)選擇網(wǎng)絡(luò)》WLAN模式切換》選擇模式為sta
2)重啟系統(tǒng)(系統(tǒng)>>重啟系統(tǒng)),重啟后選擇網(wǎng)絡(luò)》wan(sta)端口
3)配置wan(
發(fā)表于 07-25 07:27
IR900 Wi-Fi聯(lián)網(wǎng)的配置過(guò)程
例如上圖,IR900 通過(guò)Wi-Fi接口連接公司辦公無(wú)線網(wǎng)絡(luò) inhand-office (SSID為無(wú)線網(wǎng)絡(luò)的名稱) 首先將Wi-Fi接口與WLAN接口解綁
登陸IR900后,進(jìn)入
發(fā)表于 07-25 06:09
使用Arduino 1.6.8在AT STA模式下運(yùn)行Wi-Fi,“WiFi強(qiáng)制休眠開(kāi)始”功能后未調(diào)用延遲功能是怎么回事?
我使用 Arduino 1.6.8 在 AT STA 模式下運(yùn)行 Wi-Fi。ESP-8266 固件基于 SDK1.5
我想將 wifi AP 置于調(diào)制解調(diào)器睡眠
發(fā)表于 07-22 06:48
AT 0.60.0.0看不到我的Wi-Fi網(wǎng)絡(luò),為什么?
我對(duì) AT 0.60.0.0 有一點(diǎn)問(wèn)題。當(dāng)我通過(guò) AT CWLAP 顯示所有網(wǎng)絡(luò)時(shí),我看不到我的路由器 AP 網(wǎng)絡(luò),但我可以連接到它。當(dāng)我在智能手機(jī)中打開(kāi) Wi-Fi 熱點(diǎn)時(shí),我可以看到我的熱點(diǎn)
發(fā)表于 07-18 08:31
全方位性能對(duì)比 | 遠(yuǎn)距離Wi-Fi VS 傳統(tǒng)Wi-Fi
Wi-Fi通信技術(shù)當(dāng)前已成為無(wú)線局域網(wǎng)(WLAN)最常見(jiàn)、應(yīng)用非常廣泛的通信技術(shù)。從Wi-Fi4、Wi-Fi5和Wi-Fi6,傳統(tǒng)的WiFi
驗(yàn)證物聯(lián)網(wǎng)Wi-Fi HaLow用例的MM6108-EKH08開(kāi)發(fā)套件來(lái)啦
驗(yàn)證物聯(lián)網(wǎng)Wi-Fi HaLow用例的MM6108-EKH08開(kāi)發(fā)套件來(lái)啦 MM6108-EKH08開(kāi)發(fā)套件專為驗(yàn)證物聯(lián)網(wǎng)
Wi-Fi的誕生與發(fā)展
和5GHz兩個(gè)頻段,承載著不斷增長(zhǎng)的網(wǎng)絡(luò)需求。ABIResearch顯示,2022年Wi-Fi上傳流量激增80%,Wi-Fi數(shù)據(jù)流量已超過(guò)蜂窩流量,且成為流量增量貢
WI-FI基礎(chǔ)知識(shí)及飛易通SOC模塊
“WiFi”或“Wifi”,但是這些寫法并沒(méi)有被Wi-Fi聯(lián)盟認(rèn)可。 一、通常說(shuō)的WI-FI幾: 第一代:以IEEE 802.11為準(zhǔn),工作頻段為2.4GHz, 最高速率半雙工2Mbi
Wi-Fi HaLow和傳統(tǒng)Wi-Fi的區(qū)別
Wi-Fi HaLow和傳統(tǒng)Wi-Fi的區(qū)別? Wi-Fi是一種無(wú)線網(wǎng)絡(luò)技術(shù),可以連接到互聯(lián)網(wǎng)或局域網(wǎng),為用戶提供無(wú)線上網(wǎng)的便利。隨著科技的發(fā)展和互
全志R128基礎(chǔ)組件開(kāi)發(fā)指南-WiFi Manager②
_STATION);wifi_sta_connect(&cn_para);wifi_sta_disconnect();1.以station模式打開(kāi)Wi-Fi Manager2.
發(fā)表于 01-25 14:28
全志R128基礎(chǔ)組件開(kāi)發(fā)指南-WiFi Manager
WIFI_STA_DISCONNECTED:station 模式處于已取消連接狀態(tài)
定義Wi-Fi Manager station 模式在連接過(guò)程中的事件結(jié)構(gòu)體描述:該結(jié)構(gòu)體主要用于
發(fā)表于 01-24 10:11
評(píng)論