您的位置首页  家电资讯  新闻

鸿蒙实战课堂 | Hi3861V100创建Wi-Fi驱动应用详细步骤与方法

  • 来源:互联网
  • |
  • 2020-10-15
  • |
  • 0 条评论
  • |
  • |
  • T小字 T大字

Hi3861V100、Hi3861LV100 通过API(Application Programming Interface)面向开发者提供Wi-Fi功能的开发和应用接口,包括芯片初始化、资源配置、Station创建和配置、扫描、关联以及去关联、状态查询等一系列功能, 框架结构如图1-1所示。

各功能模块说明如下:

▪ APP应用开发层:用户基于API接口的二次开发。

▪ Example示例:SDK提供的功能开发示例。

▪ API接口:提供基于SDK的通用接口。

▪ LWIP协议栈:网络协议栈。

▪ WPA SUPPLICANT(含HOSTAPD):Wi-Fi管理模块。

▪ Wi-Fi驱动:802.11协议实现模块。

▪ Platform平台:提供SoC系统板级支持包(包括:芯片和外围设备驱动、操作系统以及系统管理)

1、Wi-Fi驱动加载与卸载

1.1 概述

在完成芯片上电后,驱动加载实现对芯片寄存器的初始配置、校准参数读取与写入、软件资源的申请和配置;驱动卸载实现软件资源的释放。

1.2 开发流程

使用场景:Wi-Fi驱动初始化为Wi-Fi功能提供基本资源配置和芯片初始化,是Wi-Fi功能实现的第一步。当需要配置Wi-Fi功能时,必须先完成驱动的初始化,Wi-Fi功能使用完成后,可以使用去初始化完成资源释放也可以使用软复位来完成资源释放。

功能:Wi-Fi驱动加载与卸载提供的接口如表2-1所示

使用驱动加载与卸载的典型流程:

步骤1:调用hi_wifi_init, 完成Wi-Fi驱动初始化。

步骤2:参考“3 STA功能”或“4 SoftAp功能”配置Wi-Fi功能。

步骤3:调用hi_wifi_deinit,完成Wi-Fi驱动去初始化。

----

结束

返回值如表2-2所示

1.3 注意事项

驱动资源配置不支持运行中修改,须先卸载驱动再进行修改,修改后重新初始化。

驱动为了保证Wi-Fi业务的连续性,会在启动时根据VAP数量和用户数量预申请内存,其中1个VAP资源预申请约5K内存,1个用户资源预申请约7K内存,请根据场景需要合理配置初始化的资源数。目前仅配网时需要用到SoftAp和STA共存,一般建议配置为2个VAP和2个用户;如果可以实现配网时先关闭SoftAp再启动STA去关联,VAP和用户数量均可配置为1。

1.4 编程实例

示例1:基于LiteOS的app_main函数,在系统初始化时自动完成Wi-Fi驱动的加载,此加载方式无须进行卸载开发,系统reboot时自动完成驱动卸载和加载。

示例2:基于shell命令,在系统启动后,通过手动下发shell命令完成Wi-Fi驱动的加载和卸载。

2、STA功能

2.1 概述

STA功能即NON-AP Station功能,实现驱动STA VAP的创建、扫描、关联以及DHCP,完成通信链路的建立。开发STA功能前,须完成驱动加载。

2.2 开发流程

使用场景:当需要接入某个网络并与该网络通信时,需要启动STA功能。

功能:驱动STA功能提供的接口,如表3-1所示。

STA功能开发的典型流程:

步骤1:调用hi_wifi_sta_start, 启动STA。

步骤2:调用hi_wifi_set_bandwidth, 设置STA带宽模式,20M带宽可不用配置。

步骤3:(可选,根据需要配置)调用hi_wifi_sta_set_reconnect_policy, 设置自动重连。

步骤4:调用hi_wifi_sta_scan(或调用hi_wifi_sta_advance_scan;执行带参数扫描),触发STA扫描。

步骤5:调用hi_wifi_sta_scan_results,获取扫描结果。

步骤6:根据接入网络需求,自定义筛选扫描结果,调用hi_wifi_sta_connect, 进行连接。

步骤7:调用hi_wifi_sta_get_connect_info,查询Wi-Fi连接状态。

步骤8:连接成功后,调用netifapi_dhcp_start,启动DHCP客户端,获取IP地址。

步骤9:调用hi_wifi_sta_disconncet,离开当前连接的网络。

步骤10:调用netifapi_dhcps_stop,停止DHCP客户端。

步骤11:调用hi_wifi_sta_stop,关闭STA。

---结束

返回值如表3-2所示

2.3 注意事项

▪ STA支持5M/1 OM窄带模式,需要时可调用接口设置,不调用则默认启动20M带宽STA。

