本文來(lái)源電子發(fā)燒友社區(qū),作者:ouxiaolong, 帖子地址:https://bbs.elecfans.com/jishu_2286198_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
1.新建工程及源碼
1) 新建目錄
$ mkdir hello
在applications/sample/myapp中新建src目錄以及myapp.c文件,代碼如下所示。
#include
#include "ohos_init.h"
#include"ohos_types.h"
void app_task(void)
{
printf("n");
printf("Hello hi3861!n");
printf("n");
}
SYS_RUN(app_task);
2) 新建編譯組織文件
新建applications/sample/myapp/BUILD.gn文件,內(nèi)容如下所示:
static_library("myapp"){
sources = [
"src/myapp.c"
include_dirs = [
"http://utils/native/lite/include"
}
static_library中指定業(yè)務(wù)模塊的編譯結(jié)果,為靜態(tài)庫(kù)文件libmyapp.a,開(kāi)發(fā)者根據(jù)實(shí)際情況完成填寫(xiě)。
sources中指定靜態(tài)庫(kù).a所依賴(lài)的.c文件及其路徑,若路徑中包含"http://"則表示絕對(duì)路徑(此處為代碼根路徑),若不包含"http://"則表示相對(duì)路徑。
include_dirs中指定source所需要依賴(lài)的.h文件路徑
新建的工程目錄如下:
$ tree

2.添加新組件
修改文件build/lite/components/applications.json,添加組件hello_world_app的配置。
{
"component": "my_app",
"description": "appsamples.",
"optional": "true",
"dirs": [
"applications/sample/myapp"
],
"targets": [
"http://applications/sample/myapp:myapp"
],
"rom": "",
"ram": "",
"output": [],
"features": [],
"deps": {
"components": [],
"third_party": []
}
},

3.修改單板配置文件
修改文件vendor/hisilicon/hispark_pegasus/config.json,新增my_app組件的條目。
{
"subsystem":"applications",
"components": [
{ "component": "wifi_iot_sample_app", "features":[] }
{ "component":"my_app", "features":[] }
},

4.關(guān)閉xts測(cè)試子系統(tǒng)。
系統(tǒng)每次開(kāi)機(jī)后都要跑xts認(rèn)證程序,這里先刪除該部分內(nèi)容。

接下來(lái)就可以編譯了。
$ hb set

全編譯。
$ hb build -f

成功編譯后,固件在out/hispark_pegasus/wifiiot_hispark_pegasus目錄下。

Hi3861_wifiiot_app_allinone.bin就是需要燒寫(xiě)的固件。
然后把固件下載到板子中。

接下來(lái)就可以根據(jù)該實(shí)例開(kāi)發(fā)自己的應(yīng)用了。
下面簡(jiǎn)單分析下系統(tǒng)的啟動(dòng)流程,系統(tǒng)的入口函數(shù)是app_main(),在device/hisilicon/hispark_pegasus/sdk_liteos/app/wifiiot_app/src/app_main.c文件中。
hi_void app_main(hi_void)
{
#ifdef CONFIG_FACTORY_TEST_MODE
printf("factory testmode!rn");
#endif
const hi_char* sdk_ver =hi_get_sdk_version();
printf("sdk ver:%srn",sdk_ver);
hi_flash_partition_table *ptable = HI_NULL;
peripheral_init();
peripheral_init_no_sleep();
#ifndef CONFIG_FACTORY_TEST_MODE
hi_lpc_register_wakeup_entry(peripheral_init);
#endif
hi_u32 ret =hi_factory_nv_init(HI_FNV_DEFAULT_ADDR, HI_NV_DEFAULT_TOTAL_SIZE,HI_NV_DEFAULT_BLOCK_SIZE);
if (ret != HI_ERR_SUCCESS) {
}
/* partion table should init after factorynv init. */
ret = hi_flash_partition_init();
if (ret != HI_ERR_SUCCESS) {
printf("flash partition table initfail:0x%x rn", ret);
}
ptable = hi_get_partition_table();
ret =hi_nv_init(ptable->table[HI_FLASH_PARTITON_NORMAL_NV].addr,ptable->table[HI_FLASH_PARTITON_NORMAL_NV].size,
HI_NV_DEFAULT_BLOCK_SIZE);
if (ret != HI_ERR_SUCCESS) {
printf("nv init failrn");
}
#ifndef CONFIG_FACTORY_TEST_MODE
hi_upg_init();
#endif
/* if not use file system, there is no needinit it */
hi_fs_init();
(hi_void)hi_event_init(APP_INIT_EVENT_NUM,HI_NULL);
hi_sal_init();
/* 此處設(shè)為T(mén)RUE后中斷中看門(mén)狗復(fù)位會(huì)顯示復(fù)位時(shí)PC值,但有復(fù)位不完全風(fēng)險(xiǎn),量產(chǎn)版本請(qǐng)務(wù)必設(shè)為FALSE */
hi_syserr_watchdog_debug(HI_FALSE);
/* 默認(rèn)記錄宕機(jī)信息到FLASH,根據(jù)應(yīng)用場(chǎng)景,可不記錄,避免頻繁異常宕機(jī)情況損耗FLASH壽命 */
hi_syserr_record_crash_info(HI_TRUE);
hi_lpc_init();
hi_lpc_register_hw_handler(config_before_sleep,config_after_sleep);
#if defined(CONFIG_AT_COMMAND)|| defined(CONFIG_FACTORY_TEST_MODE)
ret = hi_at_init();
if (ret == HI_ERR_SUCCESS) {
hi_at_sys_cmd_register();
}
#endif
/* 如果不需要使用Histudio查看WIFI驅(qū)動(dòng)運(yùn)行日志等,無(wú)需初始化diag */
/* if not use histudio for diagnostic, diaginitialization is unnecessary */
#ifndef CONFIG_FACTORY_TEST_MODE
#ifndef ENABLE_SHELL_DEBUG
#ifdef CONFIG_DIAG_SUPPORT
(hi_void)hi_diag_init();
#endif
#else
(hi_void)hi_shell_init();
#endif
tcpip_init(NULL, NULL);
#endif
ret = hi_wifi_init(APP_INIT_VAP_NUM,APP_INIT_USR_NUM);
if (ret != HISI_OK) {
printf("wifi initfailed!n");
} else {
printf("wifi initsuccess!n");
}
app_demo_task_release_mem(); /* 釋放系統(tǒng)棧內(nèi)存所使用任務(wù) */
#ifndef CONFIG_FACTORY_TEST_MODE
app_demo_upg_init();
#ifdef CONFIG_HILINK
ret = hilink_main();
if (ret != HISI_OK) {
printf("hilink initfailed!n");
} else {
printf("hilink initsuccess!n");
}
#endif
#endif
OHOS_Main();
}
該函數(shù)首先打印SDK的版本信息,然后掛載文件系統(tǒng),初始化WiFi信息等等一系列初始化,接這就到OHOS_Main(),該函數(shù)就是OpenHarmony系統(tǒng)的初始化。OHOS_Main()函數(shù)在文件device/hisilicon/hispark_pegasus/sdk_liteos/app/wifiiot_app/src/ohos_main.c中。
void OHOS_Main()
{
#if defined(CONFIG_AT_COMMAND)|| defined(CONFIG_FACTORY_TEST_MODE)
hi_u32 ret;
ret = hi_at_init();
if (ret == HI_ERR_SUCCESS) {
hi_u32 ret2 =hi_at_register_cmd(G_OHOS_AT_FUNC_TBL, OHOS_AT_FUNC_NUM);
if (ret2 != HI_ERR_SUCCESS) {
printf("Register ohosfailed!n");
}
}
#endif
OHOS_SystemInit();
}
值得注意的是OHOS_SystemInit()函數(shù)是一個(gè)弱函數(shù),其定義如下:
void __attribute__((weak))OHOS_SystemInit(void)
{
return;
}
因此該函數(shù)主要是系統(tǒng)為應(yīng)用開(kāi)發(fā)者提供的。OHOS_SystemInit()函數(shù)在base/startup/bootstrap_lite/services/source/system_init.c文件中。
void OHOS_SystemInit(void)
{
MODULE_INIT(bsp);
MODULE_INIT(device);
MODULE_INIT(core);
SYS_INIT(service);
SYS_INIT(feature);
MODULE_INIT(run);
SAMGR_Bootstrap();
}
到這里基本就完成了所得初始化,其中我們編寫(xiě)的應(yīng)用就是MODULE_INIT(run)中完成的。
在base/startup/bootstrap_lite/services/source/core_main.h文件中,有如下定義:
MODULE_INIT定義如下:
#define MODULE_INIT(name)
do {
MODULE_CALL(name, 0);
} while (0)
MODULE_CALL定義如下:
#define MODULE_CALL(name,step)
do {
InitCall *initcall = (InitCall*)(MODULE_BEGIN(name, step));
InitCall *initend = (InitCall*)(MODULE_END(name, step));
for (; initcall < initend;initcall++) {? ?? ?? ?? ?? ?? ?? ?
(*initcall)();
}
} while (0)
模塊的名字定義如下:
#define MODULE_NAME(name, step) ".zinitcall."#name #step ".init"
而SYS_RUN在utils/native/lite/include/ohos_init.h中定義。
/**
*@BriefIdentifies the entry for initializingand starting a system running phase by the
* priority 2.
*
* This macro is used to identify the entrycalled at the priority 2 in the system startup
* phase of the startup process. n
*
*@paramfunc Indicates the entry function forinitializing and starting a system running phase.
* The type is void (*)(void).
*/
#define SYS_RUN(func)LAYER_INITCALL_DEF(func, run, "run")
而LAYER_INITCALL_DEF定義如下:
#define LAYER_INITCALL(func,layer, clayer, priority)
static__attribute__((constructor(CTOR_VALUE_##layer + LAYER_INIT_LEVEL_##priority)))
void BOOT_##layer##priority##func(){func();}
#else
#define LAYER_INITCALL(func,layer, clayer, priority)
static const InitCall USED_ATTR__zinitcall_##layer##_##func
__attribute__((section(".zinitcall." clayer #priority".init"))) = func
#endif
// Default priority is 2,priority range is [0, 4]
#define LAYER_INITCALL_DEF(func,layer, clayer)
LAYER_INITCALL(func, layer, clayer, 2)
可以看到最終SYS_RUN宏定義都是定義在.zinitcall中,因此SYS_RUN()宏設(shè)置的函數(shù)都會(huì)在MODULE_INIT(run)完成調(diào)用。
好了,最后看看應(yīng)用啟動(dòng)的調(diào)用流程:

官方文檔:
https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-ide-lite-steps-hi3861-helloworld.md
聲明:本文內(nèi)容及配圖由入駐作者撰寫(xiě)或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀(guā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)注
15文章
2428瀏覽量
129632 -
HarmonyOS
+關(guān)注
關(guān)注
80文章
2154瀏覽量
36088 -
HiSpark
+關(guān)注
關(guān)注
1文章
156瀏覽量
7765
發(fā)布評(píng)論請(qǐng)先 登錄
相關(guān)推薦
熱點(diǎn)推薦
技術(shù)資訊 I Wi-Fi 模塊設(shè)計(jì)
本文要點(diǎn)Wi-Fi模塊設(shè)計(jì)旨在打造一套緊湊且高效的硬件和軟件解決方案,使設(shè)備能夠通過(guò)Wi-Fi網(wǎng)絡(luò)實(shí)現(xiàn)通信。Wi-Fi模塊設(shè)計(jì)是一個(gè)復(fù)雜的過(guò)程,要求研發(fā)人員兼具硬件與軟件工程方面的專(zhuān)業(yè)知識(shí)
Wi-Fi:無(wú)線(xiàn)連接的全球通用語(yǔ)
Wi-Fi功能,跨品牌、跨設(shè)備互聯(lián)互通性強(qiáng),生態(tài)完整。3. 靈活部署,易于擴(kuò)展支持星型、Mesh等多種組網(wǎng)方式,可根據(jù)環(huán)境靈活布置接入點(diǎn),擴(kuò)大覆蓋范圍。4. 技術(shù)持續(xù)演進(jìn)從802.11a/b/g到
發(fā)表于 01-07 09:49
Nordic發(fā)布nRF7002 EBII 開(kāi)發(fā)板, 支持Wi-Fi 6, 解鎖nRF54L新玩法
了 Wi-Fi 6 功能,幫助開(kāi)發(fā)人員創(chuàng)建高性能、高能效的Wi-Fi 6 物聯(lián)網(wǎng)解決方案。
基于 Nordic 的 nRF7002 Wi-Fi 協(xié)同 IC,nRF7002 EBII幫助
發(fā)表于 12-10 11:58
Wi-Fi模塊選型指南 | 低功耗藍(lán)牙/Wi-Fi 6模塊推薦 | 物聯(lián)網(wǎng)設(shè)備集成攻略
:選擇用模塊的理由: 是為了方便電路集成設(shè)計(jì),特別是硬件兼容集成設(shè)計(jì),這樣只要產(chǎn)品前期做好了綜合設(shè)計(jì),后續(xù)做產(chǎn)品設(shè)計(jì)以及應(yīng)用端的靈活選擇,提供了很大的便利,省得重復(fù)設(shè)計(jì)硬件,縮短開(kāi)發(fā)周,加快將產(chǎn)品推向市場(chǎng)的時(shí)間; 二:Wi-Fi模塊選型注意點(diǎn)
淺談Wi-Fi 6E與Wi-Fi 7的關(guān)鍵器件——BAW濾波器新技術(shù)
作者: Qorvo 亞太區(qū)無(wú)線(xiàn)連接事業(yè)部高級(jí)行銷(xiāo)經(jīng)理林健富 ? 2020年1月,Wi-Fi聯(lián)盟正式宣布開(kāi)放6GHz頻段(5925MHz-7125MHz),并將其命名為Wi-Fi 6E。2020年4月
發(fā)表于 09-19 18:29
?2184次閱讀
雙頻匹配 SP4T Wi-Fi 交換機(jī) skyworksinc
電子發(fā)燒友網(wǎng)為你提供()雙頻匹配 SP4T Wi-Fi 交換機(jī)相關(guān)產(chǎn)品參數(shù)、數(shù)據(jù)手冊(cè),更有雙頻匹配 SP4T Wi-Fi 交換機(jī)的引腳圖、接線(xiàn)圖、封裝手冊(cè)、中文資料、英文資料,雙頻匹配
發(fā)表于 08-01 18:34
Texas Instruments CC335x SimpleLink?雙頻Wi-Fi? 6配套IC數(shù)據(jù)手冊(cè)
Texas Instruments CC335x SimpleLink?雙頻Wi-Fi ^?^ 配套IC提供Wi-Fi 6、BLE,并兼容Wi-Fi 4 (802.11 a/b/g/n
如何選擇合適的芯科科技Wi-Fi開(kāi)發(fā)板
您正在尋找適用于超低功耗物聯(lián)網(wǎng)應(yīng)用項(xiàng)目的Wi-Fi 開(kāi)發(fā)板嗎?本文將介紹Silicon Labs(芯科科技)推出的所有SiWx917 Wi-Fi 6和低功耗藍(lán)牙5.4解決方案的Wi-Fi
Wi-Fi 8:開(kāi)啟極高可靠性 (UHR) 連接的新紀(jì)元——1
,在2019年,Wi-Fi 6憑借著MU-MIMO、1024QAM、OFDMA等“革命性創(chuàng)新”技術(shù),大幅提升了Wi-Fi 本身的能效,讓Wi-Fi 6在短短的3-4年內(nèi)成為
發(fā)表于 06-13 11:09
芯科科技推出新款Wi-Fi 6開(kāi)發(fā)套件SiWG917Y
問(wèn)問(wèn)任何一位Wi-Fi開(kāi)發(fā)者,他們工作中最困難的部分是什么?你很可能會(huì)聽(tīng)到這樣的回答:“設(shè)計(jì)天線(xiàn)以及應(yīng)對(duì)全球射頻(RF)法規(guī)認(rèn)證?!?因應(yīng)這一挑戰(zhàn),Silicon Labs (芯科
[CYW4373] BT device_id正常,Wi-Fi device_id失敗的原因?
CYW4373 時(shí),無(wú)法識(shí)別 USB 集線(xiàn)器的 device_id(04b4:bd30)。但是,檢測(cè)到了 BT 設(shè)備 ID (04b4:640c),因此設(shè)備掃描可以正常運(yùn)行。但無(wú)法識(shí)別Wi-Fi設(shè)備
發(fā)表于 06-05 06:07
基于 Wi-Fi 的定位服務(wù)
以下捕獲使用 location_wifi_get 函數(shù)請(qǐng)求 Wi-Fi 定位服務(wù)。該事件的總功耗為 125.85mC,日志顯示精確度為 30.0m。
Got location:
method
發(fā)表于 04-17 15:16
nRF Cloud Wi-Fi 定位服務(wù)
、Predictive-GPS、Single-Cell、Multi-Cell 和 Wi-Fi 定位。通過(guò)利用 nRF Cloud 的優(yōu)化定位算法,基于 Nordic SoC 和 模組的產(chǎn)品可在定位用例
發(fā)表于 04-17 15:07
Wi-Fi 定位服務(wù)
Wi-Fi 是一種著名的無(wú)線(xiàn)網(wǎng)絡(luò)技術(shù),用于設(shè)備的局域網(wǎng)和互聯(lián)網(wǎng)接入。Wi-Fi 通過(guò) Wi-Fi 網(wǎng)絡(luò)為家庭、辦公室和學(xué)校等環(huán)境提供便捷的無(wú)線(xiàn)互聯(lián)網(wǎng)接入服務(wù)。
Wi-Fi 定位是一種
發(fā)表于 04-17 15:01
【HarmonyOS HiSpark Wi-Fi IoT 套件試用連載】第4章 OpenHarmony應(yīng)用開(kāi)發(fā)實(shí)例
評(píng)論