提交 bb8d5764 编写于 作者: A Annie_wang

update docs

Signed-off-by: NAnnie_wang <annie.wangli@huawei.com>
上级 43d1aae5
...@@ -64,491 +64,926 @@ The relationships between the main modules are as follows: ...@@ -64,491 +64,926 @@ The relationships between the main modules are as follows:
The WLAN module provides the following types of APIs: The WLAN module provides the following types of APIs:
- WLAN APIs that can be directly called by drivers 1. Hardware Device Interface (HDI) and Hardware Abstraction Layer (HAL) APIs for upper-layer services
- APIs for vendors 2. APIs for vendors
- APIs for the HDI layer
3. WLAN APIs directly called by drivers
**Figure 3** WLAN driver APIs **Figure 3** WLAN driver APIs
![image](figures/WLAN_driver_APIs.png "WLAN Driver APIs") ![image](figures/WLAN_driver_APIs.png "WLAN Driver APIs")
- The WLAN Driver module provides APIs that you can directly use to create or release a **WifiModule**, connect to or disconnect from a WLAN hotspot, request or release a **NetBuf**, and convert between the **pbuf** structure of Lightweight IP (lwIP) and a **NetBuf**. - The WLAN module provides HDI APIs for upper-layer services (applicable to the standard system). **Table 1** describes the major APIs.
Tables 1 to 3 describe these APIs.
**Table 1** wifi_module.h (HDF-based WLAN driver development) **Table 1** IWlanInterface.idl
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| struct WifiModule \*WifiModuleCreate(const struct HdfConfigWifiModuleConfig \*config) | Creates a **WifiModule**.| | CreateFeature([in] int type, [out] struct HdfFeatureInfo ifeature);| Creates an **ifeature** instance.|
| void WifiModuleDelete(struct WifiModule \*module) | Deletes a **WifiModule** and releases its data.| | DestroyFeature([in] struct HdfFeatureInfo ifeature);| Destroys an **ifeature** instance.|
| int32_t DelFeature(struct WifiModule \*module, uint16_t featureType) | Deletes a feature from a **WifiModule**.| | GetPowerMode([in] struct HdfFeatureInfo ifeature, [out] unsigned char mode);| Obtains the power mode.|
| int32_t AddFeature(struct WifiModule \*module, uint16_t featureType, struct WifiFeature \*featureData) | Adds a feature to a **WifiModule**.| | SetPowerMode([in] struct HdfFeatureInfo ifeature, [in] unsigned char mode);| Sets the power mode.|
**Table 2** wifi_mac80211_ops.h - The WLAN module provides HAL APIs for upper-layer services (applicable to small and mini systems). **Table 2** and **Table 3** describe some APIs.
**Table 2** wifi_hal.h
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| int32_t (\*startAp)(NetDevice \*netDev) | Starts an AP.| | int32_t WifiConstruct(struct IWiFi \*\*wifiInstance)| Creates an **IWiFi** instance with basic capabilities.|
| int32_t (\*stopAp)(NetDevice \*netDev) | Stops an AP.| | int32_t WifiDestruct(struct IWiFi \*\*wifiInstance)| Destroys an **IWiFi** instance.|
| int32_t (\*connect)(NetDevice \*netDev, WifiConnectParams \*param) | Connects to a hotspot.| | int32_t (\*start)(struct IWiFi \*)| Creates a channel between the HAL and the driver and obtains the NICs supported by the driver.|
| int32_t (\*disconnect)(NetDevice \*netDev, uint16_t reasonCode) | Disconnects from a hotspot.| | int32_t (\*stop)(struct IWiFi \*)| Stops the channel between the HAL and the driver.|
**Table 3** hdf_netbuf.h **Table 3** wifi_hal_base_feature.h
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| static inline void NetBufQueueInit(struct NetBufQueue \*q) | Initializes a **NetBuf** queue.| | int32_t (\*getFeatureType)(const struct IWiFiBaseFeature \*)| Obtains the feature type.|
| struct NetBuf \*NetBufAlloc(uint32_t size) | Allocates a **NetBuf**.| | int32_t (\*setMacAddress)(const struct IWiFiBaseFeature \*, unsigned char \*, uint8_t)| Sets the MAC address.|
| void NetBufFree(struct NetBuf \*nb) | Releases a **NetBuf**.| | int32_t (\*getDeviceMacAddress)(const struct IWiFiBaseFeature \*, unsigned char \*, uint8_t)| Obtains the device MAC address.|
| struct NetBuf \*Pbuf2NetBuf(const struct NetDevice \*netdev, struct pbuf \*lwipBuf) | Converts the **pbuf** structure of lwIP to a **NetBuf**.| | int32_t (\*setTxPower)(const struct IWiFiBaseFeature \*, int32_t)| Sets the transmit power.|
| struct pbuf \*NetBuf2Pbuf(const struct NetBuf \*nb) | Converts a **NetBuf** to the **pbuf** structure of lwIP.|
- The WLAN Driver module also provides APIs that you need to fill in the implementation. This type of APIs can be used to initialize/deinitialize a **NetDevice**, opening/stopping a **NetDevice**, and obtaining the **NetDevice** status. Table 4 describes some of these APIs. - The WLAN Driver module also provides APIs that you need to fill in the implementation. **Table 4** describes some APIs.
**Table 4** net_device.h **Table 4** net_device.h
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| int32_t (\*init)(struct NetDevice \*netDev) | Initializes a **NetDevice**.| | int32_t (\*init)(struct NetDevice \*netDev) | Initializes a network device. |
| struct NetDevStats \*(\*getStats)(struct NetDevice \*netDev) | Obtains the state of a **NetDevice**.| | struct NetDevStats \*(\*getStats)(struct NetDevice \*netDev) | Obtains the state of a network device. |
| int32_t (\*setMacAddr)(struct NetDevice \*netDev, void \*addr) | Sets the MAC address.| | int32_t (\*setMacAddr)(struct NetDevice \*netDev, void \*addr) | Sets the MAC address.|
| void (\*deInit)(struct NetDevice \*netDev) | Deinitializes a **NetDevice**.| | void (\*deInit)(struct NetDevice \*netDev) | Deinitializes a network device. |
| int32_t (\*open)(struct NetDevice \*netDev) | Opens a **NetDevice**.| | int32_t (\*open)(struct NetDevice \*netDev) | Opens a network device. |
| int32_t (\*stop)(struct NetDevice \*netDev) | Stops a **NetDevice**.| | int32_t (\*stop)(struct NetDevice \*netDev) | Stops a network device. |
- The WLAN Driver module provides APIs that you can directly use to create or release a **WifiModule**, connect to or disconnect from a WLAN hotspot, request or release a **NetBuf**, and convert between the **pbuf** structure of Lightweight IP (lwIP) and a **NetBuf**.
- The WLAN Driver module also provides APIs to the HDI layer for creating and destroying an **IWiFi** object and setting the MAC address. Tables 5 and 6 describe some of the APIs. Tables 5 to 7 describe the APIs.
**Table 5** wifi_hal.h **Table 5** wifi_module.h
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| int32_t WifiConstruct(struct IWiFi \*\*wifiInstance) | Creates an **IWiFi** object with basic capabilities.| | struct WifiModule \*WifiModuleCreate(const struct HdfConfigWifiModuleConfig \*config) | Creates a **WifiModule**.|
| int32_t WifiDestruct(struct IWiFi \*\*wifiInstance) | Destroys an **IWiFi** object.| | void WifiModuleDelete(struct WifiModule \*module) | Deletes a **WifiModule** and releases its data.|
| int32_t (\*start)(struct IWiFi \*) | Creates a channel between the HAL and the driver and obtains the NICs supported by the driver.| | int32_t DelFeature(struct WifiModule \*module, uint16_t featureType) | Deletes a feature from a **WifiModule**.|
| int32_t (\*stop)(struct IWiFi \*) | Stops the channel between the HAL and the driver.| | int32_t AddFeature(struct WifiModule \*module, uint16_t featureType, struct WifiFeature \*featureData) | Adds a feature to a **WifiModule**.|
**Table 6** wifi_hal_base_feature.h **Table 6** wifi_mac80211_ops.h
| API| Description| | API| Description|
| -------- | -------- | | -------- | -------- |
| int32_t (\*getFeatureType)(const struct IWiFiBaseFeature \*) | Obtains the feature type.| | int32_t (\*startAp)(NetDevice \*netDev) | Starts an AP.|
| int32_t (\*setMacAddress)(const struct IWiFiBaseFeature \*, unsigned char \*, uint8_t) | Sets the MAC address.| | int32_t (\*stopAp)(NetDevice \*netDev) | Stops an AP.|
| int32_t (\*getDeviceMacAddress)(const struct IWiFiBaseFeature \*, unsigned char \*, uint8_t) | Obtains the device MAC address.| | int32_t (\*connect)(NetDevice \*netDev, WifiConnectParams \*param) | Connects to a hotspot.|
| int32_t (\*setTxPower)(const struct IWiFiBaseFeature \*, int32_t) | Sets the transmit power.| | int32_t (\*disconnect)(NetDevice \*netDev, uint16_t reasonCode) | Disconnects from a hotspot.|
**Table 7** hdf_netbuf.h
| API| Description|
| -------- | -------- |
| static inline void NetBufQueueInit(struct NetBufQueue \*q) | Initializes a **NetBuf** queue.|
| struct NetBuf \*NetBufAlloc(uint32_t size) | Allocates a **NetBuf**.|
| void NetBufFree(struct NetBuf \*nb) | Releases a **NetBuf**.|
| struct NetBuf \*Pbuf2NetBuf(const struct NetDevice \*netdev, struct pbuf \*lwipBuf) | Converts the **pbuf** structure of lwIP to a **NetBuf**.|
| struct pbuf \*NetBuf2Pbuf(const struct NetBuf \*nb) | Converts a **NetBuf** to the **pbuf** structure of lwIP.|
### How to Develop ### How to Develop
The WLAN driver module developed based on the HDF and Platform frameworks provides a unified driver model for WLAN modules of different vendors regardless of the OS and system on a chip (SoC). The WLAN driver module developed based on the HDF and Platform frameworks provides a unified driver model for WLAN modules of different vendors regardless of the OS and system on a chip (SoC).
1. Configure hardware (such as modules and chips) parameters in the **wlan_platform.hcs** file. This file can be parsed by the APIs in the HDF to generate structure objects with full configuration.
1. Configure hardware (such as modules and chips) parameters in the **wifi_config.hcs** file. This configuration file is parsed by the corresponding API in the HDF to generate a structure object for full configuration. 2. Implement initialization and deinitialization of the WLAN module (such as initialize and deinitialize the WLAN chip and WLAN chip driver).
2. Initialize and create a module. 3. Implement the delivery of control flow commands.
3. Attach and initialize the chip. 4. Implement event reporting.
4. Implement the upper-layer Wi-Fi Protected Access (WPA) service.
### Development Example ### Development Example
This example describes how to initialize a WLAN module. The following uses the Hi3881 WLAN chip as an example: The following uses the Hi3881 WLAN chip as an example to describe how to initialize a WLAN module.
1. Set parameters for the WLAN module based on hardware attributes. 1. Configure hardware parameters.
``` ```text
/* Set parameters in the wlan_platform.hcs file based on hardware attributes. The following is an example of the WLAN platform configuration. */ /* Configure parameters in wlan_platform.hcs based on the hardware you use. The following is an example of WLAN platform configuration. */
hisi :& deviceList { hisi :& deviceList {
device0 :: deviceInst { device0 :: deviceInst {
deviceInstId = 0; deviceInstId = 0;
powers { powers {
power0 { power0 {
powerSeqDelay = 0; /* Power sequence delay. */ powerSeqDelay = 0; /* Power sequence delay. */
powerType = 1; /* Power supply type. The value 0 indicates that the device is always powered on, and 1 indicates power supply through general-purpose input/output (GPIO). */ powerType = 1; /* Power supply type. The value 0 indicates that the device is always on. The value 1 indicates power supply through GPIO. */
gpioId = 1; /* GPIO pin number. */ gpioId = 1; /* GPIO pin number. */
activeLevel=1; /* Active level. The value 0 indicates low level, and 1 indicates high level. */ activeLevel=1; /* Active level. The value 0 indicates low level, and 1 indicates high level. */
}
power1 {
powerSeqDelay = 0; /* Power sequence delay. */
powerType = 0; /* Power supply type. The value 0 indicates that the device is always on. The value 1 indicates power supply through GPIO. */
}
} }
power1 { reset {
powerSeqDelay = 0; /* Power sequence delay. */ resetType = 0; /* Reset type. The value 0 indicates that reset is dynamically determined, and 1 indicates reset through GPIO. */
powerType = 0; /* The value 0 indicates that the device is always powered on, and 1 indicates power supply through GPIO. */ gpioId = 2; /* GPIO pin number. */
activeLevel=1; /* Active level. The value 0 indicates low level, and 1 indicates high level. */
resetHoldTime = 30; /* Hold time (ms) after a reset. */
}
bootUpTimeout = 30; /* Boot timeout duration (ms). */
bus {
busEnable = 1; /* Whether to initialize the bus. The value 1 means to initialize the bus; the value 0 means the opposite. */
busType = 0; /* Bus type. The value 0 indicates SDIO. */
busId = 2; /* Bus number. */
funcNum = [1]; /* SDIO function number. */
timeout = 1000; /* Timeout duration for data read/write. */
blockSize = 512; /* Size of the data block to read or write. */
} }
}
reset {
resetType = 0; /* Reset type. The value 0 indicates that reset is dynamically determined, and value 1 indicates reset through GPIO. */
gpioId = 2; /* GPIO pin number. */
activeLevel=1; /* Active level. The value 0 indicates low level, and 1 indicates high level. */
resetHoldTime = 30; /* Hold time (ms) after a reset. */
}
bootUpTimeout = 30; /* Boot timeout duration (ms). */
bus {
busType = 0; /* Bus type. The value 0 indicates SDIO. */
busId = 2; /* Bus number. */
funcNum = [1]; /* SDIO function number. */
timeout = 1000; /* Timeout duration for data read/write. */
blockSize = 512; /* Size of the data block to read or write. */
} }
} }
} /* Add the configuration file wlan_chip_<Chip name>.hcs (for example, wlan_chip_hi3881.hcs) for each chip and set parameters. The following uses the Hi3881 chip as an example. */
/* Add the configuration file wlan_chip_<Chip name>.hcs (for example, wlan_chip_hi3881.hcs) for each chip and set parameters. The following uses the Hi3881 chip as an example. */ root {
root { wlan_config {
wlan_config { hi3881 :& chipList {
hi3881 :& chipList { chipHi3881 :: chipInst {
chipHi3881 :: chipInst { match_attr = "hdf_wlan_chips_hi3881"; /* Attribute used to match the chip. */
match_attr = "hdf_wlan_chips_hi3881"; /* Attribute used to match the chip. */ chipName = "hi3881"; /* WLAN chip name. */
chipName = "hi3881"; /* WLAN chip name. */ bus {
sdio { vendorId = 0x0296; /* Vendor ID. */
vendorId = 0x0296; /* Vendor ID. */ deviceId = [0x5347]; /* Device ID. */
deviceId = [0x5347]; /* Device ID. */ }
} }
} }
} }
} }
} ```
```
2. Hook the **init** and **deinit** functions of the WLAN chip and WLAN chip driver.
2. Hook the **init** and **deinit** functions of the WLAN chip and WLAN chip driver.
```c
``` #include "hdf_device_desc.h"
/* Process of implementing WLAN module initialization. */ #include "hdf_wifi_product.h"
#include "hdf_device_desc.h" #include "hdf_log.h"
#include "hdf_wifi_product.h" #include "osal_mem.h"
#include "hdf_log.h" #include "hdf_wlan_chipdriver_manager.h"
#include "osal_mem.h" #include "securec.h"
#include "hdf_wlan_chipdriver_manager.h" #include "wifi_module.h"
#include "securec.h" #include "hi_wifi_api.h"
#include "wifi_module.h" #include "hi_types_base.h"
#include "hi_wifi_api.h"
#include "hi_types_base.h" #define HDF_LOG_TAG Hi3881Driver
#define HDF_LOG_TAG Hi3881Driver /* Functions for initializing and deinitializing a WLAN chip. */
int32_t InitHi3881Chip(struct HdfWlanDevice *device);
/* Functions for initializing and deinitializing a WLAN chip. */ int32_t DeinitHi3881Chip(struct HdfWlanDevice *device);
int32_t InitHi3881Chip(struct HdfWlanDevice *device); /* Functions for initializing and deinitializing a WLAN chip driver. */
int32_t DeinitHi3881Chip(struct HdfWlanDevice *device); int32_t Hi3881Deinit(struct HdfChipDriver* chipDriver, struct NetDevice *netDevice);
/* Functions for initializing and deinitializing a WLAN chip driver. */ int32_t Hi3881Init(struct HdfChipDriver* chipDriver, struct NetDevice *netDevice);
int32_t Hi3881Deinit(struct HdfChipDriver* chipDriver, struct NetDevice *netDevice);
int32_t Hi3881Init(struct HdfChipDriver* chipDriver, struct NetDevice *netDevice); /* Initialize mac80211 by hooking the functions of the chip. */
hi_void HiMac80211Init(struct HdfChipDriver *chipDriver);
/* Initialize mac80211 by hooking the functions of the chip. */
hi_void HiMac80211Init(struct HdfChipDriver *chipDriver); static const char* const HI3881_DRIVER_NAME = "hisi";
static const char* const HI3881_DRIVER_NAME = "hisi"; /* Hook the functions of the WLAN chip driver, mac80211, and chip. */
static struct HdfChipDriver *BuildHi3881Driver(struct HdfWlanDevice *device, uint8_t ifIndex)
/* Hook the functions of the WLAN chip driver, mac80211, and chip. */ {
static struct HdfChipDriver *BuildHi3881Driver(struct HdfWlanDevice *device, uint8_t ifIndex) struct HdfChipDriver *specificDriver = NULL;
{ if (device == NULL) {
struct HdfChipDriver *specificDriver = NULL; HDF_LOGE("%s fail: channel is NULL!", __func__);
if (device == NULL) { return NULL;
HDF_LOGE("%s fail : channel is NULL", __func__); }
return NULL; (void)ifIndex;
} specificDriver = (struct HdfChipDriver *)OsalMemCalloc(sizeof(struct HdfChipDriver));
(void)device; if (specificDriver == NULL) {
(void)ifIndex; HDF_LOGE("%s fail: OsalMemCalloc fail!", __func__);
specificDriver = (struct HdfChipDriver *)OsalMemCalloc(sizeof(struct HdfChipDriver)); return NULL;
if (specificDriver == NULL) { }
HDF_LOGE("%s fail: OsalMemCalloc fail!", __func__); if (memset_s(specificDriver, sizeof(struct HdfChipDriver), 0, sizeof(struct HdfChipDriver)) != EOK) {
return NULL; HDF_LOGE("%s fail: memset_s fail!", __func__);
} OsalMemFree(specificDriver);
if (memset_s(specificDriver, sizeof(struct HdfChipDriver), 0, sizeof(struct HdfChipDriver)) != EOK) { return NULL;
HDF_LOGE("%s fail: memset_s fail!", __func__); }
OsalMemFree(specificDriver);
return NULL; if (strcpy_s(specificDriver->name, MAX_WIFI_COMPONENT_NAME_LEN, HI3881_DRIVER_NAME) != EOK) {
HDF_LOGE("%s fail: strcpy_s fail!", __func__);
OsalMemFree(specificDriver);
return NULL;
}
specificDriver->init = Hi3881Init;
specificDriver->deinit = Hi3881Deinit;
HiMac80211Init(specificDriver);
return specificDriver;
} }
if (strcpy_s(specificDriver->name, MAX_WIFI_COMPONENT_NAME_LEN, HI3881_DRIVER_NAME) != EOK) { /* Release the WLAN chip driver. */
HDF_LOGE("%s fail : strcpy_s fail", __func__); static void ReleaseHi3881Driver(struct HdfChipDriver *chipDriver)
OsalMemFree(specificDriver); {
return NULL; if (chipDriver == NULL) {
return;
}
if (strcmp(chipDriver->name, HI3881_DRIVER_NAME) != 0) {
HDF_LOGE("%s:Not my driver!", __func__);
return;
}
OsalMemFree(chipDriver);
} }
specificDriver->init = Hi3881Init;
specificDriver->deinit = Hi3881Deinit; static uint8_t GetHi3881GetMaxIFCount(struct HdfChipDriverFactory *factory) {
(void)factory;
HiMac80211Init(specificDriver); return 1;
return specificDriver;
}
/* Release the WLAN chip driver. */
static void ReleaseHi3881Driver(struct HdfChipDriver *chipDriver)
{
if (chipDriver == NULL) {
return;
} }
if (strcmp(chipDriver->name, HI3881_DRIVER_NAME) != 0) {
HDF_LOGE("%s:Not my driver!", __func__); /* Register WLAN chip functions. */
return; static int32_t HDFWlanRegHisiDriverFactory(void)
{
static struct HdfChipDriverFactory tmpFactory = { 0 };
struct HdfChipDriverManager *driverMgr = NULL;
driverMgr = HdfWlanGetChipDriverMgr();
if (driverMgr == NULL) {
HDF_LOGE("%s fail: driverMgr is NULL!", __func__);
return HDF_FAILURE;
}
tmpFactory.driverName = HI3881_DRIVER_NAME;
tmpFactory.GetMaxIFCount = GetHi3881GetMaxIFCount;
tmpFactory.InitChip = InitHi3881Chip;
tmpFactory.DeinitChip = DeinitHi3881Chip;
tmpFactory.Build = BuildHi3881Driver;
tmpFactory.Release = ReleaseHi3881Driver;
tmpFactory.ReleaseFactory = NULL;
if (driverMgr->RegChipDriver(&tmpFactory) != HDF_SUCCESS) {
HDF_LOGE("%s fail: driverMgr is NULL!", __func__);
return HDF_FAILURE;
}
return HDF_SUCCESS;
} }
OsalMemFree(chipDriver);
} static int32_t HdfWlanHisiChipDriverInit(struct HdfDeviceObject *device)
{
static uint8_t GetHi3881GetMaxIFCount(struct HdfChipDriverFactory *factory) { (void)device;
(void)factory; return HDFWlanRegHisiDriverFactory();
return 1;
}
/* Register WLAN chip functions. */
static int32_t HDFWlanRegHisiDriverFactory(void)
{
static struct HdfChipDriverFactory tmpFactory = { 0 };
struct HdfChipDriverManager *driverMgr = NULL;
driverMgr = HdfWlanGetChipDriverMgr();
if (driverMgr == NULL && driverMgr->RegChipDriver != NULL) {
HDF_LOGE("%s fail: driverMgr is NULL!", __func__);
return HDF_FAILURE;
} }
tmpFactory.driverName = HI3881_DRIVER_NAME;
tmpFactory.GetMaxIFCount = GetHi3881GetMaxIFCount; struct HdfDriverEntry g_hdfHisiChipEntry = {
tmpFactory.InitChip = InitHi3881Chip; .moduleVersion = 1,
tmpFactory.DeinitChip = DeinitHi3881Chip; .Bind = HdfWlanHisiDriverBind,
tmpFactory.Build = BuildHi3881Driver; .Init = HdfWlanHisiChipDriverInit,
tmpFactory.Release = ReleaseHi3881Driver; .Release = HdfWlanHisiChipRelease,
tmpFactory.ReleaseFactory = NULL; .moduleName = "HDF_WLAN_CHIPS"
if (driverMgr->RegChipDriver(&tmpFactory) != HDF_SUCCESS) { };
HDF_LOGE("%s fail: driverMgr is NULL!", __func__);
return HDF_FAILURE; HDF_INIT(g_hdfHisiChipEntry);
```
For details about initialization of the chip and chip driver, see hdfinit_3881.c. The functions are as follows:
```c
#include "hdf_wifi_product.h"
#include "hi_wifi_api.h"
#if (_PRE_OS_VERSION_LINUX == _PRE_OS_VERSION)
#include "oal_thread.h"
#include "osal_time.h"
#endif
#include "wifi_mac80211_ops.h"
#include "wal_cfg80211.h"
#include "net_adapter.h"
#include "hdf_wlan_utils.h"
#define HDF_LOG_TAG Hi3881Driver
/* Initialize the WLAN chip. */
int32_t InitHi3881Chip(struct HdfWlanDevice *device)
{
uint8_t maxPortCount = 3;
int32_t ret = HI_SUCCESS;
uint8_t maxRetryCount = 3;
if (device == NULL || device->bus == NULL) {
HDF_LOGE("%s:NULL ptr!", __func__);
return HI_FAIL;
}
do {
if (ret != HI_SUCCESS) {
if (device->reset != NULL && device->reset->Reset != NULL) {
device->reset->Reset(device->reset);
}
HDF_LOGE("%s:Retry init hi3881!last ret=%d", __func__, ret);
}
ret = hi_wifi_init(maxPortCount, device->bus);
} while (ret != 0 && --maxRetryCount > 0);
if (ret != 0) {
HDF_LOGE("%s:Init hi3881 driver failed!", __func__);
return ret;
}
return HI_SUCCESS;
} }
return HDF_SUCCESS; /* Deinitializing the WLAN chip. */
} int32_t DeinitHi3881Chip(struct HdfWlanDevice *device)
{
static int32_t HdfWlanHisiChipDriverInit(struct HdfDeviceObject *device) (void)device;
{ int32_t ret = hi_wifi_deinit();
(void)device; if (ret != 0) {
return HDFWlanRegHisiDriverFactory(); HDF_LOGE("%s:Deinit failed!ret=%d", __func__, ret);
} }
return ret;
struct HdfDriverEntry g_hdfHisiChipEntry = {
.moduleVersion = 1,
.Init = HdfWlanHisiChipDriverInit,
.moduleName = "HDF_WLAN_CHIPS"
};
HDF_INIT(g_hdfHisiChipEntry);
```
```
#include "hdf_wifi_product.h"
#include "hi_wifi_api.h"
#if (_PRE_OS_VERSION_LINUX == _PRE_OS_VERSION)
#include "oal_thread.h"
#include "osal_time.h"
#endif
#include "wifi_mac80211_ops.h"
#include "wal_cfg80211.h"
#include "net_adapter.h"
#include "hdf_wlan_utils.h"
#define HDF_LOG_TAG Hi3881Driver
/* Function for initializing the WLAN chip. */
int32_t InitHi3881Chip(struct HdfWlanDevice *device)
{
uint8_t maxPortCount = 1;
int32_t ret = HI_SUCCESS;
uint8_t maxRetryCount = 2;
if (device == NULL) {
HDF_LOGE("%s:NULL ptr!", __func__);
return HI_FAIL;
} }
do { /* Initializing the WLAN chip driver. */
if (ret != HI_SUCCESS) { int32_t Hi3881Init(struct HdfChipDriver *chipDriver, struct NetDevice *netDevice)
if (device->reset != NULL && device->reset->Reset != NULL) { {
device->reset->Reset(device->reset); hi_u16 mode;
int32_t ret;
nl80211_iftype_uint8 type;
(void)chipDriver;
HDF_LOGI("%s: start...", __func__);
mode = wal_get_vap_mode();
if (mode >= WAL_WIFI_MODE_BUTT) {
oam_error_log1(0, 0, "wal_init_drv_netdev:: invalid mode[%d]", mode);
return HI_FAIL;
}
if (mode == WAL_WIFI_MODE_STA) {
type = NL80211_IFTYPE_STATION;
#ifdef _PRE_WLAN_FEATURE_P2P
if (InitNetdev(netDevice, NL80211_IFTYPE_P2P_DEVICE) != HI_SUCCESS) {
return HI_FAIL;
} }
HDF_LOGE("%s:Retry init hi3881!last ret=%d", __func__, ret); #endif
} else if (mode == WAL_WIFI_MODE_AP) {
type = NL80211_IFTYPE_AP;
} else {
oam_error_log1(0, 0, "wal_init_drv_netdev:: invalid mode[%d]", mode);
return HI_FAIL;
}
ret = wal_init_drv_wlan_netdev(type, WAL_PHY_MODE_11N, netDevice);
if (ret != HI_SUCCESS) {
oam_error_log2(0, OAM_SF_ANY, "wal_init_drv_netdev %s failed.l_return:%d\n", netDevice->name, ret);
} }
ret = hi_wifi_init(maxPortCount);
} while (ret != 0 && --maxRetryCount > 0);
if (ret != 0) {
HDF_LOGE("%s:Init hi3881 driver failed!", __func__);
return ret; return ret;
} }
return HI_SUCCESS;
} /* Deinitializing the WLAN chip driver. */
int32_t Hi3881Deinit(struct HdfChipDriver *chipDriver, struct NetDevice *netDevice)
/* Function for deinitializing the WLAN chip. */ {
int32_t DeinitHi3881Chip(struct HdfWlanDevice *device) int32_t ret;
{ (void)chipDriver;
(void)device; ret = DeinitNetdev(NL80211_IFTYPE_P2P_DEVICE);
int32_t ret = hi_wifi_deinit(); if (ret != HI_SUCCESS) {
if (ret != 0) { oam_error_log1(0, OAM_SF_ANY, "Hi3881Deinit: DeinitNetdev p2p device fail, ret = %d\n", ret);
HDF_LOGE("%s:Deinit failed!ret=%d", __func__, ret); return ret;
}
return wal_deinit_drv_wlan_netdev(netDevice);
} }
return ret; ```
}
During the chip initialization process, call **NetDeviceInit()** to initialize a network device, call **NetDeviceAdd()** to add the network device to a protocol stack, and hook function pointers of **netdev**.
/* Function for initializing the WLAN chip driver. */
int32_t Hi3881Init(struct HdfChipDriver *chipDriver, struct NetDevice *netDevice) ```c
{ hi_s32 wal_init_drv_wlan_netdev(nl80211_iftype_uint8 type, wal_phy_mode mode, oal_net_device_stru *netdev)
HDF_LOGI("%s: start...", __func__); {
hi_u16 mode = wal_get_vap_mode(); hi_char *ac_mode_str = NULL;
int32_t ret; hi_s32 ret;
nl80211_iftype_uint8 type; if (oal_unlikely(netdev == HI_NULL)) {
(void)chipDriver; oam_error_log0(0, OAM_SF_ANY, "{netdev is null!}");
return HI_ERR_CODE_PTR_NULL;
if (mode >= WAL_WIFI_MODE_BUTT) { }
oam_error_log1(0, 0, "wal_init_drv_netdev:: invalid mode[%d]", mode);
do {
/* Initialize the network device. */
ret = wal_init_netdev(type, netdev);
if (ret != HI_SUCCESS) {
break;
}
ret = wal_init_netif(type, netdev);
if (ret != HI_SUCCESS) {
break;
}
ac_mode_str = "11bgn";
if (mode == WAL_PHY_MODE_11G) {
ac_mode_str = "11bg";
} else if (mode == WAL_PHY_MODE_11B) {
ac_mode_str = "11b";
}
ret = wal_ioctl_set_mode(netdev, ac_mode_str);
} while (false);
if (ret != HI_SUCCESS) {
wal_deinit_wlan_vap(netdev);
oal_net_unregister_netdev(netdev);
oal_net_clear_netdev(netdev);
return HI_FAIL; return HI_FAIL;
} }
if (mode == WAL_WIFI_MODE_STA) { return HI_SUCCESS;
type = NL80211_IFTYPE_STATION;
} else if (mode == WAL_WIFI_MODE_AP) {
type = NL80211_IFTYPE_AP;
} else {
oam_error_log1(0, 0, "wal_init_drv_netdev:: invalid mode[%d]", mode);
return HI_FAIL;
} }
ret = wal_init_drv_wlan_netdev(type, WAL_PHY_MODE_11N, netDevice); /* Hook function pointers of netdev. For details, see NetDeviceInterFace. */
if (ret != HI_SUCCESS) { oal_net_device_ops_stru g_wal_net_dev_ops =
oam_error_log2(0, OAM_SF_ANY, "wal_init_drv_netdev %s failed.l_return:%d\n", netDevice->name, ret); {
.getStats = wal_netdev_get_stats,
.open = wal_netdev_open,
.stop = wal_netdev_stop,
.xmit = hmac_bridge_vap_xmit,
.ioctl = wal_net_device_ioctl,
.changeMtu = oal_net_device_change_mtu,
.init = oal_net_device_init,
.deInit = oal_net_free_netdev,
#if (defined(_PRE_WLAN_FEATURE_FLOWCTL) || defined(_PRE_WLAN_FEATURE_OFFLOAD_FLOWCTL))
.selectQueue = wal_netdev_select_queue,
#endif
.setMacAddr = wal_netdev_set_mac_addr,
#if (_PRE_OS_VERSION_LITEOS == _PRE_OS_VERSION)
.netifNotify = HI_NULL,
#endif
.specialEtherTypeProcess = SpecialEtherTypeProcess,
};
hi_s32 wal_init_netif(nl80211_iftype_uint8 type, oal_net_device_stru *netdev, const oal_wireless_dev *wdev)
{
/* Add the network device to the protocol stack. */
hi_u32 ret = NetDeviceAdd(netdev, (Protocol80211IfType)type);
...
return HI_SUCCESS;
} }
return ret; ```
}
/* Function for deinitializing the WLAN chip driver. */
int32_t Hi3881Deinit(struct HdfChipDriver *chipDriver, struct NetDevice *netDevice) 3. Bind the commands to be delivered, including setting the MAC address and transmit power, implement STA connection and scan, start APs, and setting the country code.
{
(void)chipDriver; ```c
int32_t ret = wal_deinit_drv_wlan_netdev(netDevice); /* Implement the basic capabilities of the MAC layer. */
if (ret != HDF_SUCCESS) { static struct HdfMac80211BaseOps g_baseOps = {
return ret; .SetMode = WalSetMode,
.AddKey = WalAddKey,
.DelKey = WalDelKey,
.SetDefaultKey = WalSetDefaultKey,
.GetDeviceMacAddr = WalGetDeviceMacAddr,
.SetMacAddr = WalSetMacAddr,
.SetTxPower = WalSetTxPower,
.GetValidFreqsWithBand = WalGetValidFreqsWithBand,
.GetHwCapability = WalGetHwCapability
};
/* Implement the STA capabilities of the MAC layer. */
static struct HdfMac80211STAOps g_staOps = {
.Connect = WalConnect,
.Disconnect = WalDisconnect,
.StartScan = WalStartScan,
.AbortScan = WalAbortScan,
.SetScanningMacAddress = WalSetScanningMacAddress,
};
/* Implement the AP capabilities of the MAC layer. */
static struct HdfMac80211APOps g_apOps = {
.ConfigAp = WalConfigAp,
.StartAp = WalStartAp,
.StopAp = WalStopAp,
.ConfigBeacon = WalChangeBeacon,
.DelStation = WalDelStation,
.SetCountryCode = WalSetCountryCode,
.GetAssociatedStasCount = WalGetAssociatedStasCount,
.GetAssociatedStasInfo = WalGetAssociatedStasInfo
};
static struct HdfMac80211P2POps g_p2pOps = {
.RemainOnChannel = WalRemainOnChannel,
.CancelRemainOnChannel = WalCancelRemainOnChannel,
.ProbeReqReport = WalProbeReqReport,
.AddIf = WalAddIf,
.RemoveIf = WalRemoveIf,
.SetApWpsP2pIe = WalSetApWpsP2pIe,
.GetDriverFlag = WalGetDriverFlag
};
/* Initialize mac80211 and hook functions of the chip. */
void HiMac80211Init(struct HdfChipDriver *chipDriver)
{
if (chipDriver == NULL) {
HDF_LOGE("%s:input is NULL!", __func__);
return;
}
chipDriver->ops = &g_baseOps;
chipDriver->staOps = &g_staOps;
chipDriver->apOps = &g_apOps;
chipDriver->p2pOps = &g_p2pOps;
}
```
4. Invoke the event reporting APIs.
The WLAN framework provides the event reporting APIs. For example, call **HdfWiFiEventNewSta AP** to report information about the newly associated STA. For details, see **hdf_wifi_event.c**.
```c
hi_u32 oal_cfg80211_new_sta(oal_net_device_stru *net_device, const hi_u8 *mac_addr, hi_u8 addr_len,
oal_station_info_stru *station_info, oal_gfp_enum_uint8 en_gfp)
{
#if (_PRE_OS_VERSION_LINUX == _PRE_OS_VERSION) && !defined(_PRE_HDF_LINUX)
cfg80211_new_sta(net_device, mac_addr, station_info, en_gfp);
hi_unref_param(addr_len);
#elif (_PRE_OS_VERSION_LITEOS == _PRE_OS_VERSION) || defined(_PRE_HDF_LINUX)
struct StationInfo info = { 0 };
info.assocReqIes = station_info->assoc_req_ies;
info.assocReqIesLen = station_info->assoc_req_ies_len;
HdfWifiEventNewSta(net_device, mac_addr, WLAN_MAC_ADDR_LEN, &info);
hi_unref_param(en_gfp);
hi_unref_param(addr_len);
#endif
return HI_SUCCESS;
} }
return ReleasePlatformNetDevice(netDevice); ```
} ## Verification
```
Develop test cases in the WLAN module unit test to verify the basic features of the WLAN module. The following uses Hi3516D V300 standard system as an example.
1. Set up the test environment.
- Create a **hostapd.conf** file (used to start the AP) and copy the following content to the file:
```text
interface=wlan0
driver=hdf wifi
ctrl_interface=udp
#Wi-Fi name
ssid=test
hw_mode=g
channel=1
ignore_broadcast_ssid=0
wpa=2
rsn_pairwise=CCMP
# Wi-Fi password.
wpa_passphrase=12345678
```
- Create a **wpa_supplicant.conf** file (used to start the STA) and copy the following content to the file:
```text
country=GB
network={
#Hotspot name
ssid="test"
#Hotspot password
psk="12345678"
}
```
- Create a **dhcpc.sh** file (used to write the IP address allocated by the udhcpc to the device) and copy the following content to the file:
```shell
#!/system/bin/sh
[ -z "$1" ] && echo "Error: should be called from udhcpc" && exit 1
RESOLV_CONF="/etc/resolv.conf"
[ -n "$broadcast" ] && BROADCAST="broadcast $broadcast"
[ -n "$subnet" ] && NETMASK="netmask $subnet"
case "$1" in
deconfig)
/system/bin/ifconfig $interface 0.0.0.0
;;
renew|bound)
/system/bin/ifconfig $interface $ip $BROADCAST $NETMASK
if [ -n "$router" ] ; then
echo "deleting routers"
while busybox route del default gw 0.0.0.0 dev $interface ; do
:
done
for i in $router ; do
busybox route add default gw $i dev $interface
done
fi
echo -n > $RESOLV_CONF
[ -n "$domain" ] && echo search $domain >> $RESOLV_CONF
for i in $dns ; do
echo adding dns $i
echo nameserver $i >> $RESOLV_CONF
done
;;
esac
3. During the chip initialization process, call **NetDeviceInit()** to initialize a network device, call **NetDeviceAdd()** to add the network device to a protocol stack, and hook function pointers of **netdev**. exit 0
```
``` - Create a **udhcpd.conf** file (used to start the **udhcpd**) and copy the following content to the file:
hi_s32 wal_init_drv_wlan_netdev(nl80211_iftype_uint8 type, wal_phy_mode mode, hi_char* ifname, hi_u32* len)
{
oal_net_device_stru *netdev = HI_NULL;
...... ```text
/* Initialize the network device and obtain the initialized instance. */ start 192.168.12.2
netdev = NetDeviceInit(ifname, *len, LITE_OS); end 192.168.12.100
oal_wireless_dev *wdev = (oal_wireless_dev *)oal_mem_alloc(OAL_MEM_POOL_ID_LOCAL, sizeof(oal_wireless_dev)); interface wlan0 #default: eth0
ret = wal_init_netif(type, netdev, wdev); max_leases 20 #default: 254
remaining yes #default: yes
auto_time 7200 #default: 7200 (2 hours)
decline_time 3600 #default: 3600 (1 hour)
conflict_time 3600 #default: 3600 (1 hour)
offer_time 60 #default: 60 (1 minute)
min_lease 60 #defult: 60
lease_file /vendor/etc/udhcpd.leases
opt dns 10.221.0.11 8.8.8.8
option subnet 255.255.255.0
opt router 192.168.12.1
```
...... - Run the following commands to push the files required for the test to the development board:
return HI_SUCCESS; ```shell
} hdc shell "mount -o rw,remount /"
/* Hook pointers of NetDeviceInterFace(). */ timeout /T 1
oal_net_device_ops_stru g_wal_net_dev_ops = hdc file send dhcpc.sh /system/lib/
{ hdc shell "chmod 777 /system/lib/dhcpc.sh"
.getStats = wal_netdev_get_stats, hdc file send wpa_supplicant.conf /
.open = wal_netdev_open, hdc shell "mount -o rw,remount /vendor"
.stop = wal_netdev_stop, hdc file send hostapd.conf /
.xmit = hmac_bridge_vap_xmit, hdc file send udhcpd.conf /vendor/etc
.ioctl = wal_net_device_ioctl, hdc shell "touch /vendor/etc/udhcpd.leases"
.changeMtu = oal_net_device_change_mtu, hdc shell "chmod 777 /vendor/etc/udhcpd.leases"
.init = oal_net_device_init, ```
.deInit = oal_net_free_netdev,
#if (defined(_PRE_WLAN_FEATURE_FLOWCTL) || defined(_PRE_WLAN_FEATURE_OFFLOAD_FLOWCTL)) 2. Verify basic Wi-Fi features.
.selectQueue = wal_netdev_select_queue,
#endif - Verify basic AP features.
.setMacAddr = wal_netdev_set_mac_addr,
#if (_PRE_OS_VERSION_LITEOS == _PRE_OS_VERSION) 1. Start the AP on the development board and enable Wi-Fi on the test terminal. For example, choose **Settings** > **WLAN** and turn on Wi-Fi on a mobile phone.
.netifNotify = HI_NULL,
#endif 2. Run the following command in the **cmd** window:
.specialEtherTypeProcess = SpecialEtherTypeProcess, ```shell
}; hdc shell
hostapd ./hostapd.conf
hi_s32 wal_init_netif(nl80211_iftype_uint8 type, oal_net_device_stru *netdev, const oal_wireless_dev *wdev) ```
{
/* Add the network device to a protocol stack. */ 3. Run the following commands in another **cmd** window:
hi_u32 ret = NetDeviceAdd(netdev, (Protocol80211IfType)type);
```shell
...... hdc shell
ifconfig wlan0 192.168.12.1 netmask 255.255.255.0
busybox udhcpd /vendor/etc/udhcpd.conf
```
4. On the mobile phone, select the network named **test** in the available Wi-Fi list and enter the password.
The network name and password are configured in the **hostapd.conf** file. You can see the network name in the connected Wi-Fi list if the connection is successful.
5. Ping the test terminal from the development board.
```shell
busybox ping xxx.xxx.xxx.xxx
```
In the command, xxx.xxx.xxx.xxx indicates the IP address of the test terminal. If the test terminal can be pinged, the basic features of the WLAN driver are implemented successfully.
- Verify basic STA features.
1. Start the STA on the development board, and enable the hotspot on the test terminal. (The hotspot name and password are configured in the **hostapd.conf** file. The hotspot name is **test**, and the password is **12345678**.)
2. Run the following command in the **cmd** window:
```shell
hdc shell
wpa_supplicant -i wlan0 -d -c wpa_supplicant.conf
```
3. Run the following commands in another **cmd** window:
```shell
hdc shell
mount -o rw,remount /
mount -o rw,remount /vendor
busybox udhcpc -i wlan0 -s system/lib/dhcpc.sh
```
The IP addresses of the board and test terminal are displayed if the command is successful.
4. Ping the test terminal from the development board.
```shell
busybox ping xxx.xxx.xxx.xxx
```
In the command, xxx.xxx.xxx.xxx indicates the IP address of the test terminal. If the test terminal can be pinged, the basic features of the WLAN driver are implemented successfully.
return HI_SUCCESS; 3. Verify the unit test cases.
}
``` To test a specified interface of the HDI module, perform the following steps:
4. Hook functions of **WifiMac80211Ops**. 1. Call **WlanInterfaceGetInstance()** to obtain a WLAN service instance.
2. Call **Start()** to create a channel between the HAL and the driver and obtain information about the driver network interface card (NIC).
```
/* Hook function pointers of mac80211. */ 3. Call **GetSupportFeature()** to obtain the WLAN features supported by the device.
/* Define the functions for implementing the basic capabilities in the MAC layer for the driver. */ 4. Call **Stop()** to destroy the channel between the HAL and the driver
static struct HdfMac80211BaseOps g_baseOps = {
.SetMode = WalSetMode, 5. Call **WlanInterfaceRelease()** to destroy the WLAN service instance.
.AddKey = WalAddKey,
.DelKey = WalDelKey, The sample code is as follows:
.SetDefaultKey = WalSetDefaultKey,
.GetDeviceMacAddr = WalGetDeviceMacAddr, ```c
.SetMacAddr = WalSetMacAddr, #include "v1_0/iwlan_interface.h"
.SetTxPower = WalSetTxPower, #include "wlan_callback_impl.h"
.GetValidFreqsWithBand = WalGetValidFreqsWithBand, #include "wlan_impl.h"
.GetHwCapability = WalGetHwCapability
}; #define PROTOCOL_80211_IFTYPE_NUM 11;
#define HDF_SUCCESS 0
/* Define the functions for implementing the STA capabilities in the MAC layer for the driver. */ #define HDF_FAILURE (-1)
static struct HdfMac80211STAOps g_staOps = {
.Connect = WalConnect, static int32_t hdi_main()
.Disconnect = WalDisconnect, {
.StartScan = WalStartScan, int32_t rc;
.AbortScan = WalAbortScan, const char *WLAN_SERVICE_NAME = "wlan_hal_c_service";
.SetScanningMacAddress = WalSetScanningMacAddress, static struct IWlanInterface *g_wlanObj = NULL;
}; uint8_t supType[PROTOCOL_80211_IFTYPE_NUM + 1] = {0};
uint32_t supTypeLen = PROTOCOL_80211_IFTYPE_NUM + 1;
/* Define the functions for implementing the AP capabilities in the MAC layer for the driver. */
static struct HdfMac80211APOps g_apOps = { /* Obtain the WLAN service instance. */
.ConfigAp = WalConfigAp, g_wlanObj = WlanInterfaceGetInstance(WLAN_SERVICE_NAME);
.StartAp = WalStartAp, if (g_wlanObj == NULL)
.StopAp = WalStopAp, {
.ConfigBeacon = WalChangeBeacon, return HDF_FAILURE;
.DelStation = WalDelStation, }
.SetCountryCode = WalSetCountryCode,
.GetAssociatedStasCount = WalGetAssociatedStasCount, /* Create a channel between the HAL and the driver and obtain the driver NIC information. */
.GetAssociatedStasInfo = WalGetAssociatedStasInfo rc = g_wlanObj->Start(g_wlanObj);
}; if (rc != HDF_SUCCESS)
{
/* Initialize mac80211 and hook functions of the chip. */ return HDF_FAILURE;
hi_void HiMac80211Init(struct HdfChipDriver *chipDriver) }
{
if (chipDriver == NULL) { /* Obtain the WLAN features supported by the device irrespective of the device status (AP, STA, or P2P).
oam_error_log(0, OAM_SF_ANY, "%s:input is NULL!", __func__); rc = g_wlanObj->GetSupportFeature(g_wlanObj, supType, &supTypeLen);
return; if (rc != HDF_SUCCESS)
{
return HDF_FAILURE;
}
/* Destroy the channel between the HAL and the driver. */
rc = g_wlanObj->Stop(g_wlanObj);
if (rc != HDF_SUCCESS)
{
return HDF_FAILURE;
}
/* Destroy the WLAN service instance. */
rc = WlanInterfaceRelease(g_wlanObj);
if (rc != HDF_SUCCESS)
{
return HDF_FAILURE;
}
return rc;
} }
chipDriver->ops = &g_baseOps; ```
chipDriver->staOps = &g_staOps;
chipDriver->apOps = &g_apOps; To test a specified interface of the HAL module, perform the following steps:
}
``` 1. Call **WifiConstruct()** to create an **IWiFi** instance.
2. Use the created **IWiFi** instance to call **start()** to create a channel between the HAL and the driver and obtain the driver NIC information.
3. Call **createFeature()** to create an **apFeature** or **staFeature**. These features can be used to invoke specific APIs. The following uses the **apFeature** instance as an example.
4. Call related APIs, for example, call **setMacAddress()** to set the MAC address and call **getDeviceMacAddress()** to obtain the device MAC address.
5. Call **destroyFeature()** to destroy the **apFeature** instance.
6. Call **stop()** to destroy the channel between the HAL and the driver.
7. Call **WifiDestruct()** to destroy the **IWiFi** instance.
The sample code is as follows:
```c
#include "wifi_hal.h"
#include "wifi_hal_sta_feature.h"
#include "wifi_hal_ap_feature.h"
#include "wifi_hal_cmd.h"
#include "wifi_hal_event.h"
#define MAC_LEN 6
#define HDF_SUCCESS 0
#define HDF_FAILURE (-1)
static int32_t hal_main()
{
int32_t ret;
struct IWiFi *wifi;
/* Create an IWiFi instance. */
ret = WifiConstruct(&wifi);
if (ret != HDF_SUCCESS || wifi == NULL) {
return HDF_FAILURE;
}
/* Create a channel between the HAL and the driver and obtain the driver NIC information. */
ret = wifi->start(wifi);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
/* Create an apFeature instance. */
ret = wifi->createFeature(PROTOCOL_80211_IFTYPE_AP, (struct IWiFiBaseFeature **)&apFeature);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
/* Obtain the MAC address of the device. */
unsigned char mac[MAC_LEN] = {0};
ret = apFeature->baseFeature.getDeviceMacAddress((struct IWiFiBaseFeature *)apFeature, mac, MAC_LEN);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
/* Destroy the apFeature instance. */
ret = wifi->destroyFeature((struct IWiFiBaseFeature *)apFeature);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
/* Destroy the channel between the HAL and the driver. */
ret = wifi->stop(wifi);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
/* Destroy the IWiFi instance. */
ret = WifiDestruct(&wifi);
if (ret != HDF_SUCCESS) {
return HDF_FAILURE;
}
return ret;
}
```
4. Verify the test cases.
1. Push the test cases to the development board.
```shell
hdc file send /xxx /data
```
In the command, xxx indicates the path of the test cases of the development board.
2. Modify the permissions on the test cases and execute the test cases.
```shell
hdc shell
cd data
chmod 777 Test_case_name
./ Test case name.
```
3. Check the test case execution result.
## Reference ## Reference
- Code repositories: - Code repositories:
[drivers\_hdf\_core](https://gitee.com/openharmony/drivers_hdf_core) **[drivers\_hdf\_core](https://gitee.com/openharmony/drivers_hdf_core)**
[drivers\_peripheral](https://gitee.com/openharmony/drivers_peripheral) [drivers\_peripheral](https://gitee.com/openharmony/drivers_peripheral)
[drivers\_interface](https://gitee.com/openharmony/drivers_interface)
- Code paths: - Code paths:
Adaptation of WLAN FlowCtl component on LiteOS: **//drivers/hdf_core/adapter/khdf/liteos/model/network/wifi** - Adaptation of WLAN FlowCtl component on LiteOS:
**//drivers/hdf_core/adapter/khdf/liteos/model/network/wifi**
Adaptation of HDF network model on LiteOS: **//drivers/hdf_core/adapter/khdf/liteos/model/network** - Adaptation of HDF network model on LiteOS:
Adaptation of WLAN FlowCtl component on Linux, build of the HDF WLAN model, and build of the vendor's WLAN driver: **//drivers/hdf_core/adapter/khdf/liteos/model/network**
**//drivers/hdf_core/adapter/khdf/linux/model/network/wifi** - Adaptation of WLAN FlowCtl component on Linux, build of the HDF WLAN model, and build of the vendor's WLAN driver:
Core code for implementing the WLAN module: **//drivers/hdf_core/framework/model/network/wifi** **//drivers/hdf_core/adapter/khdf/linux/model/network/wifi**
External APIs of the WLAN module: **//drivers/hdf_core/framework/include/wifi** - Core code for implementing the WLAN module:
HDF network model APIs: **//drivers/hdf_core/framework/include/net** **//drivers/hdf_core/framework/model/network/wifi**
WLAN HDI APIs and implementation: **//drivers/peripheral/wlan** - External APIs of the WLAN module:**//drivers/hdf_core/framework/include/wifi**
- HDF network model APIs:
**//drivers/hdf_core/framework/include/net**
- WLAN HDI server implementation:
**//drivers/peripheral/wlan**
- External APIs of the WLAN HDI:
**//out/{product_name}/gen/drivers/interface/wlan/v1_0**
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册