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

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

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

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

深入剖析esp32c3的系統(tǒng)底層啟動

嵌入式IoT ? 來源:嵌入式IoT ? 作者:bigmagic ? 2021-07-06 10:38 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

1.本文概述對于esp32的玩法,基本上定位都是做上層應(yīng)用,樂鑫官方提供的ESP-IDF物聯(lián)網(wǎng)開發(fā)框架已經(jīng)十分的完善,做上層應(yīng)用按照這套框架進(jìn)行開發(fā),完全不必了解底層的實現(xiàn)細(xì)節(jié)。作為一個深入研究riscv底層的愛好者來說,跳過ESP-IDF框架,直接像使用單片機一樣去使用ESP32C3更加有意思。本文的目的就是理解ESP32C3的裸機開發(fā)流程,像玩單片機一樣去使用這個riscv的mcu。

2.esp32c3分析對于esp32c3玩法,從玩家來看可能更加類似ESP8266,相比8266,可以做如下表格對比:

8266C366

cpuXtensaRISCV

時鐘頻率160MHz160MHz

WIFIIEEE 802.11 b/g/n;2.4GHz;HT20;up to 75 MbpsIEEE 802.11 b/g/n;2.4GHz;HT20;up to 150 Mbps

藍(lán)牙N/ABluetooth LE v5.0

SRAM160 KB400KB

ROM0384KB

RTC ROM1KB8KB

簡單對比一下,不難發(fā)現(xiàn)esp32的還是與8266有點類似,而從目前的信息來看,esp32c3芯片的定價也是基本上和8266差不多的。

玩esp32c3,除了可以學(xué)習(xí)riscv架構(gòu),也能夠?qū)Φ讓酉到y(tǒng)的嵌入式編程有著更加深刻的理解。

3.esp32c3系統(tǒng)啟動流程如果按照樂鑫ESP-IDF正常的啟動流程來看,啟動過程有三個階段

bootloader第一階段

該階段主要是上電后,從ROM中運行,并且將bootloader第二階段程序從flash的0x0地址偏移處搬運到RAM中。

SOC上電后,直接執(zhí)行復(fù)位向量代碼,通過檢測GPIO_STRAP_REG的寄存器的狀態(tài)來確定啟動模式。

一般來說,有三種啟動模式:

reset from deep sleep

這種啟動模式就是系統(tǒng)從深度睡眠中被喚醒。

power up

上電啟動

看門狗復(fù)位

bootloader第二階段

該程序開始存放在flash的0x0地址處,其中的作用是從flash中加載分區(qū)表,并且決定啟動的程序位置,對于OTA來說非常有用處。而且也有一些flash程序的解壓或者壓縮的代碼,安全啟動,以及 over-the-air updates(OTA)等等。然后將程序的數(shù)據(jù)段放到DROM,指令段放到DRAM中。

主程序啟動

第二階段啟動后,加載主程序并且運行自己的程序的業(yè)務(wù)邏輯。主要的流程就是首先初始化C語言的執(zhí)行環(huán)境,設(shè)置棧指針地址,運行FreeRTOS操作系統(tǒng),然后運行main任務(wù)線程,執(zhí)行app_main。用戶自己在app_main中編寫自己的邏輯。

4.分析esp32c3上的裸機程序目的是讓esp32c3上電后直接啟動我們自己編寫的裸機程序,那么首先ROM中的程序是不能改變的。

https://www.espressif.com/sites/default/files/documentation/esp32-c3_technical_reference_manual_cn.pdf

要寫裸機代碼,首先需要看懂技術(shù)手冊,在芯片Boot控制的這一章節(jié),有描述ESP32C3的啟動一共有三個Strapping管腳GPIO2,GPIO8,GPIO9。

通過這個三個引腳的組合,可以控制boot模式。

啟動模式GPIO2GPIO8GPIO9

SPI Boot 模式1x1

Download Boot模式110

對于SPI模式,又分為兩種方式:

常規(guī)flash啟動

這種模式支持安全啟動,程序直接在RAM中。

直接啟動方式

不支持安全啟動,程序直接運行在flash中,默認(rèn)使用這種方式時,需要將程序的bin文件的前兩個字節(jié)(地址:0x42000000)為0xaebd041d。

