一区二区三区三上|欧美在线视频五区|国产午夜无码在线观看视频|亚洲国产裸体网站|无码成年人影视|亚洲AV亚洲AV|成人开心激情五月|欧美性爱内射视频|超碰人人干人人上|一区二区无码三区亚洲人区久久精品

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

淺析Zephyr在ESP32上的啟動流程

ZephyrProject ? 來源:開源中國 ? 作者:HalfCoder ? 2021-06-07 17:04 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

理解Zephyr在一款soc上的啟動流程,有利于分析和調(diào)試開機(jī)過程卡死,驅(qū)動異常等的問題。因此在上手一款新的soc時(shí)掌握Zephyr在其上面的啟動流程非常必要。本文對Zephyr在ESP32上的啟動流程進(jìn)行分析,說明ESP32從上電開始如何執(zhí)行到Zephyr應(yīng)用的main函數(shù)。

Zephyr支持兩種ESP32引導(dǎo)方式:

配置CONFIG_BOOTLOADER_ESP_IDF=n:ROM Boot -》 Zephyr

配置CONFIG_BOOTLOADER_ESP_IDF=y. ROM Boot -》 ESP32 Bootloader -》 Zephyr

本文只分析CONFIG_BOOTLOADER_ESP_IDF=y的流程,在該流程理解另一種也類似,在CONFIG_BOOTLOADER_ESP_IDF=n的情況下相當(dāng)于是在ESP32的bootloader處放了一個(gè)zephyr應(yīng)用。

ESP32下Zephyr是被當(dāng)作ESP32的APP被引導(dǎo),因此有必要簡單了解ESP32的啟動流程

ESP32啟動階段

ESP32是雙核CPU,其中cpu0叫做PRO CPU, cpu1叫做APP CPU,啟動流程如下:

SOC上電, PRO CPU開始運(yùn)行,跳到ROM 0x40000400 處復(fù)位向量代碼處執(zhí)行

在PRO CPU上運(yùn)行ROM上一級引導(dǎo)代碼從Flash的0x1000讀出二級引導(dǎo)程序加載到內(nèi)部IRAM

跳轉(zhuǎn)到內(nèi)部IRAM上二級引導(dǎo)程序執(zhí)行

二級引導(dǎo)程序從 Flash 的 0x8000 偏移地址處讀取分區(qū)表, 從分區(qū)表中讀到APP的信息

二級引導(dǎo)程序?qū)ephyr數(shù)據(jù)和代碼段復(fù)制到DRAM和IRAM。對于Zephyr內(nèi)一些加載地址位于DROM和IROM區(qū)域的段,通過配置 Flash MMU 為其提供正確的映射。

二級引導(dǎo)程序會從Zephyr二進(jìn)制鏡像文件的頭部尋找的入口地址,然后跳轉(zhuǎn)到該地址處運(yùn)行。

以上流程中1~3是已經(jīng)被固化到ESP32的ROM中無法修改,4~6是由modules/hal/espressif/components/bootloader完成,可以做定制修改,但一般不修改。以上1~6都是在PRO CPU中執(zhí)行。

Zephyr的入口地址就是函數(shù)__start,第六步后就會跳轉(zhuǎn)到__start中執(zhí)行

Zephyr階段

Zephyr階段運(yùn)行到main主要步驟:__start-》z_cstart-》bg_thread_main-》main

__start

文件位置zephyr/soc/xtensa/esp32/soc.c, 主要完成下面內(nèi)容:

搬移中斷向量表

初始化bss段

關(guān)閉中斷

確保APP CPU沒有運(yùn)行(將在后面SMP初始化階段打開)

代碼摘要如下

void __attribute__((section(“.iram1”))) \_\_start(void)

{

//搬移中斷向量表

__asm__ __volatile__ (

“wsr %0, vecbase”

: “r”(&_init_start));

//BSS段初始化

(void)memset(&_bss_start, 0,

(&_bss_end - &_bss_start) * sizeof(_bss_start));

__asm__ __volatile__ (

“”

: “g”(&_bss_start)

: “memory”);

//關(guān)閉中斷

__asm__ __volatile__ (

“wsr %0, PS”

: “r”(PS_INTLEVEL(XCHAL_EXCM_LEVEL) | PS_UM | PS_WOE));

//關(guān)閉APP CPU

*app_cpu_config_reg &= ~DPORT_APPCPU_CLKGATE_EN;

//初始化cpu指針

__asm__ volatile(“wsr.MISC0 %0; rsync” : : “r”(&_kernel.cpus[0]));

//開始zephyr初始化

z_cstart();

CODE_UNREACHABLE;

}

