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

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

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

sparc v8架構(gòu)的異常處理

嵌入式IoT ? 來源:嵌入式IoT ? 作者:嵌入式IoT ? 2020-09-25 15:44 ? 次閱讀

sparc v8架構(gòu)的異常處理

1.前言

2.異常簡(jiǎn)介

3.異常的使用場(chǎng)合

4.sparc v8異常處理流程

5.總結(jié)

1.前言

對(duì)于研究芯片處理器架構(gòu),是件非常有意思的事情。剛開始的接觸時(shí)候也是一頭霧水,不知所云,看著厚厚的架構(gòu)手冊(cè),不知道從哪里下手。比如《ARMv8-A Architecture reference manual》一共是6666頁純英文文檔,如果沒真正看過,估計(jì)一上來就開始打退堂鼓了。后面接觸的芯片的體系架構(gòu)多了,自然也明白很多東西其實(shí)是有一些共性的,雖然架構(gòu)不同,但是指令集、流水線以及系統(tǒng)運(yùn)行的模式也能猜測(cè)7到8分準(zhǔn)確。本文主要介紹一下sparc v8體系架構(gòu)下的異常處理,同時(shí)簡(jiǎn)單的對(duì)比一下armv8體系架構(gòu)的異常。

2.異常簡(jiǎn)介

Exception,中文翻譯一般是異常,龍芯的手冊(cè)上翻譯為例外。就是系統(tǒng)在運(yùn)行的過程中發(fā)生了異常事件,比如除0溢出、數(shù)組越界、文件找不到等。這種錯(cuò)誤一般都是可以預(yù)測(cè)到的,所以芯片設(shè)計(jì)的時(shí)候,也會(huì)預(yù)留一些陷阱,當(dāng)在特定的情況下,進(jìn)入這個(gè)陷阱,說明發(fā)生了特定的事情。當(dāng)然在語言處理層面,也會(huì)引入異常的這個(gè)概念,也就是比如java中,遇到異??梢詔hrow拋棄也能夠catch捕獲異常。對(duì)于芯片架構(gòu)來說,這種處理過程更加有意思。

在armv8中,會(huì)指定一個(gè)異常向量表,將這個(gè)異常向量表的首地址交給一個(gè)寄存器,當(dāng)異常發(fā)生的時(shí)候,則會(huì)跳轉(zhuǎn)到相應(yīng)偏移的處理程序中。

system_vectors: .align11 .setVBAR,system_vectors .orgVBAR //ExceptionfromCurrentEL(EL1)withSP_EL0(SPSEL=1) .org(VBAR+0x00+0) Bvector_error//Synchronous .org(VBAR+0x80+0) Bvector_irq//IRQ/vIRQ .org(VBAR+0x100+0) Bvector_fiq//FIQ/vFIQ .org(VBAR+0x180+0) Bvector_error//Error/vError //ExceptionfromCurrentEL(EL1)withSP_ELn .org(VBAR+0x200+0) Bvector_error//Synchronous .org(VBAR+0x280+0) Bvector_irq//IRQ/vIRQ .org(VBAR+0x300+0) Bvector_fiq//FIQ/vFIQ .org(VBAR+0x380+0) Bvector_error //ExceptionfromlowerEL,aarch64 .org(VBAR+0x400+0) Bvector_error .org(VBAR+0x480+0) Bvector_error .org(VBAR+0x500+0) Bvector_error .org(VBAR+0x580+0) Bvector_error //ExceptionfromlowerEL,aarch32 .org(VBAR+0x600+0) Bvector_error .org(VBAR+0x680+0) Bvector_error .org(VBAR+0x700+0) Bvector_error .org(VBAR+0x780+0) Bvector_error .org(VBAR+0x800+0) Bvector_error

在armv8架構(gòu)中,處理器所處的模式一共有四種,EL0EL1EL2EL3。同一時(shí)刻只能處于一種ELx,所以在每個(gè)EL層級(jí),異常的處理都會(huì)有Synchronous、IRQ、FIQ、Error四種。這也是armv8的特殊之處。

而對(duì)于sparc v8架構(gòu)而言,處理器的模式只有兩種,supervisor 和 user mode。只需要設(shè)置寄存器即可。相比較而言sparc v8的異常更好理解。就是系統(tǒng)在user模式下權(quán)限比較低,可以做不破壞系統(tǒng)狀態(tài)的事情,比如不能改變系統(tǒng)運(yùn)行狀態(tài),不能修改寄存器值,不能修改PC指針等等。但是在supervisor下就能夠做這些事情。