而對于Download Boot模式,可以將UART0或者USB下載代碼到flash中或者SRAM中,這樣可以直接在SRAM中運行。

而本文的實驗過程采用的是直接啟動方式。

在編寫裸機代碼之前,首先來看一下memory map。

對于數(shù)據(jù)的布局如下

程序的鏈接腳本可設(shè)置如下:

MEMORY

{

irom (x): org = 0x42000000, len = 0x400000

drom (r): org = 0x3C000000, len = 0x400000

ram (rw): org = 0x3FC80000, len = 0x50000

rtc_ram (rx): org = 0x50000000, len = 0x2000

}

因為涉及到數(shù)據(jù)段和代碼段的地址分離問題,當(dāng)程序編譯成一整個固件的時候,在flash中的存在形式就是一個elf格式的文件,通過內(nèi)存的加載,將代碼段,數(shù)據(jù)段分別放到IRAM和DRAM中,同時將棧指針地址,數(shù)據(jù)段,bss段指向ram中。這樣就完成了裸機程序的布局。

接下來要開始構(gòu)建裸機工程了。

5.esp32c3裸機工程的構(gòu)建在自行構(gòu)建裸機工程的時候,也參考一些國外工程師的一些代碼,最后結(jié)合自己的理解,通過meson+ninja構(gòu)建出屬于自己的esp32c3裸機代碼實驗平臺。

為什么不用cmake或者makefile,原因是makefile的跨平臺效率不是很好,而且語法比較復(fù)雜,而cmake也比較慢,所以想到以后可能會到windows上開發(fā),換一種高效簡單的工程構(gòu)建方式比較,就采用meson+ninja build。關(guān)于構(gòu)建語法規(guī)則這里不做贅述。只介紹工程如何使用。

首先本文的環(huán)境只在Linux上環(huán)境下做編譯,并在windows平臺上下載程序。整個平臺后期會完全在windows上進(jìn)行開發(fā)。

1.從github上下載代碼

git clone git@github.com:bigmagic123/esp32c3_bare_metal.git

該工程項目主要用于研究esp32c3裸機實驗平臺。

2.下載riscv交叉編譯工具鏈

首先需要下載教程編譯工具鏈。

https://github.com/xpack-dev-tools/riscv-none-embed-gcc-xpack/releases/tag/v10.1.0-1.1/

下載對應(yīng)版本的riscv最新的交叉編譯工具鏈即可。

3.設(shè)置gcc路徑

直接修改esp32c3_bare_metal/example/cross.txt中的路徑即可。

4c66a4ba-ddc8-11eb-9e57-12bb97331649.png

替換自己的編譯路徑即可。

4.編譯程序

meson setup _build --cross-file cross.txt

cd _build

ninja

6.esp32c3裸機代碼下載與運行首先需要下載python3。可以在windows系統(tǒng)上進(jìn)行操作。

安裝好后,可以輸入pip install esptool。

下載完成后,esp32c3通過串口調(diào)試助手連接到電腦。

下載完成,可以通過esptool探測芯片ID。

通過下面的命令燒錄并啟動串口

esptool.py --port COM4 --baud 921600 write_flash 0x0000 demo.bin

python -m serial.tools.miniterm COM4 115200

如果退出,可以輸出下面的命令

ctrl + ]

這樣就可以將程序燒錄到flash中了。

7.分析裸機驅(qū)動程序的編寫編寫裸機程序,在對于esp32c3的編程模型中,可以使用ROM的里面的程序進(jìn)行設(shè)計。

其原理就是ROM中運行程序,每個函數(shù)都有特定的地址,只需要知道ROM函數(shù)對應(yīng)的地址,就可以通過訪問地址,從而訪問函數(shù)。