是否發(fā)現(xiàn)跳到zephyr的__start是一個(gè)C函數(shù),但之前Zephyr并沒有做C堆棧(SP指針)初始化?這是因?yàn)樵贓SP32的bootloader階段已經(jīng)做了,Zephyr無需再做。

z_cstart

主要完成kernel初始化,PRE_KERNEL_1和PRE_KERNEL_2級別的驅(qū)動初始化,然后啟動main thread:bg_thread_main,剩下的其它初始化和應(yīng)用程序的main都在bg_thread_main中。

代碼摘要如下

__boot_func

FUNC_NORETURN void z_cstart(void)

{

//架構(gòu)相關(guān)的內(nèi)核初始化

arch_kernel_init();

// static devices初始化

z_device_state_init();

//初始化PRE_KERNEL_1和PRE_KERNEL_2驅(qū)動,大多都是硬件相關(guān)

z_sys_init_run_level(_SYS_INIT_LEVEL_PRE_KERNEL_1);

z_sys_init_run_level(_SYS_INIT_LEVEL_PRE_KERNEL_2);

//創(chuàng)建并切換到main thread運(yùn)行

switch_to_main_thread(prepare_multithreading());

CODE_UNREACHABLE; /* LCOV_EXCL_LINE */

}

__boot_func

static char *prepare_multithreading(void)

{

char *stack_ptr;

//初始化OS調(diào)度器

z_sched_init();

//創(chuàng)建main thread

stack_ptr = z_setup_new_thread(&z_main_thread, z_main_stack,

CONFIG_MAIN_STACK_SIZE, bg_thread_main,

NULL, NULL, NULL,

CONFIG_MAIN_THREAD_PRIORITY,

K_ESSENTIAL, “main”);

//將main thread加入到就緒態(tài)

z_mark_thread_as_started(&z_main_thread);

z_ready_thread(&z_main_thread);

//為每顆CPU 創(chuàng)建idle thread

for (int i = 0; i 《 CONFIG_MP_NUM_CPUS; i++) {

init_idle_thread(i);

_kernel.cpus[i].idle_thread = &z_idle_threads[i];

_kernel.cpus[i].id = i;

_kernel.cpus[i].irq_stack =

(Z_KERNEL_STACK_BUFFER(z_interrupt_stacks[i]) +

K_KERNEL_STACK_SIZEOF(z_interrupt_stacks[i]));

}

initialize_timeouts();

return stack_ptr;

}

main thread被加入到就緒態(tài),因此下一次調(diào)度時(shí)bg_thread_main就會被執(zhí)行

bg_thread_main

在bg_thread_main中完成剩余的驅(qū)動初始化,并且啟動esp32的第二顆CPU: APP CPU, 然后運(yùn)行到應(yīng)用的main函數(shù)。

代碼摘要如下

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

__boot_func

static void bg_thread_main(void *unused1, void *unused2, void *unused3)

{

z_sys_post_kernel = true;

//初始化POST_KERNEL級別驅(qū)動

z_sys_init_run_level(_SYS_INIT_LEVEL_POST_KERNEL);

boot_banner();

//初始化APPLICATION級別驅(qū)動

z_sys_init_run_level(_SYS_INIT_LEVEL_APPLICATION);

//初始化靜態(tài)聲明的thread

z_init_static_threads();

#ifdef CONFIG_SMP

//初始化SMP, 到這里才會啟動ESP32的另一顆CPU

z_smp_init();

//初始SMP級別的驅(qū)動,例如跨CPU通信的mailbox, ipm驅(qū)動

z_sys_init_run_level(_SYS_INIT_LEVEL_SMP);

#endif

extern void main(void);

//執(zhí)行應(yīng)用程序的main

main();

/* Mark nonessenrial since main() has no more work to do */

z_main_thread.base.user_options &= ~K_ESSENTIAL;

}

關(guān)于main

這里調(diào)用的main函數(shù),是在Zephyr應(yīng)用程序中實(shí)現(xiàn),最后通過鏈接器鏈接在一起。Zephyr應(yīng)用程序的main是在main thread中執(zhí)行,由于main thread的默認(rèn)優(yōu)先級比較高0, 因此要注意不要在main中去做while(1),避免導(dǎo)致其它搶占式線程拿不到CPU。

