在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

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

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

sparc v8架構的異常處理

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

sparc v8架構的異常處理

1.前言

2.異常簡介

3.異常的使用場合

4.sparc v8異常處理流程

5.總結

1.前言

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

2.異常簡介

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

在armv8中,會指定一個異常向量表,將這個異常向量表的首地址交給一個寄存器,當異常發(fā)生的時候,則會跳轉到相應偏移的處理程序中。

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架構中,處理器所處的模式一共有四種,EL0EL1EL2EL3。同一時刻只能處于一種ELx,所以在每個EL層級,異常的處理都會有Synchronous、IRQ、FIQ、Error四種。這也是armv8的特殊之處。

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

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

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

3.異常的使用場合

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

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

另外就是系統(tǒng)進入中斷的時候,本質上來說,中斷其實就是異常的一種,因為異常分為同步和異步,其中異步異常就是中斷。在中斷里做的事情一般都是比較緊急的事情。

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

4.sparc v8異常處理流程

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

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

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

5.總結

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

原文標題:sparc v8架構的異常處理

文章出處:【微信公眾號:嵌入式IoT】歡迎添加關注!文章轉載請注明出處。

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

    關注

    0

    文章

    16

    瀏覽量

    9895

原文標題:sparc v8架構的異常處理

文章出處:【微信號:Embeded_IoT,微信公眾號:嵌入式IoT】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    risc-v與esp32架構對比分析

    RISC-V與ESP32在架構上存在顯著的差異,這些差異主要體現(xiàn)在處理器類型、設計原則、功能特性以及應用場景等方面。以下是對兩者架構的詳細對比分析: 一、
    發(fā)表于 09-26 08:40

    iTOP-3562開發(fā)板/核心板采用RK3562,集成四核A53+Mali G52架構

    A53+Mali G52架構,主頻2GHZ,內置1TOPSNPU算力,RK809動態(tài)調頻。支持OpenGLES1.1/2.0/3.2、0penCL2.0、Vulkan 1.1內嵌高性能2D加速硬件
    發(fā)表于 09-05 11:30

    X86架構處理器有哪些優(yōu)點和缺點

    X86架構處理器作為計算機領域的重要組成部分,具有多個顯著的優(yōu)點和一定的缺點。以下是對X86架構處理器優(yōu)缺點的詳細分析。
    的頭像 發(fā)表于 08-22 11:25 ?2073次閱讀

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

    X86架構和ARM架構是兩種主流的CPU架構,它們在多個方面存在顯著的差異。以下是對這兩種架構的詳細比較,涵蓋了追求目標、應用領域、技術特點、性能功耗比、軟件生態(tài)以及未來趨勢等方面。
    的頭像 發(fā)表于 08-22 11:21 ?9278次閱讀

    探索RISC-V二進制翻譯,openKylin成功在SG2042平臺運行X86架構軟件!

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

    ElfBoard技術貼|如何將libwebsockets庫編譯為x86架構

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

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

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

    移動端芯片性能提升,Armv9架構新升級引發(fā)關注

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

    鴻湖萬聯(lián)成功舉辦基于x86架構的OpenHarmony應用生態(tài)挑戰(zhàn)賽

    近日,由開放原子開源基金會、央視網(wǎng)、江蘇省工業(yè)和信息化廳、無錫市人民政府、江蘇軟件產業(yè)人才發(fā)展基金會、蘇州工業(yè)園區(qū)、無錫高新區(qū)等共同承辦,鴻湖萬聯(lián)參與共建的“基于x86架構的OpenHarmony應用生態(tài)挑戰(zhàn)賽”決賽路演在無錫圓滿落幕。
    的頭像 發(fā)表于 04-23 09:26 ?353次閱讀
    鴻湖萬聯(lián)成功舉辦基于x86<b class='flag-5'>架構</b>的OpenHarmony應用生態(tài)挑戰(zhàn)賽

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

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

    CMS-WRITER V8燒寫器用戶手冊

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

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

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

    【RISC-V開放架構設計之道|閱讀體驗】RV64的初體驗和未來的展望

    來提供用戶模式,來限制不可信代碼的內存訪問空間(u模式),因此在支持RV64架構處理器中會有一個物理內存保護的功能(Physical Memory Protection)。 這個功能也就是我們
    發(fā)表于 01-24 22:47

    基于FreeRTOS+LVGL V8智能家居儀表盤設計

    用野火啟明6M5開發(fā)板制作了一個基于 FreeRTOS 和 LVGL V8 的智能家居儀表盤,顏值較高,也可以作為桌面擺件使用
    的頭像 發(fā)表于 01-22 14:10 ?4987次閱讀
    基于FreeRTOS+LVGL <b class='flag-5'>V8</b>智能家居儀表盤設計

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

    國產高性能、低功耗通用計算微處理器的設計研發(fā)和產業(yè)化推廣。飛騰派是一款面向行業(yè)工程師、學生和愛好者的開源硬件,采用飛騰嵌入式四核處理器,兼容ARM V8架構,板載64位 DDR4內存,
    發(fā)表于 01-02 22:43
    主站蜘蛛池模板: 成人免费视频一区| 五月婷婷六月丁香在线| 在线视频91| 在线播放交视频| 国产精品丝袜xxxxxxx| 国卡一卡二卡三免费网站| 日成人网| 午夜看片影院在线观看| 黄 在线| 一区视频在线| 日本特级视频| 亚洲精品综合网在线8050影院| 免费观看视频在线观看| 亚洲欧洲一区二区三区在线| 日本日b视频| 天天色综合4| 天天操91| 四虎国产精品成人永久免费影视| 99婷婷| 在线视频亚洲| 欧美午夜视频在线观看| 天堂在线链接| 1v1高h肉爽文bl| 国产精品电影一区| 天堂网在线www资源网| 李丽莎尤物福利视频| 久久亚洲精品玖玖玖玖| 久久久精品免费| 宅男69免费永久网站| 国产精品久久久精品视频| 五月激情啪啪| 青草青青视频| 毛片爽爽爽免费看| 婷婷色激情| 狠狠色狠狠色综合日日小蛇| www五月| 日韩综合色| 免费观看欧美成人1314w色| 婷婷激情四射网| 天天添天天干| 亚洲国产丝袜精品一区杨幂|