所以這時(shí)候問題就來了,兩種模式如何切換,這時(shí)就需要借助Exception。一般來說,sparc v8的啟動(dòng)入口就是異常向量的入口,所以第一次進(jìn)來的就是reset異常。當(dāng)系統(tǒng)處于異常處理程序的時(shí)候,這時(shí)候的模式為supervisor,可以做很多事情,比如修改pc指針,修改處理器模式等等。最后退出異常處理,進(jìn)入用戶模式進(jìn)行處理。

在sparc中,預(yù)留了一些可以配置的軟件中斷,使用ta n來觸發(fā)系統(tǒng)進(jìn)入特定的陷阱,其中n表示軟件中斷標(biāo)號(hào),這些都是設(shè)計(jì)者為芯片使用者留下的工具。

3.異常的使用場(chǎng)合

說起異常,很多人都覺得這是一個(gè)致命的錯(cuò)誤,所以避而遠(yuǎn)之。其實(shí)不然,異常使用得當(dāng),將會(huì)大大提高系統(tǒng)的運(yùn)行效率。比如在rtos porting的過程中,我們常常需要改變處理器的運(yùn)行狀態(tài),或者利用異常進(jìn)入到特定的處理函數(shù)中,例如system call等等。

異常也提供了安全機(jī)制,比如在芯片使用上,我們往往不會(huì)賦予我們的執(zhí)行程序在芯片的最高權(quán)限下去使用這個(gè)芯片。比如armv8,我們不會(huì)去el3上運(yùn)行一個(gè)系統(tǒng),這樣一不小心就會(huì)出現(xiàn)不可逆轉(zhuǎn)的錯(cuò)誤。一般的rtos或者linux都會(huì)選擇el1作為系統(tǒng)運(yùn)行的層級(jí)。需要在el3上做的事情比較少,這時(shí)候就可以通過異常轉(zhuǎn)換層級(jí),達(dá)到我們的目的。在sparc v8上也是這樣,一般程序運(yùn)行在user mode,只有需要的時(shí)候,才會(huì)切換到supervisor mode。

另外就是系統(tǒng)進(jìn)入中斷的時(shí)候,本質(zhì)上來說,中斷其實(shí)就是異常的一種,因?yàn)楫惓7譃橥胶彤惒剑渲挟惒疆惓>褪侵袛?。在中斷里做的事情一般都是比較緊急的事情。

當(dāng)系統(tǒng)進(jìn)入trap的時(shí)候,就是出現(xiàn)了同步異常的時(shí)候,這時(shí)候需要告知使用者,當(dāng)前出現(xiàn)了除零錯(cuò)誤地址訪問異常等等。這些都是trap必須設(shè)置的,如果芯片沒有這些保護(hù)機(jī)制,任程序繼續(xù)執(zhí)行下去,那將會(huì)造成不可預(yù)知的后果。

4.sparc v8異常處理流程

在sparc異常的處理中,默認(rèn)情況下會(huì)在程序執(zhí)行的入口處設(shè)定異常向量表。然后首先通過一個(gè)reset的異常進(jìn)入第一行啟動(dòng)代碼。系統(tǒng)運(yùn)行起來后,會(huì)初始化狀態(tài)寄存器,初始化C語言執(zhí)行需要的環(huán)境,比如清除bss段、設(shè)置sp棧指針等等。

然后程序進(jìn)入C語言執(zhí)行,其中匯編語言中的ret1會(huì)主動(dòng)將pc值填充,然后跳轉(zhuǎn)。系統(tǒng)運(yùn)行時(shí),若遇到中斷需要處理,則進(jìn)入中斷處理程序。如果系統(tǒng)在user mode下運(yùn)行,需要修改pc值,那么只能通過trap指令進(jìn)行,其中sparc v8的ta指令就是進(jìn)入同步異常,然后去處理supervisor模式才能做的事情。

對(duì)于一個(gè)rtos來說,線程壓棧的時(shí)候,會(huì)把當(dāng)前的pc、和一些狀態(tài)寄存器、通用寄存器的值讀出來,保存在當(dāng)前的線程棧中,也就是一塊內(nèi)存中,接著會(huì)將另外的一個(gè)線程棧的內(nèi)容從內(nèi)存中取出來,然后設(shè)置pc值、狀態(tài)寄存器值、以及通用寄存器值等等,這時(shí)在sparc v8上就需要執(zhí)行ta 3指令了,其中ta n中的n是自己設(shè)定的,需要自己實(shí)現(xiàn)相關(guān)的處理函數(shù),這里只是預(yù)留了一個(gè)陷阱,至于陷阱怎么處理,那是需要自己來設(shè)定的。

