MCU引腳翻轉(zhuǎn)測試
在使用STM32讀取數(shù)字?jǐn)z像頭數(shù)據(jù)、寫入TFT中時(shí),涉及數(shù)據(jù)傳輸速率的問題,需要IO口快速翻轉(zhuǎn)。所以,我做了這個實(shí)驗(yàn),測試STM32的IO口最快翻轉(zhuǎn)速率
本文引用地址:http://m.butianyuan.cn/article/201611/320969.htm測試共分三部分:
(1)通過IO口的翻轉(zhuǎn)讀取外部數(shù)據(jù):
(2)純粹的IO翻轉(zhuǎn)速率:
(3)通過FSMC方式訪問外部數(shù)據(jù)
測試條件:72MHz主頻,F(xiàn)LASH_Latency_2
測試結(jié)果:
高等優(yōu)化:
讀數(shù)據(jù):
IO翻轉(zhuǎn):
FSMC:
低等優(yōu)化:
讀數(shù)據(jù):
IO翻轉(zhuǎn):
FSMC:
又配置了DMA進(jìn)行數(shù)據(jù)傳輸,其傳輸速率與FSMC的速率基本完全一致。
同時(shí),又使用飛思卡爾的MC9S12XS128處理器做了引腳翻轉(zhuǎn)實(shí)驗(yàn),在60MHz主頻下,讀數(shù)據(jù)速率為3.5MHz,IO翻轉(zhuǎn)速度為5.4MHz,而且還可以再提升。
結(jié)果中可以看出:
雖然STM32的主頻可達(dá)72MHz,但其引腳翻轉(zhuǎn)速率并不能做到很快。尤其在flash中運(yùn)行時(shí),受FLASH_Latency的限制,只有在主頻為36MHz時(shí),F(xiàn)LASH_Latency才能達(dá)到0而穩(wěn)定運(yùn)行。此時(shí)的執(zhí)行效率才能達(dá)到手冊上宣稱的1.25個百萬指令周期每秒每兆赫茲。然而,這卻并不是處理器的最高處理速度。但在主頻72MHz時(shí),又不能達(dá)到執(zhí)行效率的最高。
高等速度優(yōu)化可以顯著提高引腳翻轉(zhuǎn)速度(從反匯編來看,還可以繼續(xù)提高)但最快的數(shù)據(jù)傳輸仍然是FSMC,而且,F(xiàn)SMC也是最有效的數(shù)據(jù)傳輸模式,因?yàn)樗€包括相應(yīng)的地址線輸出,可以同時(shí)自動完成OE、CS、RS等信號的選擇,這是IO模擬數(shù)據(jù)傳輸所不能的。
與其他處理器相比,(例如MC9S12XS128)STM32的數(shù)據(jù)傳輸并沒有多大的優(yōu)勢(甚至有點(diǎn)慢)。當(dāng)然S12已經(jīng)超頻50%了。STM32的高速數(shù)據(jù)傳輸要靠高等優(yōu)化來完成,而這是比較危險(xiǎn)的。所以,只能靠對C語言的了解,和對代碼優(yōu)化的經(jīng)驗(yàn),才能更好的使用STM32。
對于了解它的人,STM32絕對是他手中利器
評論