關(guān)于SMP

從前面的分析可以看到z_smp_init前,Zephyr上包括main thread的所有代碼都是在PRO CPU上執(zhí)行,在z_smp_init后Zephyr的代碼才有機(jī)會運(yùn)行到APP CPU上, SMP是一個(gè)很大的議題,不是在本文分析范圍內(nèi)。這里簡單列出esp32 SMP初始化的主要流程供參考:

z_smp_init(smp.c)-》arch_start_cpu(esp32-mp.c)-》appcpu_start-》esp32_rom_ets_set_appcpu_boot_addr-》appcpu_entry1-》z_appcpu_stack_switch-》appcpu_entry2-》smp_init_top(smp.c)

參考

https://docs.espressif.com/projects/esp-idf/zh_CN/latest/esp32/api-guides/startup.html

編輯:jq

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報(bào)投訴
  • cpu
    cpu
    +關(guān)注

    關(guān)注

    68

    文章

    11080

    瀏覽量

    217090
  • soc
    soc
    +關(guān)注

    關(guān)注

    38

    文章

    4392

    瀏覽量

    222769
  • SMP
    SMP
    +關(guān)注

    關(guān)注

    0

    文章

    78

    瀏覽量

    20282
  • ESP32
    +關(guān)注

    關(guān)注

    21

    文章

    1017

    瀏覽量

    19265

原文標(biāo)題:Zephyr ESP32啟動流程

