本文來源電子發燒友社區,作者:ouxiaolong, 帖子地址:https://bbs.elecfans.com/jishu_2286198_1_1.html
開發環境:
開發環境:
開發系統:Ubuntu 20.04
MCU:Hi3861
OpenHarmony版本:3.0.1-LTS
1.新建工程及源碼
1) 新建目錄
$ mkdir hello
#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文件,內容如下所示:
static_library("myapp"){
sources = [
"src/myapp.c"
include_dirs = [
"http://utils/native/lite/include"
}
static_library中指定業務模塊的編譯結果,為靜態庫文件libmyapp.a,開發者根據實際情況完成填寫。
sources中指定靜態庫.a所依賴的.c文件及其路徑,若路徑中包含"http://"則表示絕對路徑(此處為代碼根路徑),若不包含"http://"則表示相對路徑。
include_dirs中指定source所需要依賴的.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.關閉xts測試子系統。
系統每次開機后都要跑xts認證程序,這里先刪除該部分內容。
接下來就可以編譯了。
$ hb set
全編譯。
$ hb build -f
成功編譯后,固件在out/hispark_pegasus/wifiiot_hispark_pegasus目錄下。
Hi3861_wifiiot_app_allinone.bin就是需要燒寫的固件。
然后把固件下載到板子中。
接下來就可以根據該實例開發自己的應用了。
下面簡單分析下系統的啟動流程,系統的入口函數是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();
/* 此處設為TRUE后中斷中看門狗復位會顯示復位時PC值,但有復位不完全風險,量產版本請務必設為FALSE */
hi_syserr_watchdog_debug(HI_FALSE);
/* 默認記錄宕機信息到FLASH,根據應用場景,可不記錄,避免頻繁異常宕機情況損耗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驅動運行日志等,無需初始化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(); /* 釋放系統棧內存所使用任務 */
#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();
}
該函數首先打印SDK的版本信息,然后掛載文件系統,初始化WiFi信息等等一系列初始化,接這就到OHOS_Main(),該函數就是OpenHarmony系統的初始化。OHOS_Main()函數在文件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()函數是一個弱函數,其定義如下:
void __attribute__((weak))OHOS_SystemInit(void)
{
return;
}
因此該函數主要是系統為應用開發者提供的。OHOS_SystemInit()函數在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();
}
到這里基本就完成了所得初始化,其中我們編寫的應用就是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()宏設置的函數都會在MODULE_INIT(run)完成調用。
好了,最后看看應用啟動的調用流程:
官方文檔:
https://gitee.com/openharmony/docs/blob/master/zh-cn/device-dev/quick-start/quickstart-ide-lite-steps-hi3861-helloworld.md
聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。
舉報投訴
-
wi-fi
+關注
關注
14文章
2169瀏覽量
124837 -
HarmonyOS
+關注
關注
79文章
1982瀏覽量
30422 -
HiSpark
+關注
關注
1文章
156瀏覽量
6945
發布評論請先 登錄
相關推薦
Wi-Fi 8要來了!未來Wi-Fi技術演進方向揭秘
產品銷售中,雖然Wi-Fi 7產品的銷量份額快速從年初的個位數百分比增長至14%,但Wi-Fi 6產品的銷量份額依然穩定在60%左右。如果從存量設備來看,那么Wi-Fi 7路由器的占比將遠遠小于這個數。 ? 智能手機等終端設備已
華為海思正式進入Wi-Fi FEM賽道?
大家都知道了,2018年11 月離開銳迪科(RDA),前往福建晉江創立三伍微,專注于Wi-Fi射頻前端芯片,從路由器Wi-Fi FEM,到手機Wi-Fi FEM,再到IoT FEM全覆
發表于 12-11 17:42
摩爾斯微電子發布Wi-Fi HaLow評估套件,加速物聯網開發
近日,全球領先的Wi-Fi HaLow解決方案提供商摩爾斯微電子正式推出一款開創性的評估套件——MM6108-EKH05。這款完全整合的開發平臺,旨在推動各行業物聯網解決方案的快速發展
從Wi-Fi 4到Wi-Fi 7:網速飆升40倍的無線革命
1 Wi-Fi技術的快速發展 每一代新的Wi-Fi協議發布,都會帶來更高的無線速率。 ? 從Wi-Fi 4到Wi-Fi 7:無線網絡技術顯著
Wi-Fi 7與Wi-Fi 6E有什么區別
也許很多人還在考慮是否要將使用的Wi-Fi設備升級到Wi-Fi 6或Wi-Fi 6E,而這些標準的繼任者卻已經開始“登堂入室”了。Wi-Fi 7是新一代
網速快4倍!iPhone 16/Pro全系支持Wi-Fi 7
在安卓全面普及Wi-Fi 7一年之后,蘋果終于在iPhone 16系列配備了Wi-Fi 7技術,并且是全系支持。 相比之下,前代的iPhone 15不論是標準版還是Pro版都僅僅支持Wi-Fi 6E
未來的Wi-Fi路由器
廠家加入開始殺價,Wi-Fi FEM由于廠家眾多,價格一降再降,直接殺到成本價以下,DC-DC電源芯片也好不到哪里去,供應商的上市年度報和季度報也是不堪入眼。 除了跟著主芯片從Wi-Fi4升級到Wi-Fi5,再從
DA16600 超低功耗 Wi-Fi + 藍牙低功耗模塊開發套件數據手冊
電子發燒友網站提供《DA16600 超低功耗 Wi-Fi + 藍牙低功耗模塊開發套件數據手冊.rar》資料免費下載
發表于 05-31 17:51
?4次下載
DA16200 超低功耗 Wi-Fi 模塊開發套件 Pro數據手冊
電子發燒友網站提供《DA16200 超低功耗 Wi-Fi 模塊開發套件 Pro數據手冊.rar》資料免費下載
發表于 05-30 17:53
?1次下載
DA16200 超低功耗 Wi-Fi 模塊開發套件數據手冊
電子發燒友網站提供《DA16200 超低功耗 Wi-Fi 模塊開發套件數據手冊.rar》資料免費下載
發表于 05-30 17:13
?0次下載
驗證物聯網Wi-Fi HaLow用例的MM6108-EKH08開發套件來啦
驗證物聯網Wi-Fi HaLow用例的MM6108-EKH08開發套件來啦 MM6108-EKH08開發套件專為驗證物聯網Wi-Fi HaLow用例而設計。該
Wi-Fi的誕生與發展
短距離無線通信技術有Wi-Fi、ZigBee、藍牙以及Z-Wave,今天我們先揭開Wi-Fi的神秘面紗。Chrent短距離無線通信技術——Wi-Fi過去的20多年,Wi-Fi靠著僅有的
Wi-Fi HaLow和傳統Wi-Fi的區別
Wi-Fi HaLow和傳統Wi-Fi的區別? Wi-Fi是一種無線網絡技術,可以連接到互聯網或局域網,為用戶提供無線上網的便利。隨著科技的發展和互聯網的普及,Wi-Fi也在不斷演進和
評論