在[esp-idf](https://github.com/espressif/esp-idf)。

components/esp_rom/esp32c3/ld/esp32c3.rom.ld

其中定義了一些rom函數(shù)的地址,比如通過串口發(fā)送一個字節(jié)

uart_tx_one_char = 0x40000068;

其頭文件

components/esp_rom/include/esp32c3/rom/uart.h

函數(shù)的定義

/**

* @brief Output a char to printf channel, wait until fifo not full.

*

* @param None

*

* @return OK.

*/

STATUS uart_tx_one_char(uint8_t TxChar);

另外,也以通過編程手冊進(jìn)行操作寄存器的編程,這種難度稍微大一些。

https://www.espressif.com/sites/default/files/documentation/esp32-c3_technical_reference_manual_cn.pdf

比如在定時器組(TIMG)的章節(jié)

在寄存器的控制寄存器,首先TIMG_T0_EN設(shè)置為1的時候,使能計數(shù)器。

對于ESP32C3的編程,首先配置一下寄存器,使能定時器。

然后可以通過UPDATE寄存器更新寄存器的值。

當(dāng)使能定時器時,其值不斷在增加/減少。每次需要讀取數(shù)據(jù)的時候,需要將上述的31位寫0或者1,才能去讀T0LO寄存器。

其定時器的值為54位。這樣就可以正常通過寄存器操作esp32c3定時器了。

8.總結(jié)esp32c3裸機編程,可以清楚的理解esp32的底層啟動過程,完全當(dāng)作單片機來使用。

關(guān)于wifi和藍(lán)牙部分,使用rom中提供的函數(shù)地址,通過鏈接腳本和頭文件的方式進(jìn)行函數(shù)調(diào)用,這樣非常方便,而大部分驅(qū)動編程則需要自己查詢datasheet,操作外設(shè)對應(yīng)的寄存器進(jìn)行訪問。

編輯:jq

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

    關(guān)注

    6067

    文章

    44989

    瀏覽量

    650357
  • 寄存器
    +關(guān)注

    關(guān)注

    31

    文章

    5434

    瀏覽量

    124443
  • 藍(lán)牙
    +關(guān)注

    關(guān)注

    116

    文章

    6077

    瀏覽量

    173985
  • 物聯(lián)網(wǎng)
    +關(guān)注

    關(guān)注

    2930

    文章

    46230

    瀏覽量

    392308
  • ESP
    ESP
    +關(guān)注

    關(guān)注

    0

    文章

    192

    瀏覽量

    35028

原文標(biāo)題:esp32c3的系統(tǒng)底層啟動分析

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

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

掃碼添加小助手

加入工程師交流群

    評論

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

    基于ESP32C3的智能小車設(shè)計

    你有沒有想過,從零開始親手制作一輛堅固耐用的遙控越野車?今天,小編就帶你走進(jìn)一個融合機械、電子與物聯(lián)網(wǎng)的精彩DIY項目——一款由 Seeed Studio XIAO ESP32C3 強力驅(qū)動的 3D打印4x4 RC漫游車!
    的頭像 發(fā)表于 06-04 11:11 ?824次閱讀
    基于<b class='flag-5'>ESP32C3</b>的智能小車設(shè)計

    樂鑫ESP32-C5全面進(jìn)入量產(chǎn)

    樂鑫信息科技 (688018.SH) 宣布,ESP32-C5 現(xiàn)已全面進(jìn)入量產(chǎn)。
    的頭像 發(fā)表于 05-06 16:50 ?592次閱讀

    原來ESP32竟可《一“芯”兩用》既做人體檢測傳感器也做Wi-Fi數(shù)據(jù)傳輸

    如何使用ESP32來做人體檢測傳感器,對我來說還是挺新鮮的事兒,對你來說是否有也一樣呢?接下來我會重點來展開說說如何通過ESP32來實現(xiàn),這里我用的的是ESP32C3模組;0、前言之前看過樂鑫
    的頭像 發(fā)表于 12-18 18:12 ?3916次閱讀
    原來<b class='flag-5'>ESP32</b>竟可《一“芯”兩用》既做人體檢測傳感器也做Wi-Fi數(shù)據(jù)傳輸

    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ā)表于 12-07 15:30 ?11次下載

    【AI技術(shù)支持】ESP32-C3-Lyra播放音頻無法控制音量及異聲問題處理

    【AI技術(shù)支持】ESP32-C3-Lyra播放音頻無法控制音量及異聲問題處理
    的頭像 發(fā)表于 11-22 01:01 ?1609次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32-C3</b>-Lyra播放音頻無法控制音量及異聲問題處理

    基于ESP32-C3FN4為核心自主研發(fā)的Wi-Fi+BT模塊-RF-WM-ESP32B1

    WI-FI模組 - RF-WM-ESP32B1是基于ESP32-C3FN4為核心自主研發(fā)的Wi-Fi+BT模塊,支持IEEE 802.11b/g/n (2.4 GHz Wi-Fi)和低功耗藍(lán)牙5.0,可廣泛用于各種消費類電子、手機外設(shè)產(chǎn)品等。
    的頭像 發(fā)表于 11-07 09:45 ?658次閱讀
    基于<b class='flag-5'>ESP32-C3</b>FN4為核心自主研發(fā)的Wi-Fi+BT模塊-RF-WM-<b class='flag-5'>ESP32</b>B1

    【AI技術(shù)支持】ESP32C3 開發(fā)板在Linux環(huán)境下,進(jìn)行JTAG 調(diào)試演示

    啟明云端/01JTAG調(diào)試工具本教程主要演示ESP32C3開發(fā)板在linux環(huán)境下,通過vscode的ESP-IDF插件使用JTAG調(diào)試工具。ESP32C3不但內(nèi)置了USB-JTAG,還內(nèi)置了
    的頭像 發(fā)表于 10-17 08:01 ?3409次閱讀
    【AI技術(shù)支持】<b class='flag-5'>ESP32C3</b> 開發(fā)板在Linux環(huán)境下,進(jìn)行JTAG 調(diào)試演示

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

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

    esp32c3內(nèi)置USB-Serial-JTAG的使用

    1、介紹一句話:esp32-c3內(nèi)置了兩個開發(fā)利器usb-serial和usb-jtag,只需要一條數(shù)據(jù)線即可進(jìn)行程序燒錄、在線調(diào)試、日志輸出,大大方便了開發(fā)者;以下來自官方數(shù)據(jù)手冊介紹2
    的頭像 發(fā)表于 08-08 08:11 ?6138次閱讀
    <b class='flag-5'>esp32c3</b>內(nèi)置USB-Serial-JTAG的使用

    esp32c3安全啟動文檔里的簽名,使用與計算的簽名和使用idf.py簽名有什么不同?

    esp32c3安全啟動文檔里的簽名,使用與計算的簽名和使用idf.py簽名有什么不同?預(yù)簽名用的是--pub-key,普通的簽名用的是--keyfile?
    發(fā)表于 07-23 08:15

    導(dǎo)入ESP32C3的項目時,報這個提示Select a Kit for xxxx,請問應(yīng)該選擇什么?

    導(dǎo)入ESP32C3的項目時,報這個提示Select a Kit for xxxx,請問應(yīng)該選擇什么? 使用的ESP-IDF 5.2.2版本的插件
    發(fā)表于 07-22 06:06

    esp32c3使用flash_download_tool_3.9.5燒錄不能擦除之前保存在nvs里面的信息怎么辦?

    esp32c3使用flash_download_tool_3.9.5燒錄不能擦除之前保存在nvs里面的信息,如果不按flash_download_tool里面的擦除按鍵,有沒有辦法使用flash_download_tool燒錄程序的時候,同時也把nvs里面的信息也擦除一遍。
    發(fā)表于 07-19 07:47

    ESP32C3可以使用ESP-SkaiNet或者ESP-ADF開發(fā)離線語言識別嗎?

    ESP32C3可以使用ESP-SkaiNet或者ESP-ADF開發(fā)離線語言識別嗎?
    發(fā)表于 07-19 07:43

    使用ESP32C3的SoftAP例程,為啥手機和電腦都搜不到AP呢?

    版本是5.02,使用StationDemo可以連接這個AP,但是用手機筆記本搜不到,一般是原因啊 開發(fā)板用的是ESP32-C3-MINI-1ESP32-C3-DevkitM-1 v1.0,硬件上加了32.768K晶振,其它沒動 軟件純DEMO工程沒有動
    發(fā)表于 07-19 07:13

    esp32c3 OTA鏡像錯誤的原因?

    使用的是esp32c3參考的例程是 native_ota_example 錯誤日志如下 2024-07-03 09:41:17 E (24704) esp_ota_ops: OTA image
    發(fā)表于 07-19 06:50