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

    浏览量

    9896

原文标题:sparc v8架构的异常处理

文章出处:【微信号:Embeded_IoT,微信公众号:嵌入式IoT】欢迎添加关注!文章转载请注明出处。

收藏 人收藏

    评论

    相关推荐

    risc-v与esp32架构对比分析

    RISC-V与ESP32在架构上存在显著的差异,这些差异主要体现在处理器类型、设计原则、功能特性以及应用场景等方面。以下是对两者架构的详细对比分析: 一、
    发表于 09-26 08:40

    iTOP-3562开发板/核心板采用RK3562,集成四核A53+Mali G52架构

    A53+Mali G52架构,主频2GHZ,内置1TOPSNPU算力,RK809动态调频。支持OpenGLES1.1/2.0/3.2、0penCL2.0、Vulkan 1.1内嵌高性能2D加速硬件
    发表于 09-05 11:30

    X86架构处理器有哪些优点和缺点

    X86架构处理器作为计算机领域的重要组成部分,具有多个显著的优点和一定的缺点。以下是对X86架构处理器优缺点的详细分析。
    的头像 发表于 08-22 11:25 2289次阅读

    X86架构和ARM架构有什么区别

    X86架构和ARM架构是两种主流的CPU架构,它们在多个方面存在显著的差异。以下是对这两种架构的详细比较,涵盖了追求目标、应用领域、威廉希尔官方网站 特点、性能功耗比、软件生态以及未来趋势等方面。
    的头像 发表于 08-22 11:21 9450次阅读

    探索RISC-V二进制翻译,openKylin成功在SG2042平台运行X86架构软件!

    众所周知,在新的指令集架构发展初期,往往采用兼容其他架构软件的方法来拓展自身生态体系,如苹果公司的Rosetta2和微软的Arm64EC,都是将X86架构软件运行在ARM架构的系统之上
    的头像 发表于 07-24 08:34 590次阅读
    探索RISC-<b class='flag-5'>V</b>二进制翻译,openKylin成功在SG2042平台运行X86<b class='flag-5'>架构</b>软件!

    ElfBoard威廉希尔官方网站 贴|如何将libwebsockets库编译为x86架构

    在之前的文章中,我们已经详细介绍了如何交叉编译libwebsockets并将其部署到ELF1开发板上。然而在调试阶段,发现将libwebsockets在Ubuntu环境下编译为x86架构可能更为方便
    的头像 发表于 07-10 09:38 1243次阅读
    ElfBoard威廉希尔官方网站
贴|如何将libwebsockets库编译为x86<b class='flag-5'>架构</b>

    迅为RK3562核心板四核A53+MaliG52架构,应用于商业平板电脑,视频会议,智能家居,教育电子,医疗设备,边缘计算,工业应用

    迅为RK3562核心板四核A53+MaliG52架构,应用于商业平板电脑,视频会议,智能家居,教育电子,医疗设备,边缘计算,工业应用
    发表于 07-09 10:57

    I.MX6ULL-飞凌 ElfBoard ELF1板卡 - 如何在Ubuntu中编译OpenCV库(X86架构

    使用X86架构的OpenCV库,利用主机的强大计算性能和丰富的调试工具,可以加速开发进程并简化调试环节。下面就跟小伙伴详细讲述如何在Ubuntu环境下将 OpenCV 编译为 X86 架构。 开发环境
    发表于 06-07 09:32

    移动端芯片性能提升,Armv9架构新升级引发关注

    “数码博主”5月17日的最新爆料指出,联发科积极推进Armv9新一代IP BLACKHAWK“黑鹰”的架构设计,预计天玑9400芯片将采用这一架构,有望以“全大核”设计再度领跑移动SoC CPU性能榜单。
    的头像 发表于 05-17 16:51 1050次阅读

    鸿湖万联成功举办基于x86架构的OpenHarmony应用生态挑战赛

    近日,由开放原子开源基金会、央视网、江苏省工业和信息化厅、无锡市人民政府、江苏软件产业人才发展基金会、苏州工业园区、无锡高新区等共同承办,鸿湖万联参与共建的“基于x86架构的OpenHarmony应用生态挑战赛”决赛路演在无锡圆满落幕。
    的头像 发表于 04-23 09:26 362次阅读
    鸿湖万联成功举办基于x86<b class='flag-5'>架构</b>的OpenHarmony应用生态挑战赛

    福特野马旗舰性能版回归中国,搭载5.0L Coyote V8自然吸气引擎

    早在 2015 年,福特便推出了以前的野马系列,搭载 2.3L 涡轮增压四缸引擎和 5.0L V8 两大动力选择。但由于日益严格的排放限制,自 2020 年起,V8 车型在中国市场逐渐消失。
    的头像 发表于 02-19 15:38 551次阅读

    CMS-WRITER V8烧写器用户手册

    电子发烧友网站提供《CMS-WRITER V8烧写器用户手册.pdf》资料免费下载
    发表于 01-30 17:54 2次下载

    arm架构和x86架构区别 linux是x86还是arm

    ARM架构和x86架构是两种不同的计算机处理架构,它们在体系结构、指令集、应用领域等方面有着明显的区别。Linux操作系统则具有广泛的适配性,可以运行在各种
    的头像 发表于 01-30 13:46 1.9w次阅读

    【RISC-V开放架构设计之道|阅读体验】RV64的初体验和未来的展望

    来提供用户模式,来限制不可信代码的内存访问空间(u模式),因此在支持RV64架构处理器中会有一个物理内存保护的功能(Physical Memory Protection)。 这个功能也就是我们
    发表于 01-24 22:47

    基于FreeRTOS+LVGL V8智能家居仪表盘设计

    用野火启明6M5开发板制作了一个基于 FreeRTOS 和 LVGL V8 的智能家居仪表盘,颜值较高,也可以作为桌面摆件使用
    的头像 发表于 01-22 14:10 5118次阅读
    基于FreeRTOS+LVGL <b class='flag-5'>V8</b>智能家居仪表盘设计