下面簡(jiǎn)單介紹一下 R128 方案的資源劃分與啟動(dòng)流程。
資源劃分
CPU 資源劃分
這只是默認(rèn)配置方案,CPU 資源劃分可以按照需求任意修改
CPU | 功能說明 |
---|---|
M33 | 控制核。運(yùn)行 WI-FI/BT 固件、協(xié)議棧、驅(qū)動(dòng)、休眠喚醒、安全啟動(dòng)、安全控制 |
C906 | 應(yīng)用核。運(yùn)行大部分驅(qū)動(dòng)與主要應(yīng)用,控制臺(tái) |
HIFI5 | 算法核。運(yùn)行音頻相關(guān)驅(qū)動(dòng)與算法 |
內(nèi)存配置
R128 方案目前三個(gè)核 OS 運(yùn)行的地址范圍如下表。
這只是默認(rèn)配置方案,CPU 資源劃分可以按照需求任意修改。
CPU | 內(nèi)存使用地址 |
---|---|
M33 | lspsram ,運(yùn)行地址范圍 0x8000000 - 0x8300000 |
C906 | lspsram ,運(yùn)行地址范圍 0x8300000 - 0x8800000 |
HIFI5 | hspsram ,運(yùn)行地址范圍 0xC000660 - 0xC0A0660 |
啟動(dòng)流程
R128 方案非安全啟動(dòng)流程如下,其中 M33 為啟動(dòng)核:
這只是默認(rèn)配置方案,啟動(dòng)流程可以按照需求任意修改。
- BROM
- 加載 M33 BOOT0 至 SRAM
- 跳轉(zhuǎn) M33 BOOT0 運(yùn)行
- M33 BOOT0
- 初始化 LSPSRAM 與 HSPSRAM
- 加載 M33 RTOS 至 LSPSRAM
- 加載 C906 RTOS 至 LSPSRAM
- 加載 HIFI5 RTOS 至 HSPSRAM
- 跳轉(zhuǎn)運(yùn)行 M33 RTOS
- M33 RTOS
- 啟動(dòng)運(yùn)行 C906 RTOS
- 啟動(dòng)運(yùn)行 HIFI5 RTOS
- C906 RTOS
- 啟動(dòng)運(yùn)行用戶程序
sequenceDiagram
BROM-- >>SRAM: load M33 Core BOOT0 to SRAM
BROM-- >>BOOT0: Boot BOOT0 on M33
BOOT0-- >>LSPSRAM: init LSPSRAM
BOOT0-- >>HSPSRAM: init HSPSRAM
BOOT0-- >>LSPSRAM: load M33 RTOS to LSPSRAM
BOOT0-- >>LSPSRAM: load C906 RTOS to LSPSRAM
BOOT0-- >>HSPSRAM: load HIFI5 RTOS to HSPSRAM
BOOT0-- >>M33: BOOT0 Boot M33 RTOS
M33-- >>C906: Boot C906 RTOS
C906-- >>LSPSRAM: C906 RTOS Running on LSPSRAM
M33-- >>HIFI5: Boot HIFI5 RTOS
HIFI5-- >>HSPSRAM: HIFI5 RTOS Running on HSPSRAM
C906-- >>HSPSRAM: APP Running on HSPSRAM
修改運(yùn)行核心
系統(tǒng)有三個(gè)不同的核心,分別是 M33,C906,HIFI5,其中M33是啟動(dòng)核心不可以關(guān)閉,另外兩個(gè)核心都可以關(guān)閉。當(dāng)不需要使用 C906 核心或者 HIFI5 DSP 核心的時(shí)候,可以將這兩個(gè)核心關(guān)閉。方法如下:
關(guān)閉 HIFI5 核心
首先,選擇好 M33 的方案,因?yàn)?HIFI5 是由 M33 來啟動(dòng)的。
source envsetup.sh
lunch_rtos r128s2_m33
直接取消勾選即可:
關(guān)閉 C906 核心
首先,選擇好 M33 的方案,因?yàn)?C906 是由 M33 來啟動(dòng)的。
source envsetup.sh
lunch_rtos r128s2_m33
直接取消勾選即可:
修改核心運(yùn)行內(nèi)存空間
修改到 HSPSRAM 運(yùn)行
R128 的 M33 和 C906 兩個(gè)核運(yùn)行的系統(tǒng)都是默認(rèn)運(yùn)行在 LSPSRAM,這里示例如何修改到 HSPSRAM
- 關(guān)閉啟動(dòng) HIFI5 核心
首先,選擇好 M33 的方案,因?yàn)?HIFI5 是由 M33 來啟動(dòng)的。
source envsetup.sh
lunch_rtos r128s2_m33
由于默認(rèn) HIFI5 是運(yùn)行在 HSPSRAM 的,這里需要釋放 HSPSRAM。運(yùn)行 mrtos_menuconfig
啟動(dòng)配置。
直接取消勾選即可。
- 將 M33 和 C906 設(shè)置成在 HSPSRAM 運(yùn)行
首先選擇 M33 的方案:
source envsetup.sh
lunch_rtos r128s2_m33
接著運(yùn)行 mrtos_menuconfig
修改啟動(dòng)地址,所需要修改的配置如下圖所示:
lspsram 地址空間為 0x8000000-0x87fffff,hspsram 地址空間為 0xc000000-0xc7fffff。
這里將所需要的修改的核的地址,將8改成c即可。如修改 M33 的起始地址,將 0x08004000
,修改成0x0c004000
即可,如下圖。
然后保存配置,重新編譯 M33 方案。接下來修改 C906 的地址,選擇 C906 的方案
source envsetup.sh
lunch_rtos r128s2_c906
接著運(yùn)行 mrtos_menuconfig
修改啟動(dòng)地址,所需要修改的配置如下圖所示:
然后保存配置,重新編譯 C906 方案。
- 修改配置文件
首先,確認(rèn)自己方案使用的 image_header
文件,運(yùn)行一次打包的命令 pack
,從打包的 log
中能看出方案所選的文件,如下圖:
如果需要修改 M33 的地址,則只修改 M33 的即可,C906同理。如果取消啟動(dòng) DSP,則直接注銷掉 DSP的配置代碼。
最后,修改 M33 和 C906 在 HSPSRAM 運(yùn)行,并且取消運(yùn)行 HIFI5 的 image_header
文件修改可如下所示:
diff --git a/r128s2/pro/configs/image_header_xip.cfg b/r128s2/pro/configs/image_header_xip.cfg
index 5c83ac1..fc87d06 100755
--- a/r128s2/pro/configs/image_header_xip.cfg
+++ b/r128s2/pro/configs/image_header_xip.cfg
@@ -30,9 +30,9 @@
{"id": "0xa5e05a00", "bin": "boot0_spinor.fex", "attr": "0x01", "sram_offs": "0x40b0000", "ep": "0x40b0080"},
{"id": "0xa5e05a00", "bin": "boot0_sdcard.fex", "attr": "0x01", "sram_offs": "0x40b0000", "ep": "0x40b0080"},
{"id": "0xa5e15a01", "bin": "freertos-gz.fex", "attr": "0x01"},
- {"id": "0xa5e05a01", "bin": "rtos_arm.fex", "attr": "0x01", "sram_offs": "0x8004000", "ep": "0x8004000"},
- {"id": "0xa5e05a01", "bin": "rtos_riscv.fex", "attr": "0x01", "sram_offs": "0x8200000", "ep": "0x8200000"},
- {"id": "0xa5e05a01", "bin": "rtos_dsp.fex", "attr": "0x01", "sram_offs": "0xc000000", "ep": "0xc000660"},
+ {"id": "0xa5e05a01", "bin": "rtos_arm.fex", "attr": "0x01", "sram_offs": "0xc004000", "ep": "0xc004000"},
+ {"id": "0xa5e05a01", "bin": "rtos_riscv.fex", "attr": "0x01", "sram_offs": "0xc200000", "ep": "0xc200000"},
+ // {"id": "0xa5e05a01", "bin": "rtos_dsp.fex", "attr": "0x01", "sram_offs": "0xc000000", "ep": "0xc000660"},
{"id": "0xa5e05a01", "bin": "etf.fex", "attr": "0x01", "sram_offs": "0x4000000", "ep": "0x4000000"},
{"id": "0xa5e05a01", "bin": "rtos_xip_rv.fex", "attr": "0x02"},
{}
查看代碼內(nèi)存分布
可以在 SDK 中運(yùn)行 kamp 命令查看代碼的內(nèi)存分布
可以在最后查看內(nèi)存的總使用情況
配置XIP
R128-S2 內(nèi)置 NOR FLASH,可以將運(yùn)行效率要求不高的代碼保存在 XIP 段中,減少內(nèi)存的占用。
配置 XIP 需要把對(duì)應(yīng)的函數(shù)和庫文件加入 xip.lds.S 中,具體語法請(qǐng)參照 ld 語法。
配置多個(gè)堆內(nèi)存
有些時(shí)候當(dāng)不需要使用 DSP 核心或者 DSP 核心內(nèi)存使用量較少時(shí),可以配置多個(gè)堆內(nèi)存,將一部分內(nèi)存放置于不同的 RAM 上使用。這里以 R128-S2 關(guān)閉 DSP 核心并將 HSPSRAM 分配給 C906 核心使用為例:
配置前內(nèi)存分布情況
配置前進(jìn)入 C906 核心運(yùn)行 free 命令查看當(dāng)前內(nèi)存使用分布情況。
關(guān)閉 DSP 核心
首先,選擇好 M33 的方案,因?yàn)?DSP 是由 M33 來啟動(dòng)的。
source envsetup.sh
lunch_rtos r128s2_m33
由于默認(rèn) DSP 是運(yùn)行在 HSPSRAM 的,這里需要釋放 HSPSRAM。運(yùn)行 mrtos_menuconfig 啟動(dòng)配置。
直接取消勾選即可。
修改后請(qǐng)重新編譯 M33 核心的固件。
將 HPSRAM 全部分配給 C906 使用
選擇好 C906 的方案,運(yùn)行配置界面
source envsetup.sh
lunch_rtos r128s2_c906
image-20231017135824514
找到 Kernel Options
找到 Heap Memory Manager (Use heap-4 to allocate memory) --->
選中 Use heap-multiple to allocate memory
配置 Default Heap Ram 為 heap in lpsram 配置默認(rèn)內(nèi)存堆為 lpsram
勾選 lpsram heap 和 lpsram heap dynamic address,意思是 lpsram 的內(nèi)存是動(dòng)態(tài)分布的
配置 lpsram heap size 的大小是0x600000,因?yàn)榍懊?2M 給 M33 使用,所以剩下 6M
配置 hpsram heap 使能 HPSRAM,并配置 hpsram heap start address 為 0xc000000,hpsram heap size 為 0x7FFFFF 表示將 HPSRAM 全部分配給 C906 核心使用。
將 HPSRAM 部分分配給 C906 使用
如果 HPSRAM 需要運(yùn)行 DSP,可以分配部分給 C906 使用,配置 hpsram heap start address為 0xc400000,0xc000000 是 HPSRAM 的開始地址,前面 4M 已經(jīng)分配給 DSP 使用;并配置 hpsram heap size 為 0x400000 意思是可以用的 HPSRAM 大小是 4M。
配置后的內(nèi)存分布情況
編譯打包燒錄后,可以使用 free 命令查看配置后的內(nèi)存分布情況??梢钥吹?HPSRAM 的8M內(nèi)存全部分配給 C906 使用了,C906 一共可以用 4M LPSRAM + 8M HPSRAM = 12M RAM
審核編輯 黃宇
-
mcu
+關(guān)注
關(guān)注
146文章
17855瀏覽量
360815 -
R128
+關(guān)注
關(guān)注
0文章
41瀏覽量
241
發(fā)布評(píng)論請(qǐng)先 登錄
云游戲的基礎(chǔ)資源類型

FD60-36S24B3R2 FD60-36S24B3R2

PFD50-36S24B3R2 PFD50-36S24B3R2

FD50-36S24B3(R)2 FD50-36S24B3(R)2

如何從R52_0使用SD Boot啟動(dòng)S32z ?
MHMF012L1S2M-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

MHMF092A1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

ADC128S102EVM評(píng)估模塊

MHMF082L1S2M-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

MHMF082A1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -I/F啟動(dòng)- 松下

MHMF041A1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

MHMF022L1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

ADC128S052、ADC128S052-Q1模數(shù)轉(zhuǎn)換器數(shù)據(jù)表

MHMF021A1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -Modbus啟動(dòng)- 松下

MHMF011L1S2-MINAS A6 系列 Block動(dòng)作應(yīng)用說明資料 -I/F啟動(dòng)- 松下

評(píng)論