ARM公司白皮書 基于ARM Cortex 處理器的片上系統(SoC)解決方案適用于多種嵌入式設計細分市場,如物聯網、電機控制、醫療、汽車、家電自動化等。我們的處理器品種豐富且基于同一個標準架構,針對不同的產品市場提供廣泛而豐富的性能與成本組合。Cortex系列處理器主要基于3大產品類型量身開發,A系列:運行復雜系統的精細高端應用;R系列:高性能硬實時系統;M系列:低功耗、確定性、成本敏感的微控制器,專門優化以滿足其需求。 最先采用ARMv8-M架構的2款處理器為Cortex-M23和Cortex-M33。本文主要介紹Cortex-M33, Cortex-M33是首款采用TrustZone 安全技術和數字信號處理技術的ARMv8-M全功能實現處理器。該處理器可以支持大量靈活的配置選項,并在廣泛應用中進行部署,此外還提供專用的協同處理器界面以支持經常需要加速和大量運算的運作。Cortex-M33是一款在性能、功耗、安全與生產力之間達到最佳平衡的處理器。 為了顯著降低系統功耗,Cortex-M33處理器采用有序三階管線技術。大部分指令在頭兩個階段就能完成,而復雜的指令則需要3個階段。此外,某些16位指令將采用雙發射機制,以增強性能。處理器內核有兩個AMBA 5 AHB5界面:C-AHB和S-AHB,完全對稱,指令和數據提取性能不分伯仲。 Cortex-M33的配置高度靈活,可以滿足廣泛的系統要求 在MPU、DSP、FPU、TrustZone、ETM、MTB、ITM、BPU、DWT和協同處理器界面功能中選擇最佳組合方案,設計師即可迅速打造強大系統。在最低限度的控制系統中,NVIC可以被設定成只容納一個外部中斷;而在周邊設備豐富的系統中,NVIC能夠設定成可容納至多480個外部中斷,包含至多256個優先級。而對于那些依賴大量主動流程和線程以保持可靠運行的系統,設計師還可以增加MPU,用特權和非特權接入控制來強行隔離處理進程。如需更高級別的代碼、數據和資源保護, TrustZone則是設計師的不二之選。 應用復雜度越來越高,片上調試和追蹤技術的價值也日益凸顯,對保障產品按期交付至關重要。Cortex-M33處理器的內置調試功能可以加速軟件驗證。設計師可以用JTAG端口或雙插針串行調試端口來驗證系統,還可以選擇ETM或MTB進行出色的指令追蹤,而BPU和DWT則可以允許在調試中使用斷點和硬件觀測點。 • MPU存儲保護單元 • DSP數字信號處理 • FPU 浮點單元 • SP 單精度 • ETM 嵌入式跟蹤宏單元 • MTB 微追蹤緩沖器 • BPU 斷點單元 • DWT 數據觀測與追蹤單元 • ITM 儀器追蹤宏單元 • NVIC 嵌套向量中斷控制器 • WIC 喚醒中斷控制器 • AHB 先進高性能總線 • AMBA 先進微控制器總線架構 現在,讓我們探討一下Cortex-M33的五大特色: 1 – 為ARMv8-M 量身優化的TrustZone技術為整個系統的安全保駕護航 采用TrustZone技術的Cortex-M33處理器擁有兩個安全狀態及多種相關特色: 兩種全新的正交狀態 • 安全狀態 • 非安全狀態 • 4個堆棧和4個堆棧指示寄存器 • 硬件堆棧極限檢查 • 支持安全屬性單元(SAU)的可編程MPU • 用于發出系統安全指示的界面 • 被預先設定的接入點限制的非安全(NS)領域中可以看見安全代碼 • 其它硬件轉向非安全領域時可以自動保存并清除安全寄存器的狀態 • 大量堆積中斷或異常控制,SysTick • 安全和非安全側都配備存儲保護單元 安全狀態和非安全狀態的全面利用,必將開啟眾多新機遇和新應用的大門。該系統使用的高價值專利固件可以在安全狀態下運行。在安全狀態下設置的監管員代碼則可以在系統受到攻擊或不可靠運行后將其恢復初始;而非安全側則像以前一樣向正在用Cortex-M開發軟件的數百萬開發者開放。 2 –協同處理器界面,實現高擴展性 對某些應用而言,專用運算起到的作用可謂非同小可;但為了實現專用運算,這個全球最強大設計生態系統的所有優點必須完美保留,即允許設計師在開發工具、編譯器、調試器、操作系統和中間件之間最大限度的進行選擇。ARM生態系統可以幫助開發商節約時間和成本,進一步提高生產力。 Cortex-M33處理器包含一個可以選配、類似總線的專用界面,主要用于集成緊耦合加速器硬件。對需要頻繁運算的操作而言,該界面可以幫助設計師用自定義的處理硬件提升通用運算能力。須著重指出的是,這樣做并不會使整個生態系統分裂。該界面包含最多可用于8個協同處理器的控制和數據通路,發出的信號可顯示處理器的特權狀態和安全狀態、指令類型、相關寄存器和操作字段。協同處理器通常會合理的在幾個少數循環內完成,或在后臺運行并在完成時自動停止。操作的細節和數據可以通過該界面與單指令同時傳輸,如有需要,還可插入等待狀態。 3 – 用于任務隔離的存儲保護單元(MPU) 設計師可以自行對選配的MPU編程,為每個安全狀態和非安全狀態提供多達16個區域。在多任務環境中,操作系統可以在任務情境切換時重新編程MPU,為每個任務定義存儲訪問許可。比如說,某個應用的某個任務只被允許訪問某些應用數據和特定的周邊設備,這種情況下,MPU將保護所有其他的存儲和周邊設備,將訛誤或未授權訪問阻擋在外,有效提升系統可靠性。 存儲區設置更簡易 Cortex-M33存儲保護架構的開發基于受保護的存儲系統架構PMSAv8。最新版本搭載了針對各區域的基線與限值比較器,而非此前的二次方尺寸對齊模型。每個區域都有一個基線的初始地址、終止地址,以及訪問許可和存儲性質的設定值,因此在這一架構中,設計師設計MPU區域時再也無需顧慮將多個區域整合在一起的麻煩了。功能強化后,軟件開發變得更加簡單,客戶的使用意愿提升,編程步驟也得以減少,并將進而降低情境轉換次數。 4 – DSP拓展 選配的整數DSP拓展可以為系統增加85個新指令。大多數情況下,DSP指令可將性能平均提升3倍,讓所有以數字信號控制為中心的應用性能突飛猛進。 為幫助設計師加速軟件開發,ARM將在CMSIS項目中提供免費的DSP庫,包含整套過濾、轉換和數學功能(如矩陣),并支持多種數據類型。CMSIS項目是開源的,其開發詳情發布在github上。 5 – 單精度浮點單元 基于FPv5的選配單精度浮點拓展單元包括一份額外的16-入口 64位寄存器文件。該拓展新增45個與IEEE754-2008兼容的單精度浮點指令。使用浮點指令通常可將軟件庫平均性能提升10倍。FPU位于單獨的電源域,負責在整個單元不使用的時候切斷電源。 Cortex-M33是一款能在性能、功耗和安全之間實現最佳平衡的處理器。 嵌入式解決方案日益復雜,而它們帶來的價值也不斷凸顯,當今設計師面臨的挑戰是在相沖突的設計要素之間找到最佳平衡。此外,片上系統包含的軟件數量正在顯著增加,但項目開發時間卻不斷縮短。為了用更短的時間交付合格的產品,保證性能,減少成本,我們必須踏出正確的第一步。 Cortex-M33應運而生,為了邁出正確的第一步量身打造,ARM將過往經驗與現有的Cortex-M生態系統完美結合,實現了開發成本降低。得益于采用了多種低功耗技術的全新設計,首先降低的是系統功耗;對打造安全方案的用戶,TrustZone技術則為其應用和寶貴的IP提供保駕護航的堅實基礎。升級后的MPU和TrustZone共同提升系統的可靠性和保護能力。最后值得一提的是,我們永遠不會停止追求生產力的腳步。TrustZone的設計初衷便是保證當前用戶能夠像從前一樣,繼續在非安全領域內開發。Cortex-M33還強化了調試與追蹤性能,使復雜代碼的操作更便捷。與所有其它Cortex-M處理器一樣,Cortex-M33的所有編程都可以在C語言環境下完成,包括全部異常處理程序。總而言之,上述功能誕生的目的都是為了幫助開發者提高生產力,在更短的時間內設計出更復雜的解決方案。 在定義并開發新一代處理器的過程中,許多芯片廠商成為了ARM的合作伙伴,并積極利用TrustZone安全技術設計芯片。ARM生態系統也將重點放在將工具和軟件移植到Cortex-M33。盡管Cortex-M33已經在性能、功耗、安全和生產力之間取得了最佳平衡,但ARM及其合作伙伴將繼續努力,為開發商提供更加出色的產品,幫助其揮展創意、實現遠見,營造更連通、更智能、更安全的世界。 |