最近有人問起程序在STM32G4片內(nèi)不同存儲空間運(yùn)行的速度差異。說實(shí)在的,這個很難說死或說出個絕對的數(shù)據(jù),畢竟結(jié)果除了跟執(zhí)行代碼的存放空間有關(guān)外,還跟代碼本身的內(nèi)容、程序邏輯、編譯工具及優(yōu)化等級等都息息相關(guān)。我這里設(shè)計(jì)了一個小測試程序做了下簡單比較,以供參考。
我們不妨先看看STM32G4系列內(nèi)部系統(tǒng)框架圖。下圖是STM32G4芯片的系統(tǒng)框架圖,我將測試程序放在圖中三個黃色高亮位置來運(yùn)行。
我將程序分別放在CCM、通用SRAM1、Flash區(qū)來運(yùn)行,基于不同的配置,即是否開啟指令預(yù)取、指令/數(shù)據(jù)Cache等,得到下面一個表格。代碼所在區(qū)域欄里的數(shù)據(jù)代表各種情形下的執(zhí)行時間。
從上面表格可以看出,相同配置下在CCM里執(zhí)行速率總是最高。
至于代碼放在SRAM和Flash里的執(zhí)行速率,不同配置下結(jié)果并不太一樣。比如在開啟prefetch和使能指令/數(shù)據(jù)Cache時,即第(1)種配置條件下,在SRAM里運(yùn)行的速率是最慢的,只有在上圖中的第(3)種情形下,代碼在SRAM里運(yùn)行速率相比在FLASH里運(yùn)行才凸顯出明顯優(yōu)勢。
對于STM32G4系列芯片,芯片復(fù)位后其Prefetch功能是關(guān)閉的,而指令/數(shù)據(jù)Cache是開啟的,即復(fù)位后默認(rèn)為上面的第(2)種情形。結(jié)合上圖,我們不難看出情形(1)與情形(2)的差別不大,至少不顯著。
上面數(shù)據(jù)雖只是基于特定代碼測試而得,但作為基本的方向性判斷還是可以的。
責(zé)任編輯:haq
-
芯片
+關(guān)注
關(guān)注
460文章
52520瀏覽量
441149 -
STM32
+關(guān)注
關(guān)注
2293文章
11032瀏覽量
365116 -
代碼
+關(guān)注
關(guān)注
30文章
4900瀏覽量
70768
原文標(biāo)題:STM32G4芯片內(nèi)不同空間運(yùn)行代碼的速率比較
文章出處:【微信號:stmcu832,微信公眾號:茶話MCU】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。
發(fā)布評論請先 登錄
請問cyw20719b2的nvram的存儲空間有多少字節(jié)?
在IMX93自定義構(gòu)建期間運(yùn)行bitbake imx image full時遇到報錯怎么解決?
STM32L431RCT6主芯片 搭配 SD NAND-動態(tài)心電圖設(shè)備存儲解決方案
使用Hal庫的SPI讀取磁邊傳感器導(dǎo)致STM32G4無法運(yùn)行怎么解決?
NAND Flash與SD NAND的存儲扇區(qū)架構(gòu)差異

在STM32L431上使用內(nèi)部RTC,時間運(yùn)行到23:59:59秒后,變?yōu)榱?4:00:00并不是00:00:00,為什么?
STM32和MCP2515通信,STM32這端還需要接CAN PHY嗎?
4G工業(yè)網(wǎng)關(guān)和5G工業(yè)網(wǎng)關(guān)的差異

電腦制作云存儲空間,如何使用電腦制作云存儲空間

基于STM32設(shè)計(jì)的大氣氣壓檢測裝置

評論