www.久久久久|狼友网站av天堂|精品国产无码a片|一级av色欲av|91在线播放视频|亚洲无码主播在线|国产精品草久在线|明星AV网站在线|污污内射久久一区|婷婷综合视频网站

當前位置:首頁 > 電源 > 數(shù)字電源
[導讀] ARM體系結構  目前,ARM系列的通用32位RISC微處理器有ARM7、ARM9、ARM9E、ARM10等多個產品,這些處理器可以工作于7種模式下。除User模式以外的其它模式都叫做特權模式,除User和System以外的其它5種模式叫做異常

 ARM體系結構

  目前,ARM系列的通用32位RISC微處理器有ARM7、ARM9、ARM9E、ARM10等多個產品,這些處理器可以工作于7種模式下。除User模式以外的其它模式都叫做特權模式,除User和System以外的其它5種模式叫做異常模式。大部分應用程序都在User模式下運行,當處理器處于User模式下時,執(zhí)行的程序無法訪問一些被保護的系統(tǒng)資源,以利于操作系統(tǒng)控制系統(tǒng)資源的使用,也不能改變模式,否則就會導致一次異常。對于System模式,任何異常都不會導致進入這一模式,而且它使用的寄存器和User模式下基本相同,主要是用于有訪問系統(tǒng)資源請求而又避免使用額外的寄存器的操作系統(tǒng)任務。在特權模式下,它們可以完全訪問系統(tǒng)資源,可以自由地改變模式。在處理特定的異常時,系統(tǒng)進入對應的異常模式下。這5種異常模式都有各自額外的寄存器,用于避免在發(fā)生異常的時候與用戶模式下的程序發(fā)生沖突。

  在任意一種處理器模式中,都使用同一個寄存器來標識當前處理器的工作模式,這個寄存器叫做CPSR(當前程序狀態(tài)寄存器),它的0~4位用來表示CPU模式,而且在每一種處理器異常模式下,都有一個對應的SPSR(緩存程序狀態(tài)寄存器),用來保存進入異常模式前的CPSR的值。SPSR的作用就是當CPU從異常模式退出時,通過一條簡單的匯編指令就能夠恢復進入異常模式前的CPSR,該值保存在當前異常模式的SPSR中。

  啟動代碼的設計

  啟動代碼類似于電腦中的BIOS,它從系統(tǒng)上電開始接管CPU,依次需要負責初始化 CPU在各種模式下的堆??臻g、設定CPU的內存映射、對系統(tǒng)的各種控制寄存器做初始化、對CPU的外部存儲器進行初始化、設定各外圍設備的基地址、創(chuàng)建正確的中斷向量表、為C代碼執(zhí)行創(chuàng)建ZI(零創(chuàng)建)區(qū),然后進入到C代碼。 在C代碼中繼續(xù)對時鐘、RS232端口進行初始化,然后打開系統(tǒng)中斷允許位。最后進入到應用代碼中執(zhí)行,執(zhí)行期間響應各種不同的中斷信號并調用預先設置好的中斷服務程序處理這些中斷。整個過程的流程圖如圖1所示。

  


 

  圖1 啟動代碼流程圖

  堆棧初始化

  堆棧的初始化要處理的事情是為處理器的7個處理器模式分配堆??臻g。以下以FIQ模式下的堆棧設置為例說明:

  ORR r1, r0, #LOCKOUT | FIQ_MODE;把模式放在r1中,LOCKOUT用來屏蔽中斷位;

  MSR cpsr, r1 ;改變CPU的CPSR寄存器,進入到指定的FIQ模式;

  MSR spsr, r2 ;保存前一模式;

  LDR sp, =FIQ_STACK ;把FIQ模式下的堆棧起始值賦給當前的SP,F(xiàn)IQ_STACK是分配給FIQ模式堆??臻g(比如說1K字節(jié))的起始地址。按這種方式設置其它模式下的堆棧。

  DRAM的初始化根據系統(tǒng)配置信息來決定,因為系統(tǒng)不一定會用到DRAM,但是一定要做SDRAM的初始化。主要的處理內容是ROM和RAM基址的設定、數(shù)據總線的寬度、SDRAM的刷新時間等等,這些可以參照S3C4510B芯片的用戶手冊。特殊寄存器的設置主要是針對I/O口,比方說設定幾個I/O位用做系統(tǒng)狀態(tài)指示燈LED。寄存器的設定主要根據硬件的配置情況而定,值得注意的是由于這段啟動代碼是燒錄到ROM中的,而中斷向量必須位于零地址,所以在存儲單元沒有重新映射之前ROM基址的設定應該為零地址。

  拷貝(image)主要是為了提高運行速度,編譯生成的映像文件代碼從ROM內拷貝到RAM中去,而程序的執(zhí)行也就在RAM中。當然,啟動代碼對運行速度的要求不是很嚴格,所以這個拷貝動作可以不用做,讓代碼存放在ROM中,代碼的執(zhí)行也在ROM中,而運行中所需要的數(shù)據在RAM中。

  內存的初始化是為C代碼的運行開辟內存區(qū),代碼編譯后會分為三個區(qū):只讀區(qū)、可讀可寫區(qū),

  零初始化區(qū)。內存的初始化處理的內容是:當只讀區(qū)截止地址等于可讀可寫區(qū)基址時,把零初始化區(qū)各字節(jié)清零;當只讀區(qū)截止地址不等于可讀可寫區(qū)基址時,如果可讀可寫區(qū)基址小于零初始化基址,就從只讀區(qū)截止地址處開始把數(shù)據拷貝到可讀可寫區(qū)基址處,直到到達零初始化基址,然后把零初始化區(qū)各字節(jié)清零,否則也只用把零初始化區(qū)各字節(jié)清零。

  中斷向量表是用于處理異常情況的,當發(fā)生異常時,首先要保存當前程序的返回地址和CPSR寄存器的值,然后進入到相應的異常向量地址,一般來說在異常向量地址是一個跳轉指令,使程序進入相應的異常處理過程。由于中斷向量表要位于系統(tǒng)的零地址,當把啟動代碼燒錄到EEPROM中運行時就需要把ROM的地址定義到零地址,所以程序的入口處如下:

  