文章出處:【微信號:ZephyrProject,微信公眾號:ZephyrProject】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

    ESP32-P4 C5開發(fā)板燒錄小智全流程!速看!

    沒錯,你沒有看錯!我們帶著WT99P4C5-S1開發(fā)板燒錄小智全流程走來了!開發(fā)板搭載樂鑫科技ESP32-P4和ESP32-C5芯片,代碼完全開源,支持靈活二次開發(fā)。什么?文字教程不好理解?別怕
    的頭像 發(fā)表于 07-04 18:03 ?332次閱讀
    <b class='flag-5'>ESP32</b>-P4 C5開發(fā)板燒錄小智全<b class='flag-5'>流程</b>!速看!

    ESP32-S3開發(fā)板燒錄小智AI系統(tǒng)全流程指南

    AI語音交互領(lǐng)域不斷發(fā)展的今天,開發(fā)者們對于功能強(qiáng)大、開源靈活的開發(fā)板需求日益增長。今天,我們就來詳細(xì)了解一下ESP32AgentDevKit燒錄小智的全流程,這款搭載樂鑫科技ESP32
    的頭像 發(fā)表于 06-16 18:01 ?1444次閱讀
    <b class='flag-5'>ESP32</b>-S3開發(fā)板燒錄小智AI系統(tǒng)全<b class='flag-5'>流程</b>指南

    ESP32運(yùn)行網(wǎng)頁服務(wù)器 (Web-Server)-入門篇

    什么是ESP32WebServer?ESP32WebServer是ESP32微控制器運(yùn)行的一個(gè)嵌入式網(wǎng)頁服務(wù)器。它能夠處理HTTP請求并
    的頭像 發(fā)表于 03-09 14:24 ?4305次閱讀
    <b class='flag-5'>ESP32</b>運(yùn)行網(wǎng)頁服務(wù)器 (Web-Server)-入門篇

    esp32如何接入豆包

    要在 ESP32 上接入豆包工具,本質(zhì)是讓 ESP32 設(shè)備與豆包的 API 進(jìn)行通信,以獲取相關(guān)服務(wù)
    的頭像 發(fā)表于 02-05 13:40 ?1974次閱讀
    <b class='flag-5'>esp32</b>如何接入豆包

    【AI技術(shù)支持】ESP32模組接大電容無法正常啟動處理

    啟明云端/01問題描述客戶工控產(chǎn)品使用樂鑫ESP32-WROOM-32E-N4模組,ESP-IDF版本為idf4.46時(shí),項(xiàng)目應(yīng)用時(shí)掉
    的頭像 發(fā)表于 01-20 18:03 ?859次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32</b>模組接大電容無法正常<b class='flag-5'>啟動</b>處理

    ESP32-S3-WROOM-1/ESP32-S3-WROOM-1U技術(shù)規(guī)格書

    電子發(fā)燒友網(wǎng)站提供《ESP32-S3-WROOM-1/ESP32-S3-WROOM-1U技術(shù)規(guī)格書.pdf》資料免費(fèi)下載
    發(fā)表于 12-07 15:30 ?11次下載

    【AI技術(shù)支持】ESP32-S2-SOLO-2U模組重復(fù)欠壓復(fù)位問題處理

    問題描述電池供電的影音產(chǎn)品,使用ESP32-S2-SOLO-2U模組,ESP-IDF版本為idf5.0.1時(shí),模組電后一直報(bào)欠壓復(fù)位錯
    的頭像 發(fā)表于 11-28 01:00 ?1317次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32</b>-S2-SOLO-2U模組重復(fù)欠壓復(fù)位問題處理

    【AI技術(shù)支持】ESP32-WROVER-IE-N16R8模組啟動失敗問題處理

    你是否曾遇到過?無線視頻監(jiān)控設(shè)備,使用ESP32-WROVER-IE-N16R8模組,ESP-IDF版本為idf5.0.1時(shí),模組需與PHY芯片通信,主板
    的頭像 發(fā)表于 11-20 01:00 ?1441次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32</b>-WROVER-IE-N16R8模組<b class='flag-5'>上</b>電<b class='flag-5'>啟動</b>失敗問題處理

    【AI技術(shù)支持】ESP32模組PSRAM的CS引腳上拉導(dǎo)致功耗上升處理

    啟明云端/01你是否曾遇到過?游戲機(jī)產(chǎn)品,使用ESP32-WROOM-32E/ESP32-WROOM-32UE模組,ESP-IDF版本為
    的頭像 發(fā)表于 10-31 08:01 ?2206次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32</b>模組PSRAM的CS引腳上拉導(dǎo)致功耗上升處理

    esp32使用chatGPT做一些有意思的事情

    ChatGPT獲得響應(yīng),我們需要進(jìn)行以下步驟:1、OpenAI網(wǎng)站上注冊,并在ESP32安裝必要的庫。 2、OpenAI API創(chuàng)
    的頭像 發(fā)表于 10-18 10:04 ?1068次閱讀

    ESP32 微控制器系列指南

    2024-05-29 Don Wilcher [微控制器] ESP32 微控制器已成為物聯(lián)網(wǎng) (IoT) 和嵌入式控制器領(lǐng)域的核心部分。 ESP32 生態(tài)系統(tǒng)的制造商 Espressif
    的頭像 發(fā)表于 10-02 18:21 ?5045次閱讀
    <b class='flag-5'>ESP32</b> 微控制器系列指南

    rt-thread bsp里esp32c3里編譯出的bin文件燒到esp32的開發(fā)板運(yùn)行提示chipid不對,為什么?

    rt-thread bsp里esp32c3里編譯出的bin文件燒到esp32的開發(fā)板 運(yùn)行提示chipid不對,是否有方法修改能支持esp32
    發(fā)表于 09-27 10:01

    esp32esp8266代碼共用嗎

    本文將介紹ESP32ESP8266兩款流行的微控制器代碼共用性方面的可能性與差異性。 一、引言 隨著物聯(lián)網(wǎng)技術(shù)的飛速發(fā)展,越來越多的智能設(shè)備開始進(jìn)入我們的生活。其中,ESP32
    的頭像 發(fā)表于 08-19 18:23 ?2344次閱讀

    esp8266和esp32區(qū)別是什么

    的內(nèi)存選項(xiàng),包括最小512KB的RAM和最大16MB的閃存。 Wi-Fi和藍(lán)牙 : ESP8266 :支持2.4GHz Wi-Fi。 ESP32 :支持2.4GHz Wi-Fi和藍(lán)牙5.0,這使得ESP32
    的頭像 發(fā)表于 08-19 18:16 ?7346次閱讀

    esp32用什么軟件編程

    ESP32是一款由樂鑫(Espressif)推出的低功耗、高性能的Wi-Fi和藍(lán)牙雙模微控制器,廣泛應(yīng)用于物聯(lián)網(wǎng)、智能家居、智能穿戴等領(lǐng)域。要對ESP32進(jìn)行編程,需要選擇合適的編程軟件和開發(fā)環(huán)境
    的頭像 發(fā)表于 08-19 17:24 ?6986次閱讀