3.2. Wi-Fi API接口说明

  • wifi 的 API 接口说明如下:

Defines

ENC_NONE
ENC_WEP
ENC_WPA
ENC_WPA2
ENC_WPA3
ENC_MODE_BIT_SET(val, mode)
ENC_MODE_BIT_IS_SET(val, mode)

Functions

void wifi_set_event_callback(int (*cb)(void*, enum WIFI_EVENT))

wifi_set_event_callback,用于注册(设置)WIFI事件回调函数

Parameters

cb – 指向WIFI事件回调函数,一般为:wifi_event_callback

u8 wifi_airkiss_calcrc_bytes(u8 *p, unsigned int num_of_bytes)

wifi_airkiss_calcrc_bytes,用于计算airkiss接收包crc校验

Parameters
  • p – 指向设备端扫描到的空中SSID

  • num_of_bytes – 设备端扫描到的空中SSID长度

void wifi_set_frame_cb(void (*cb)(void *rxwi, struct ieee80211_frame *wh, void *data, u32 len, void *priv), void *priv)

wifi_set_frame_cb,用于注册(设置)WIFI底层接收到802.11数据帧回调函数

Parameters
  • cb – 指向WIFI底层接收到802.11数据帧回调函数

  • priv – 用户私有指针传递

void wifi_set_pwr(unsigned char pwr_sel)

wifi_set_pwr,用于设置WIFI 模拟功率等级

Note

参数设为0,表示把WIFI模拟功率调整到最低档位节电

Parameters

pwr_sel – 默认为6,范围为0-6

int wifi_on(void)

wifi_on,用于启动WIFI

int wifi_is_on(void)

wifi_is_on,查询WIFI是否启动

int wifi_off(void)

wifi_off,关闭WIFI

int wifi_get_mac(u8 *mac)

wifi_get_mac,获取WIFI MAC地址

Parameters

mac – 指向存储MAC地址的缓存数组,数组大小为6

int wifi_set_mac(char *mac_addr)

wifi_set_mac,设置WIFI MAC地址

Parameters

mac_addr – 指向要设置的MAC地址缓存数组,数组大小为6

void wifi_rxfilter_cfg(char mode)

wifi_rxfilter_cfg,设置WIFI接收过滤

Parameters

mode – 过滤模式

mode

说明

0

STA模式默认不过滤

1

AP模式默认不过滤

2

STA模式下使用,过滤广播,多播

3

STA模式下使用,过滤not_my_bssid

4

STA模式下使用,过滤广播+多播+not_my_bssid

5

AP模式下使用,过滤广播,多播

6

AP模式下使用,过滤not_my_bssid

7

AP模式下使用,过滤广播+多播+not_my_bssid

void wifi_set_tx_rate_control_tab(u32 tab)

wifi_set_tx_rate_control_tab,用于设置WIFI TX速率

Parameters

tab – 速率表,不需要哪个速率就删除掉,可以动态设定

u32 wifi_get_channel(void)

wifi_get_channel,用于获取WIFI当前信道

void wifi_get_bssid(u8 bssid[6])

wifi_get_bssid,用于获取WIFI当前bssid

u32 wifi_get_upload_rate(void)

wifi_get_upload_rate,用于获取WIFI上行速率

u32 wifi_get_download_rate(void)

wifi_get_download_rate,用于获取WIFI下行速率

void wifi_get_mode_cur_info(struct wifi_mode_info *info)

wifi_get_mode_cur_info,用于获取WIFI当前是什么模式,或者当前指定模式下的配置信息

Parameters

info – 指向一个wifi_mode_info类型的结构体,其包含了变量mode、ssid、pwd

int wifi_get_mode_stored_info(struct wifi_mode_info *info)

wifi_get_mode_stored_info,用于获取WIFI最后记忆的是什么模式,或者最后记忆模式下的配置信息

Parameters

info – 指向一个wifi_mode_info类型的结构体,其包含了变量mode、ssid、pwd

int wifi_set_default_mode(struct wifi_store_info *parm, char force, char store)

wifi_set_default_mode,用于设置WIFI启动默认模式配置

Note

配置STA模式情况下,把默认配置SSID也存储起来,以后即使保存过其他SSID,也不会覆盖丢失,使用连接最优信号SSID策略的情况下可以匹配连接