[!--empirenews.page--]

 

  系統(tǒng)重新映射當你為了提高運行速度而把ROM的Image拷貝到RAM后,中斷向量表就不是在零地址處,因此要重新映射存儲單元,把RAM的地址重新設定為零地址。映射就是把啟動代碼從ROM(EEPROM或者Flash)拷貝到SDRAM運行,同時再拷貝完畢以后進行內存的重新映射,把SDRAM映射到原來的ROM地址(0x0000)中,這樣就可以用SDRAM中的代碼寫Flash,使得程序代碼得以更新。但是需要注意的是,如果程序進行了映射,這樣就對在線調試帶來了困難,使得在線調試不可以在RAM中進行(如果寫入EEPROM的代碼是映射了的,則在調試器啟動的時候必然也會對程序進行映射,使得程序在調試器中不可以定位到原來的地方,使得調試失敗)。一個折中的方法是,不進行映射,就是說在調試的代碼中不可以使用下載,這樣就可以像普通的代碼一樣進行調試了。

  結 語

  做完這些初始化后,讓CPU切換到用戶模式下,并把堆棧指針SP指定到用戶堆棧區(qū),就可以進入到C代碼區(qū)運行。在C代碼中繼續(xù)對時鐘、RS232端口進行初始化,然后打開系統(tǒng)中斷允許位,進入到應用代碼中執(zhí)行。此程序加載到處理器S3C4510B中經過調試,CPU可以正常啟動,能夠對中斷請求做出及時的響應,上層應用的主代碼可以加載到Flash中,移植實時操作系統(tǒng)RTXC后對多任務的調度控制正常。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內容真實性等。需要轉載請聯(lián)系該專欄作者,如若文章內容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

北京2022年10月19日 /美通社/ -- 隨著云計算、大數(shù)據的普及發(fā)展,過去的"云"是服務于大企業(yè)的計算模型,而十多年過去了,越來越多的應用及業(yè)務走上"云端",對計算核心數(shù)需求...

關鍵字: ARM 大數(shù)據 云游戲 CPU

無線連接已成為許多產品的必備功能,但往往會增加系統(tǒng)設計的成本和復雜性,因為它通常必須作為更大應用的附加功能。Microchip Technology Inc.(美國微芯科技公司)今日推出首款基于Arm Cortex?-M...

關鍵字: Microchip ARM PIC

在這篇文章中,小編將對CPU中央處理器的相關內容和情況加以介紹以幫助大家增進對CPU中央處理器的了解程度,和小編一起來閱讀以下內容吧。

關鍵字: CPU 中央處理器 晶圓

在桌面級處理器上,AMD多年來一直在多核上有優(yōu)勢,不過12代酷睿開始,Intel通過P、E核異構實現(xiàn)了反超,13代酷睿做到了24核32線程,核心數(shù)已經超過了銳龍7000的最大16核。在服務器處理器上,AMD優(yōu)勢更大,64...

關鍵字: AMD CPU Intel EUV

SAIHUB CAB 025M成功獲得安全試驗所UL美國與加拿大認證證書 新加坡2022年10月17日 /美通社/ -- SAI.TECH Global Corporation("SAI.TECH"...

關鍵字: AI BSP PS 清潔能源

華為麒麟芯片(HUAWEI Kirin)是華為技術有限公司于2019年9月6日在德國柏林和北京同時發(fā)布的一款新一代旗艦芯片。華為麒麟在3G芯片大戰(zhàn)中,扮演了“黑馬”的角色。

關鍵字: 麒麟 CPU 華為Mate 50

物聯(lián)網正在擴大規(guī)模并加速發(fā)展,進而驅動著全新的經濟。而Arm生態(tài)系統(tǒng)正是這一巨大機遇背后的推動力。

關鍵字: ARM 物聯(lián)網

ARM公司是一家知識產權(IP)供應商,它與一般的半導體公司最大的不同就是不制造芯片且不向終端用戶出售芯片,而是通過轉讓設計方案,由合作伙伴生產出各具特色的芯片。

關鍵字: ARM

據業(yè)內信息,近日ADM的一份內部報告顯示,ADM正在計劃降低其銳龍 7000 CPU的生產計劃。現(xiàn)階段全球市場PC的低迷和銷量下滑,再加上AM5平臺整體反響不佳等等一系列原因導致ADM采取這一行動計劃。

關鍵字: PC ADM 銳龍 7000 CPU

北京2022年10月17日 /美通社/ --  "天下武功、唯快不破",數(shù)字經濟時代尤甚。 數(shù)據極富價值,堪比新時代的石油。數(shù)字經濟時代,數(shù)據價值如何快速、高效地釋放顯得尤為重要。自20...

關鍵字: 軟件 IO SSD CPU

數(shù)字電源

15504 篇文章

關注

發(fā)布文章

編輯精選

技術子站

關閉