▪ 扫描为非阻塞式接口,扫描命令下发成功后需要延迟一段时间后再获取扫描结果,全信道扫描延迟时间建议设置为1s。

▪ 可通过指定SSID、BSSID、信道等带指定参数的扫描,实现更精准地扫描,缩短扫描时间。

▪ 已知待连接网络的参数时,可省去扫描过程,直接发起连接。

▪ 连接为非阻塞式接口,连接命令下发成功后,需要通过命令获取连接状态。

▪ 注册事件回调函数后,Wi-Fi相关的事件会通过该回调上报用户,用户可根据事件执行后续动作。

▪ 不支持重复启动STA,再次启动STA时须先执行关闭STA。

▪ 关闭STA步骤为可选,设备所处的网络地位不变,不需要执行关闭STA。

2.4 编程实例

示例:实现STA功能启动、扫描、关联以及获取IP地址。

3、SoftAp功能

3.1 概述

SoftAp功能提供网络接入点供其他STA接入,并对接入的STA提供DHCP Server服务。

3.2 开发流程

使用场景:当需要创建一个网络接入点,供其他设备接入并共享网络内的数据时,需要使用SoftAP功能。

功能:提供的接口如表4-1所示。

SoftAP功能开发的典型流程:

步骤1:配置SoftAp的网络参数:

-调用hi_wifi_softap_set_protocol_mode,设置协议模式。

-调用hi_wifi_softap_set_beacon_period,设置beacon周期。

-调用hi_wifi_softap_ set_dtim_period,设置dtim周期。

步骤2:调用hi_wifi_softap_start,启动SoftAp。

步骤3:调用hi_wifi_set_bandwidth,设置SoftAp的带宽,20M带宽可不用配置。

步骤4:调用netifapi_netif_set_addr,配置DHCP服务器。

步骤5:调用netifapi_dhcps_start,启动DHCP服务器。

步骤6:调用netifapi_dhcps_stop,停止DHCP服务器。

步骤7:调用hi_wifi_softap_stop,关闭SoftAp。

--结束

返回值如表4-2所示

3.3 注意事项

SoftAp的网络参数为可选配置,无特殊要求均可使用初始默认值。

SoftAp支持5M/1 0M窄带模式,需要时可调用接口设置,不调用则默认启动20M带宽SoftAp。

SoftAp的网络参数在关闭SoftAp时不会重置,会继续沿用_上一次配置,重启单板可恢复至初始默认值。

SoftAp模式下最大关联用户数限制:

-小于初始化时配置的用户数量。

-最大关联用户不超过2个。

3.4 编程实例

示例:实现将SoftAp功能的beacon周期配置为200ms,并启动SoftAp,最后将DHCP服务器的IP地址配置为192.168.43.1。

除此之外,Wi-Fi软件应用创建还包括了混杂模式、CSI数据采集、STA&SoftAP共存、Wi-Fi&蓝牙共存、软件重传等诸多无线网实用功能开发。想详细了解学习的童鞋,可以扫码加入我们的鸿蒙技术交流群,免费领取领取完整的基于HarmonyOS Hi3861V100开发板Wi-Fi模组应用开发文档。另外还给大家准备了超级详细的Hi3861V100硬件&软件开发文档资料,也一并免费送给大家学习。

Hi3861V100软件开发资料(32份)

Hi3861V100&&LV100硬件资料(10份)

(文档资料持续更新,加入交流群即可获得第一手开发资料)

已有 23105位开发者加入

【免费申请基于Hi3861V100鸿蒙开发板】

HiSpark Wi-Fi IoT HarmonyOS 智能家居套件

产品特性:

▪ 支持鸿蒙OS、LiteOS操作系统,方便进行物联网产品的原型验证和快速开发;

▪ 特性板搭载海思Hi3861芯片,最高运行频率160MHz, 内置352 KB SRAM, 288 KB ROM, 内置2MB Flash, 支持IEEE 802.11 b/g/n, 支持STA模式、AP模式;

▪ 套件包含多个扩展板,包括OLED板、NFC扩展板、环境监测板、红绿灯板、炫彩灯板、机器人板,集成了多种常见外设;

软件支持:

SDK、支持OS Linux 4.9,Lite OS,鸿蒙OS、样本代码

活动名额:

本期提供 150个试用名额,名额已不多,想申请试用的要抓紧时间哟~ 报名截止时间:10月17日

扫一扫立即申请试用

免责声明:本站所有信息均搜集自互联网,并不代表本站观点,本站不对其真实合法性负责。如有信息侵犯了您的权益,请告知,本站将立刻处理。联系QQ:
  • 标签:加油吧威基基2
  • 编辑:郭晓刚
  • 相关文章
热网推荐更多>>