Parameters
  • parm – 指向一个wifi_store_info类型的结构体

  • force – 配置wifi_on之后的模式

    force

    说明

    0

    使用最后记忆的模式

    1

    强制默认模式

    3-200

    STA连接超时时间多少秒,如果超时都连接不上就连接最后记忆的或者最优网络

  • store – 选择是否存储默认配置的SSID

    store

    说明

    0

    不存储默认配置的SSID

    1

    存储默认配置的SSID

int wifi_store_mode_info(enum WIFI_MODE mode, char *ssid, char *pwd)

wifi_store_mode_info,用于保存WIFI模式配置信息,覆盖默认模式

Parameters
  • mode – 配置的wifi模式

  • ssid – 配置模式下的SSID

  • pwd – 配置模式下的密码

int wifi_del_stored_sta_info(char *ssid)

wifi_del_stored_ssid,用于删除STA模式下保存过的SSID,仅允许STA模式使用

Parameters

ssid – 删除wifi_get_stored_sta_info存储中的ssid

void wifi_set_target_mac_for_agc_recv(char *mac)

wifi_set_target_mac_for_agc_recv,用于设置目标接收地址,有利于提高抗干扰能力,专门针对目标地址的数据包进行接收AGC和频偏调整

Parameters

mac – 目标接收地址

int wifi_enter_ap_mode(char *ap_ssid, char *ap_pwd)

wifi_enter_ap_mode,用于设置WIFI进入AP模式

Parameters
  • ap_ssid – AP模式下的SSID

  • ap_pwd – AP模式下的密码

int wifi_get_sta_entry_rssi(char wcid, char **rssi, u8 **evm, u8 **mac)

wifi_get_sta_entry_rssi,用于AP模式下获取接入的每个STA信号质量和MAC地址

void wifi_disconnect_station(char *mac, u16 reason)

wifi_disconnect_station,用于AP模式下断开指定MAC地址的STA

Parameters
  • mac – 要断开设备的mac地址

  • reason – 断开的原因,通常填8:Deauthenticated because sending station is leaving

void wifi_set_store_ssid_cnt(u32 cnt)

wifi_set_store_ssid_cnt,用于设置WIFI最多保存多少个连接的SSID数目

Parameters

cnt – sta模式下最多保存的SSID数目,工程中默认为5

void wifi_set_sta_connect_best_ssid(u8 enable)

wifi_set_sta_connect_best_ssid,用于设置WIFI进入STA模式的时候如果匹配到信号最好的网络就去连接

Parameters

enable – 自动连接保存过的信号最好的SSID使能端,置1:使能,置0:不使能

void wifi_set_sta_connect_timeout(int sec)

wifi_set_sta_connect_timeout,用于设置WIFI连接STA超时时间

Parameters

sec – WIFI连接STA超时时间,单位为秒,工程中默认为60秒

void wifi_set_connect_sta_block(int block)

wifi_set_connect_sta_block,用于设置WIFI连接STA是否阻塞, 默认非阻塞通过事件通知

Parameters

block – 使能端,置1:阻塞,置为0:不阻塞

int wifi_enter_sta_mode(char *sta_ssid, char *sta_pwd)

wifi_enter_sta_mode,用于设置WIFI进入STA模式

Parameters
  • sta_ssid – 配置STA模式的SSID

  • sta_pwd – 配置STA模式的密码

int wifi_scan_req(void)

wifi_scan_req,用于WIFI STA模式或者AP模式下启动一次扫描空中SSID

Note

STA模式下调用返回-1代表WIFI OFF/正在扫描/连接中,无需启动扫描, 可以等待几秒或者扫描完成事件到来获取结果

struct wifi_scan_ssid_info *wifi_get_scan_result(u32 *ssid_cnt)

wifi_get_scan_result,用于启动一次扫描空中SSID后,获取扫描结果

void wifi_clear_scan_result(void)

wifi_clear_scan_result,用于获取扫描结果后,清空上次扫描结果

int wifi_get_stored_sta_info(struct wifi_stored_sta_info wifi_stored_sta_info[])

wifi_get_stored_sta_info,用于获取WIFI保存过的SSID

Note

返回WIFI保存过的SSID数目

char wifi_get_rssi(void)

wifi_get_rssi,用于获取WIFI连接的STA接收信号强度

Note

返回WIFI连接的STA接收信号强度

char wifi_get_cqi(void)

wifi_get_cqi,用于获取WIFI连接的STA信号质量

Note

返回WIFI连接的STA通信丢包质量,0-100,一般认为大于50为较好,20-50之间为一般,小于20较差, decide ChannelQuality based on: 1)last BEACON received time, 2)last RSSI权重50, 3)TxPER权重30, and 4)RxPER权重20

