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

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

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

VIP也分高低?

痞子衡嵌入式 ? 來源:恩智浦MCU加油站 ? 作者:恩智浦MCU加油站 ? 2023-04-06 11:16 ? 次閱讀

前面小編對純軟件性能分析的理論與實踐的分享,希望給大家找到了豪華待遇的感覺。當(dāng)然了,自己當(dāng)土豪爽一下也就過去了,但是性能的問題還擺在那里等待解決,接下來怎么辦呢?

改善性能可以改進(jìn)代碼的寫法或算法,這就要結(jié)合實際問題,各顯神通了。但畢竟大牛人是來仰望的,咱們還需要更加立竿見影的招數(shù),那就是給CPU占用最大的一些函數(shù)提供VIP的待遇,把它們放在VIP區(qū)中——執(zhí)行性能更高的存儲器。

以前介紹性能分析時曾提到,VIP區(qū)其實也是分等級的。不同的單片機,在存儲器的設(shè)計,總線連接方式,訪問控制策略都各有特色,對性能的影響也不一而足。嵌入式IoT的開發(fā),處處彰顯出碎片化和粉末化的特色,這可讓人怎么整?

幸好,即使世界這么紛紛擾擾,還是有大類可循的。小編也試著結(jié)合NXPLPC54000系列和i.MX RT1050系列,給各類VIP區(qū)分了5類VIP特權(quán)等級。

VIP:C級(小V)

這主要是針對外置QSPI Flash的升級。

對于LPC540xx和LPC18x0/43x0系列,它們沒有內(nèi)置Flash。如果跑不動了,可以考慮升級到其對應(yīng)的有內(nèi)置Flash的pin2pin型號,比如LPC546xx,LPC18xx/43xx(尾號非0)。內(nèi)置Flash跑血常規(guī)(CoreMark)的性能一般在外置QSPI的1.5倍以上,對于查表較多的程序甚至在數(shù)倍以上。內(nèi)部Flash的帶寬往往在128位甚至256位,還帶有專用于加速循環(huán)結(jié)構(gòu)的特制小cache,執(zhí)行程序的性能還是很棒的。

為了呈現(xiàn)更高的性價比,i.MX RT系列全部沒有內(nèi)置Flash。不過,i.MX RT的FlexSPI支持高性能的DDR模式、雙Flash交火、以及8線Flash模式。就拿EVK上的hyper flash為例,可高達(dá)332MB/s,而一般的QSPI Flash通常不過60MB/s。此外,i.MX RT的SEMC對于從SDRAM執(zhí)行代碼的性能也比較給力,如果系統(tǒng)中存在SDRAM,也可以使一些數(shù)據(jù)表和代碼放在SDRAM中。

VIP:B級(中V)

各型Flash和SDRAM對于小循環(huán)體的性能盡管還可以,但是當(dāng)程序跳轉(zhuǎn)不規(guī)則,或者順序結(jié)構(gòu)較長時,以及數(shù)據(jù)訪問隨機性強時,性能的表現(xiàn)就變得很不均勻,讓人有“雖然我表達(dá)不了太多的愛,唯有好多眼淚流出來”的感覺。

這個時候,可以使用單片機片上的系統(tǒng)RAM。對于LPC54系列的Cortex-M4/M0+單片機,可以放在內(nèi)存地址為0x2000-0000開頭的RAM中,對于i.MX RT系列則是地址為0x2020-0000的OCRAM中。這些RAM的工作頻率和隨機訪問性能比Flash好得很多。但是因為在這個地址范圍使用的AHB (LPC)或AXI (i.MX RT)系統(tǒng)總線的啟動時序開銷大,總線往往又比較忙,還要和諸多帶DMA的總線主機搶帶寬,性能加速可能得不到保證,因此充其量也就算是中V級吧。

VIP:A級(大V)

和中V級相比,大V的待遇就更好了,有了專屬的緊密耦合RAM區(qū)。

以LPC5411x為例,它有32KB的”SRAMX”,這塊SRAMX和192KB的全部容量相比只占1/6,但絕對配得上大V的待遇。它直接連接到Cortex-M4的I-Code和D-Code總線上。這兩條總線也是“特供”于快速代碼執(zhí)行的綠色通道,其它總線主設(shè)備是沒資格用的。

再看i.MX RT,它的Cortex-M7內(nèi)核更是有過之而無不及,把I-Code和D-Code升級到64位的ITCM(指令緊密耦合存儲器)和DTCM(數(shù)據(jù)緊密耦合存儲器),并且片上的512KB內(nèi)存可以自由分割,全部配置成ITCM和DTCM也可以。那沒有了其它RAM,外設(shè)要訪問怎么辦呢?Cortex-M7留了個小后門——AHB-Slave給其它DMA主機訪問TCM,當(dāng)然是看M7臉色行事。

總之,大V待遇對于大多數(shù)程序代碼已經(jīng)相當(dāng)有面兒了,性能提升也是杠杠的!

VIP:S級(超V)

啥,還有超V級?難道還有比TCM更快的,莫非小編你瘋到想把R0-R14也給賣了?