5.總結(jié)

本文主要介紹了一下異常這部分的處理邏輯,只有在研究芯片體系架構(gòu)的時(shí)候,才會(huì)需要非常深刻的了解這一塊。使用好異常,將會(huì)讓程序設(shè)計(jì)變得更加的合理,也能夠非常清晰的了解操作系統(tǒng)的底層運(yùn)行邏輯。

原文標(biāo)題:sparc v8架構(gòu)的異常處理

文章出處:【微信公眾號(hào):嵌入式IoT】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

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

    關(guān)注

    0

    文章

    16

    瀏覽量

    9860

原文標(biāo)題:sparc v8架構(gòu)的異常處理

文章出處:【微信號(hào):Embeded_IoT,微信公眾號(hào):嵌入式IoT】歡迎添加關(guān)注!文章轉(zhuǎn)載請(qǐng)注明出處。

收藏 人收藏

    評(píng)論

    相關(guān)推薦

    X86架構(gòu)處理器有哪些優(yōu)點(diǎn)和缺點(diǎn)

    X86架構(gòu)處理器作為計(jì)算機(jī)領(lǐng)域的重要組成部分,具有多個(gè)顯著的優(yōu)點(diǎn)和一定的缺點(diǎn)。以下是對(duì)X86架構(gòu)處理器優(yōu)缺點(diǎn)的詳細(xì)分析。
    的頭像 發(fā)表于 08-22 11:25 ?426次閱讀

    X86架構(gòu)和ARM架構(gòu)有什么區(qū)別

    X86架構(gòu)和ARM架構(gòu)是兩種主流的CPU架構(gòu),它們?cè)诙鄠€(gè)方面存在顯著的差異。以下是對(duì)這兩種架構(gòu)的詳細(xì)比較,涵蓋了追求目標(biāo)、應(yīng)用領(lǐng)域、技術(shù)特點(diǎn)、性能功耗比、軟件生態(tài)以及未來趨勢(shì)等方面。
    的頭像 發(fā)表于 08-22 11:21 ?3078次閱讀

    探索RISC-V二進(jìn)制翻譯,openKylin成功在SG2042平臺(tái)運(yùn)行X86架構(gòu)軟件!

    眾所周知,在新的指令集架構(gòu)發(fā)展初期,往往采用兼容其他架構(gòu)軟件的方法來拓展自身生態(tài)體系,如蘋果公司的Rosetta2和微軟的Arm64EC,都是將X86架構(gòu)軟件運(yùn)行在ARM架構(gòu)的系統(tǒng)之上
    的頭像 發(fā)表于 07-24 08:34 ?261次閱讀
    探索RISC-<b class='flag-5'>V</b>二進(jìn)制翻譯,openKylin成功在SG2042平臺(tái)運(yùn)行X86<b class='flag-5'>架構(gòu)</b>軟件!

    ElfBoard技術(shù)貼|如何將libwebsockets庫編譯為x86架構(gòu)

    在之前的文章中,我們已經(jīng)詳細(xì)介紹了如何交叉編譯libwebsockets并將其部署到ELF1開發(fā)板上。然而在調(diào)試階段,發(fā)現(xiàn)將libwebsockets在Ubuntu環(huán)境下編譯為x86架構(gòu)可能更為方便
    的頭像 發(fā)表于 07-10 09:38 ?1003次閱讀
    ElfBoard技術(shù)貼|如何將libwebsockets庫編譯為x86<b class='flag-5'>架構(gòu)</b>

    迅為RK3562核心板四核A53+MaliG52架構(gòu),應(yīng)用于商業(yè)平板電腦,視頻會(huì)議,智能家居,教育電子,醫(yī)療設(shè)備,邊緣計(jì)算,工業(yè)應(yīng)用

    迅為RK3562核心板四核A53+MaliG52架構(gòu),應(yīng)用于商業(yè)平板電腦,視頻會(huì)議,智能家居,教育電子,醫(yī)療設(shè)備,邊緣計(jì)算,工業(yè)應(yīng)用
    發(fā)表于 07-09 10:57

    移動(dòng)端芯片性能提升,Armv9架構(gòu)新升級(jí)引發(fā)關(guān)注

    “數(shù)碼博主”5月17日的最新爆料指出,聯(lián)發(fā)科積極推進(jìn)Armv9新一代IP BLACKHAWK“黑鷹”的架構(gòu)設(shè)計(jì),預(yù)計(jì)天璣9400芯片將采用這一架構(gòu),有望以“全大核”設(shè)計(jì)再度領(lǐng)跑移動(dòng)SoC CPU性能榜單。
    的頭像 發(fā)表于 05-17 16:51 ?783次閱讀

    福特野馬旗艦性能版回歸中國(guó),搭載5.0L Coyote V8自然吸氣引擎

    早在 2015 年,福特便推出了以前的野馬系列,搭載 2.3L 渦輪增壓四缸引擎和 5.0L V8 兩大動(dòng)力選擇。但由于日益嚴(yán)格的排放限制,自 2020 年起,V8 車型在中國(guó)市場(chǎng)逐漸消失。
    的頭像 發(fā)表于 02-19 15:38 ?385次閱讀

    CMS-WRITER V8燒寫器用戶手冊(cè)

    電子發(fā)燒友網(wǎng)站提供《CMS-WRITER V8燒寫器用戶手冊(cè).pdf》資料免費(fèi)下載
    發(fā)表于 01-30 17:54 ?1次下載

    arm架構(gòu)和x86架構(gòu)區(qū)別 linux是x86還是arm

    ARM架構(gòu)和x86架構(gòu)是兩種不同的計(jì)算機(jī)處理架構(gòu),它們?cè)隗w系結(jié)構(gòu)、指令集、應(yīng)用領(lǐng)域等方面有著明顯的區(qū)別。Linux操作系統(tǒng)則具有廣泛的適配性,可以運(yùn)行在各種
    的頭像 發(fā)表于 01-30 13:46 ?1.4w次閱讀

    【飛騰派4G版免費(fèi)試用】大家來了解飛騰派4G版開發(fā)板

    國(guó)產(chǎn)高性能、低功耗通用計(jì)算微處理器的設(shè)計(jì)研發(fā)和產(chǎn)業(yè)化推廣。飛騰派是一款面向行業(yè)工程師、學(xué)生和愛好者的開源硬件,采用飛騰嵌入式四核處理器,兼容ARM V8架構(gòu),板載64位 DDR4內(nèi)存,
    發(fā)表于 01-02 22:43

    Debian宣布停止i386架構(gòu)支持

    近日,在英國(guó)劍橋市舉行的小規(guī)模DebConf活動(dòng)中,Debian GNU/Linux的發(fā)布團(tuán)隊(duì)召開春季會(huì)議,探討了未來發(fā)展方向,其中包括停止對(duì)i386架構(gòu)的支持。
    的頭像 發(fā)表于 12-19 10:16 ?642次閱讀

    簡(jiǎn)單認(rèn)識(shí)IA-64架構(gòu)處理

    IA- 64 架構(gòu)處理器(IA - 64 Processors )最早為安騰架構(gòu) (Itanium Architecture)處理器的縮寫,支持64 位
    的頭像 發(fā)表于 11-27 09:33 ?1078次閱讀

    如何高效學(xué)習(xí)Arm架構(gòu)v8v9架構(gòu)

    深入學(xué)習(xí)MMU的功能,包括虛擬內(nèi)存、頁表、地址翻譯和內(nèi)存保護(hù)。實(shí)際操作:配置和使用MMU,了解虛擬內(nèi)存系統(tǒng)的工作方式。
    的頭像 發(fā)表于 11-09 12:27 ?635次閱讀
    如何高效學(xué)習(xí)Arm<b class='flag-5'>架構(gòu)</b>的<b class='flag-5'>v8</b>和<b class='flag-5'>v</b>9<b class='flag-5'>架構(gòu)</b>

    【新品體驗(yàn)】飛騰派4G版基礎(chǔ)套裝免費(fèi)試用

    飛騰派是由飛騰攜手中電港螢火工場(chǎng)研發(fā)的一款面向行業(yè)工程師、學(xué)生和愛好者的開源硬件,采用飛騰嵌入式四核處理器,兼容ARM V8架構(gòu),板載64位 DDR4內(nèi)存,分為2G和4G兩個(gè)版本。主板板載WiFi
    發(fā)表于 10-25 11:44

    X86架構(gòu)與ARM架構(gòu)的主要區(qū)別

    X86和ARM是兩種主要的CPU架構(gòu),X86架構(gòu)的CPU是PC服務(wù)器行業(yè)的老大,而ARM架構(gòu)的CPU則是移動(dòng)端的老大。它們?cè)谠O(shè)計(jì)理念、性能、功耗和應(yīng)用領(lǐng)域等方面都有顯著的區(qū)別。設(shè)計(jì)理念X86
    的頭像 發(fā)表于 09-22 08:23 ?7988次閱讀
    X86<b class='flag-5'>架構(gòu)</b>與ARM<b class='flag-5'>架構(gòu)</b>的主要區(qū)別