enum wifi_sta_connect_state wifi_get_sta_connect_state(void)

wifi_get_sta_connect_state,用于获取WIFI是连接STA状态

Note

返回WIFI连接STA的状态

int wifi_enter_smp_cfg_mode(void)

wifi_enter_smp_cfg_mode,用于设置WIFI进入配网模式/monitor模式

void wifi_set_smp_cfg_timeout(int sec)

wifi_set_smp_cfg_timeout,用于设置WIFI配网超时事件时间

Parameters

sec – WIFI配网超时时间,单位为秒

void wifi_set_smp_cfg_scan_all_channel(char onoff)

wifi_set_smp_cfg_scan_all_channel,用于设置WIFI配网模式/monitor模式下是否扫描全部信道,默认否

Parameters

onoff – 全扫描开关,1:开启,0:关闭

void wifi_set_smp_cfg_airkiss_recv_ssid(char onoff)

wifi_set_smp_cfg_airkiss_recv_ssid,用于设置WIFI airkiss配网模式下是否接收完整的SSID,默认否,有助于加快配网时效,有概率配网失败

Parameters

onoff – 全扫描开关,1:开启,0:关闭

void wifi_set_smp_cfg_just_monitor_mode(char onoff)

wifi_set_smp_cfg_just_monitor_mode,用于设置WIFI进入配网/monitor模式后,是否只保留monitor模式,默认否

Parameters

onoff – 全扫描开关,1:开启,0:关闭

void wifi_set_monitor_mode_scan_channel_time(int time_ms)

wifi_set_monitor_mode_scan_channel_time,用于在WIFI只保留monitor模式的情况下,设置扫描每个信道的时间间隔

Parameters

time_ms – 扫描每个信道的时间间隔,单位为ms

void wifi_set_airkiss_key(u8 key[16])

wifi_set_airkiss_key,用于设置WIFI配网模式下airkiss的key

Parameters

key – 为WIFI配网模式下airkiss的key数组

int wifi_get_cfg_net_result(struct smp_cfg_result *smp_cfg)

wifi_get_cfg_net_result,用于配网成功后获取WIFI配网信息

void wifi_set_channel(u8 ch)

wifi_set_channel,用于设置WIFI当前信道

Parameters

ch – 要设置的WIFI信道

void wifi_wsc_start(const char *ssid, const char *pincode, int mode)

wifi_wsc_start,用于设置wifi的WSC模式

Parameters
  • ssid – 要设置的ssid信道

  • ssid – 设置pincode值

  • mode – WSC_CFG_MODE

u8 *wifi_get_payload_ptr(void)

wifi_get_payload_ptr,用于获取WIFI底层接口填充payload指针

u8 *wifi_get_wifi_send_pkg_ptr(void)

wifi_get_payload_ptr,用于获取WIFI底层接口MAC地址配置地址用于双机对传不走wifi私有协议2.4g

void wifi_send_data(int len, enum wifi_tx_rate rate)

wifi_send_data,用于使用WIFI底层接口直接发送数据帧

Parameters
  • pkg – 要发送的数组

  • len – 发送数据的长度,最大2510字节

  • rate – WIFI发送速率

void wifi_set_long_retry(u8 retry)

wifi_set_long_retry,用于设置WIFI底层长帧重传次数

Parameters

retry – 为重传次数

void wifi_set_short_retry(u8 retry)

wifi_set_short_retry,用于设置WIFI底层短帧重传次数

Parameters

retry – 为重传次数

u32 wifi_get_remain_tx_queue(char ac_queue)

wifi_get_remain_tx_queue,用于获取WIFI底层发送队列剩余个数

Parameters

ac_queue – 为Qos优先级,用户无配置就是填0

Returns

剩余多少个包可填充,最大为 MAX_PACKETS_IN_QUEUE

void wifi_backoff_cfg(u8 cwmax)

wifi 最大backoff范围设置

Parameters

cwmax – 为最大backoff范围

u32 wifi_get_tbtt(void)

wifi_get_tbtt 获取 wifi 下一个 beacon 抵达的剩余预测时间

Returns

返回值范围 0 ~ 3FFFFF,单位为 us

u64 wifi_get_tsf(void)

wifi_get_tsf 获取 wifi TSF 计数器的值

Returns

返回值范围 0 ~ FFFFFFFFFFFFFFFF,单位为 us