倒也不是,超V級其實可以看作是上述VIP的組合,給最關(guān)鍵的模塊提供服務(wù),占用多塊RAM。比如一個壓縮jpeg的模塊,它既有代碼又有只讀數(shù)據(jù)。如果把代碼與只讀數(shù)據(jù)全放在一塊RAM,就不能發(fā)揮M4/M7雙總線的優(yōu)勢,比如沒法取指令的同時訪問數(shù)據(jù)。小編于是把代碼放ITCM,只讀數(shù)據(jù)放DTCM,相當(dāng)于它自己左手一個右手一個擁抱了整個芯片中性能最強的兩塊RAM,讓600MHz的M7火力全開,跑到QVGA分辨率下60幀每秒以上的圖片壓縮性能。

VIP:PS級(公共超V)

(僅適用于Cortex-M7)

在Cortex-M7內(nèi)核的i.MX RT系列中,支持指令高速緩存(I-Cache)和數(shù)據(jù)高速緩存(D-Cache),各有32KB。這兩個Cache的性能完全是TCM級別的。這是一項超V級水準(zhǔn)的平民福利,獻(xiàn)給全部沒有享受到大V和超V待遇的代碼和數(shù)據(jù),就稱作公共超V級吧。

有趣的是,它是全自動的——不管是什么代碼和數(shù)據(jù),上鏡率越高,就越有機會多享受超V級待遇。但若是如果什么時候起受冷落了,就最終會被掃出門。

打個不嚴(yán)謹(jǐn)?shù)谋确?,這就好比假設(shè)高鐵中以商務(wù)座的標(biāo)準(zhǔn)建餐車,即使沒買一等座和商務(wù)座,只要搶到了餐車座席吃飯,吃飯期間也享受商務(wù)座待遇。只不過,若是吃完飯想再歇會,又沒空位子了,那就祈禱別人不要來吃飯吧,否則就會被趕走。

因此,這項復(fù)用型超V待遇是按需分配的。值得注意的是,在替換cache內(nèi)容時會花時間,既對確定性產(chǎn)生影響,也降低平均性能。所以雖然比超V級弱一點,但它把福利普照給公眾,這是前面任何VIP特權(quán)也提供不了的。


審核編輯:劉清

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

    關(guān)注

    5086

    文章

    19142

    瀏覽量

    306035
  • FlaSh
    +關(guān)注

    關(guān)注

    10

    文章

    1638

    瀏覽量

    148174
  • 存儲器
    +關(guān)注

    關(guān)注

    38

    文章

    7509

    瀏覽量

    163975
  • QSPI
    +關(guān)注

    關(guān)注

    0

    文章

    41

    瀏覽量

    12219

原文標(biāo)題:VIP也分高低——存儲器對執(zhí)行性能的影響

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

