国产精品久久久aaaa,日日干夜夜操天天插,亚洲乱熟女香蕉一区二区三区少妇,99精品国产高清一区二区三区,国产成人精品一区二区色戒,久久久国产精品成人免费,亚洲精品毛片久久久久,99久久婷婷国产综合精品电影,国产一区二区三区任你鲁

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

完善資料讓更多小伙伴認識你,還能領取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頁純英文文檔,如果沒真正看過,估計一上來就開始打退堂鼓了。后面接觸的芯片的體系架構多了,自然也明白很多東西其實是有一些共性的,雖然架構不同,但是指令集、流水線以及系統運行的模式也能猜測7到8分準確。本文主要介紹一下sparc v8體系架構下的異常處理,同時簡單的對比一下armv8體系架構的異常。

2.異常簡介

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

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

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的異常更好理解。就是系統在user模式下權限比較低,可以做不破壞系統狀態的事情,比如不能改變系統運行狀態,不能修改寄存器值,不能修改PC指針等等。但是在supervisor下就能夠做這些事情。

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

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

3.異常的使用場合

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

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

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

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

4.sparc v8異常處理流程

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

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

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

5.總結

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

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

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

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

    關注

    0

    文章

    16

    瀏覽量

    10169

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

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

收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    使用PLCSIM Advanced V8仿真測試S7-1200 G2的Modbus TCP通信

    今天試一下用 PLCSIM Advanced V8 仿真測試 S7-1200 G2 的 Modbus TCP 通信。
    的頭像 發表于 02-02 17:09 ?835次閱讀
    使用PLCSIM Advanced <b class='flag-5'>V8</b>仿真測試S7-1200 G2的Modbus TCP通信

    RISC-V異常中斷機制全解析

    RISC-V 作為開源、模塊化的精簡指令集架構,其異常中斷機制是保障系統可靠運行、響應外部事件與處理內部錯誤的核心支撐。
    的頭像 發表于 12-28 14:41 ?1437次閱讀
    RISC-<b class='flag-5'>V</b><b class='flag-5'>異常</b>中斷機制全解析

    深入剖析ARM64異常處理:開發者必須掌握的底層核心邏輯

    在ARM64架構的開發領域,異常處理絕非單純的理論知識點,而是直接決定系統穩定性、調試效率和功能實現的關鍵技術。無論是嵌入式開發、Linux內核移植,還是驅動開發與芯片調試,理解異常
    的頭像 發表于 12-24 07:05 ?1104次閱讀
    深入剖析ARM64<b class='flag-5'>異常</b><b class='flag-5'>處理</b>:開發者必須掌握的底層核心邏輯

    線路保護光纖通道異常處理方法

    通道異常的 常見原因、處理步驟及預防措施 ,幫助運維人員快速定位問題,提升故障處理效率。 廣州郵科光纖線路保護系統 一、光纖通道異常的常見表現 當線路保護光纖通道出現
    的頭像 發表于 11-17 10:01 ?1108次閱讀
    線路保護光纖通道<b class='flag-5'>異常</b><b class='flag-5'>處理</b>方法

    元服務上自檢

    數量和排隊情況影響,請耐心等待。 通過:表示檢測通過,可以提交上。點擊“報告”可查看詳細的檢測報告。 待優化:表示檢測未通過。點擊“報告”可查看詳細的異常信息與日志等。若合法性檢測通過、但上
    發表于 10-21 17:18

    基于蜂鳥E203架構的指令集K擴展

    向量操作指令,例如向量加法、向量乘法等。 在蜂鳥E203架構中,可以添加K擴展指令集,以處理大規模的數據集,可以添加以下指令: 1.VADD:向量加法指令,將兩個向量相加并存儲結果到一個向量寄存器中
    發表于 10-21 09:38

    迅為Hi3403V610開發板海思Cortex-A55架構核心板卡

    迅為電子重磅推出基于海思Hi3403處理器的高性能核心板,采用先進的四核Cortex-A55架構,主頻高達1.4GHz,以強勁算力、超凡能效比與卓越的圖像處理能力,為千行百業的智能化升級注入核心動力。無論是智能視覺、工業互聯,還
    的頭像 發表于 09-30 14:18 ?686次閱讀
    迅為Hi3403<b class='flag-5'>V</b>610開發板海思Cortex-A55<b class='flag-5'>架構</b>核心板卡

    Texas Instruments DRA821x Jacinto? 64位處理器技術解析

    Texas Instruments DRA821x Jacinto? 64位處理器基于ARM?v8架構,并為帶有云連接性的網關系統進行了優化。片上系統 (SoC) 設計通過集成降低了系統級成本
    的頭像 發表于 08-28 11:33 ?1083次閱讀
    Texas Instruments DRA821x Jacinto? 64位<b class='flag-5'>處理</b>器技術解析

    德州儀器AM68x Jacinto 8處理器技術解析

    Texas Instruments AM68x 64位Jacinto? 8 TOPS Vision SoC處理器是一款基于Eval Jacinto 7架構的可擴展處理器。該系列面向智能
    的頭像 發表于 08-27 15:08 ?1110次閱讀
    德州儀器AM68x Jacinto <b class='flag-5'>8</b><b class='flag-5'>處理</b>器技術解析

    進迭時空 V8 RISC-V 后端優化

    揮著至關重要的作用。自2020年起,中科院軟件所PLCT實驗室等團隊開始為V8引擎開發RISC-V后端,并持續推動V8對RISC-V架構的支
    的頭像 發表于 07-31 09:02 ?1226次閱讀
    進迭時空 <b class='flag-5'>V8</b> RISC-<b class='flag-5'>V</b> 后端優化

    迅為iTOP-3588S開發板核心板引腳240PIN全部引出8GB內存32GBEMMC存儲

    性能強 iTOP-3588S開發板采用瑞芯微RK3588S處理器,是全新一代AloT高端應用芯片,搭載八核64位CPU,四核Cortex-A76和四核Cortex-A55架構主頻高達2.4GHZ
    發表于 06-23 11:19

    RISC-V架構CPU的RAS解決方案

    RISC-V架構以追趕者的姿態在多個應用領域與X86架構和ARM架構展開競爭。在服務器應用領域,RISC-V
    的頭像 發表于 06-06 17:03 ?1806次閱讀
    RISC-<b class='flag-5'>V</b><b class='flag-5'>架構</b>CPU的RAS解決方案

    HPM5E31IGN單核 32 位 RISC-V 處理

    本和功耗敏感的領域。l 單核32位設計:單核設計簡化了硬件復雜度,適合對實時性要求高但多核需求不強的應用場景;32位架構在內存尋址和數據處理能力上滿足大多數嵌入式系統的需求。l 低功耗與高集成度:作為
    發表于 05-29 09:23

    iTOP-3588S開發板四核心架構GPU內置GPU可以完全兼容0penGLES1.1、2.0和3.2。

    性能強 iTOP-3588S開發板采用瑞芯微RK3588S處理器,是全新一代AloT高端應用芯片,搭載八核64位CPU,四核Cortex-A76和四核Cortex-A55架構主頻高達2.4GHZ
    發表于 05-15 10:36

    iTOP-3588開發板采用瑞芯微RK3588處理器四核心架構GPU內置獨立NPU強大的視頻編解碼

    架構,主頻高達2.4GHz。 四核心架構GPU 集成Mali G610 MP4四核GPU、支持OpenGLES 1.1.2.0、 3.2, OpenCL 2.2和Vulkan1.2。帶有MMU的特殊2D
    發表于 04-09 16:09