收藏 人收藏

    評論

    相關(guān)推薦

    五極管簾柵極電壓高低的影響

    五極管,稱為五極真空管或五極電子管,是一種在電子學(xué)和無線電工程中使用的電子管。它由五個電極組成:陰極(cathode)、控制柵極(control grid)、簾柵極(screen grid)、陽極
    的頭像 發(fā)表于 09-24 14:34 ?579次閱讀

    高低溫試驗箱降溫原理是什么

    高低溫試驗箱是一種常用的環(huán)境模擬測試設(shè)備,主要用于模擬產(chǎn)品在極端高溫和低溫環(huán)境下的性能和耐久性測試。通過在一定時間內(nèi)快速升溫或降溫,試驗箱能夠模擬出各種環(huán)境條件,為電子、電工、汽車、航空航天、材料等
    的頭像 發(fā)表于 09-21 14:26 ?519次閱讀
    <b class='flag-5'>高低</b>溫試驗箱降溫原理是什么

    新思科技PCIe 7.0驗證IP(VIP)的特性

    在近期的博文《新思科技率先推出PCIe 7.0 IP解決方案,加速HPC和AI等萬億參數(shù)領(lǐng)域的芯片設(shè)計》中,新思科技宣布推出綜合全面的PCIe Express Gen 7(PCIe 7.0)驗證IP(VIP)解決方案,以支持高性能計算設(shè)計中人工智能(AI)應(yīng)用所需的高速度和低延遲。
    的頭像 發(fā)表于 07-24 10:11 ?743次閱讀
    新思科技PCIe 7.0驗證IP(<b class='flag-5'>VIP</b>)的特性

    ESP32可以直接寫入RX的高低電平,和直接讀取TX的高低電平嗎?

    如果串口的rx和tx的高低電平都是通過代碼得到的狀態(tài),想把這個高低電平的變化解析成串口數(shù)據(jù)流,在不占用IO的情況下能否解析出數(shù)據(jù)? 也就是在includesocuart_struct.h這個寄存器
    發(fā)表于 06-07 08:20

    維信諾智能像素化ViP技術(shù)榮獲Best New Display Component獎

    當(dāng)?shù)貢r間5月16日,SID DW 2024 People’s Choice Awards揭曉,維信諾智能像素化技術(shù)(ViP)經(jīng)過多日專業(yè)觀眾票選,榮獲Best New Display Component獎。
    的頭像 發(fā)表于 05-17 15:44 ?566次閱讀

    雷達(dá)液位計高低位是什么意思

    雷達(dá)液位計的高低位通常指的是液位計在測量過程中所設(shè)定或顯示的最高液位(高位)和最低液位(低位)。
    的頭像 發(fā)表于 05-14 16:11 ?1736次閱讀

    如何判斷電解池的電勢高低

    判斷電解池的電勢高低是一個涉及電化學(xué)原理和熱力學(xué)概念的復(fù)雜過程。電勢,稱為電極電位,是指在特定條件下,電極與其接觸的電解質(zhì)之間產(chǎn)生的電動勢。
    的頭像 發(fā)表于 04-28 15:25 ?3935次閱讀

    高低溫試驗箱:科技研發(fā)的得力助手

    系列高低溫試驗箱高低溫試驗箱的應(yīng)用范圍十廣泛。在電子、汽車、航空航天等領(lǐng)域,它都是產(chǎn)品研發(fā)和質(zhì)量保證的重要工具。通過模擬產(chǎn)品在高溫或低溫環(huán)境中的表現(xiàn),科研人員可以
    的頭像 發(fā)表于 04-28 10:19 ?600次閱讀
    <b class='flag-5'>高低</b>溫試驗箱:科技研發(fā)的得力助手

    動力電池系統(tǒng)高低壓線束解析

    動力電池系統(tǒng)高低壓線束分析(低壓線束)
    的頭像 發(fā)表于 04-16 11:17 ?787次閱讀
    動力電池系統(tǒng)<b class='flag-5'>高低</b>壓線束解析

    怎樣選擇一款合適的高低溫試驗箱?高低溫測試設(shè)備采購指南

    現(xiàn)如今各行各業(yè),產(chǎn)品質(zhì)量已成為決定企業(yè)品牌競爭力的核心因素,而想要知道產(chǎn)品的質(zhì)量、環(huán)境適應(yīng)性等的話,那么高低溫試驗箱是不可或缺的測試設(shè)備。   高低溫試驗箱通過模擬產(chǎn)品在極端溫度條件下的表現(xiàn),可以
    的頭像 發(fā)表于 04-09 15:24 ?1239次閱讀
    怎樣選擇一款合適的<b class='flag-5'>高低</b>溫試驗箱?<b class='flag-5'>高低</b>溫測試設(shè)備采購指南

    電源模塊高低溫老化測試方法與步驟

    為了檢測和確保電源模塊在不同溫度和惡劣環(huán)境下的工作性能,高低溫老化測試是不可或缺的測試步驟。高低溫老化測試是電子產(chǎn)品制造過程中的重要一環(huán),電源模塊高低溫老化測試就是為了檢測電源模塊在高溫和低溫下是否可以正常工作。
    的頭像 發(fā)表于 03-08 11:00 ?909次閱讀

    水位傳感器怎么調(diào)水位高低

    水位傳感器是一種用于測量液體水位高低的設(shè)備,廣泛應(yīng)用于各種工業(yè)、農(nóng)業(yè)和家用領(lǐng)域。調(diào)整水位的高低對于確保設(shè)備的正常運行和合理利用水資源非常重要。在本篇文章中,我們將詳細(xì)介紹水位傳感器的調(diào)節(jié)過程,并提
    的頭像 發(fā)表于 02-14 16:23 ?3542次閱讀

    高低溫循環(huán)試驗機一些簡單故障處理方法

    、耐熱、耐濕、耐干性試驗及品管工程的可靠性測試設(shè)備。做為高低溫循環(huán)試驗機試驗操作人員,您一定不希望設(shè)備出現(xiàn)故障而影響工作進(jìn)度,除了即時向廠商報修,自身需要有對整
    的頭像 發(fā)表于 01-12 10:08 ?709次閱讀
    <b class='flag-5'>高低</b>溫循環(huán)試驗機一些簡單故障處理方法

    如何讓高低溫沖擊試驗箱的壽命更長

    高低溫沖擊試驗箱在使用時間久后,簡單的維護(hù)與保養(yǎng)是不可少的。做到是否徹底,直接影響到高低溫沖擊試驗箱的使用壽命;那么我們在給高低溫沖擊試驗箱保養(yǎng)時,有哪些該注意的細(xì)節(jié)問題呢?首先我們要有保養(yǎng)的意識
    的頭像 發(fā)表于 01-09 10:52 ?484次閱讀
    如何讓<b class='flag-5'>高低</b>溫沖擊試驗箱的壽命更長

    高低壓共地干擾的分析

    很多人都知道,當(dāng)有高低電壓的時候,一般是不允許共地的,而是需要隔離開,比如我們常用的開關(guān)電源,它的輸入是220VAC,輸出5VDC,其中的變壓器既是降壓,起隔離作用。 一般的講,電壓越高,隔離
    發(fā)表于 01-09 06:11