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

    浏览量

    9842

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

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

收藏 人收藏

    评论

    相关推荐

    飞腾派开发板评测获奖名单公布!!!

    研发的一款面向行业工程师、学生和爱好者的开源硬件。主板处理器采用飞腾嵌入式四核处理器,兼容ARM V8架构,包含2个FTC664核和2个FTC310核,其中FTC664核主频可达1.8
    发表于 01-30 17:02

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

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

    【飞腾派4G版免费试用】大家来了解飞腾派4G版开发板

    国产高性能、低功耗通用计算微处理器的设计研发和产业化推广。飞腾派是一款面向行业工程师、学生和爱好者的开源硬件,采用飞腾嵌入式四核处理器,兼容ARM V8架构,板载64位 DDR4内存,
    发表于 01-02 22:43

    GD32能用DAP和JLINK V8下载仿真不?

    手上有上次使用STM32F103C8T6最小系统板做的DAP仿真器,也有几年前买的Jlink V8仿真器,不知道能不能开发GD32单片机?
    发表于 10-31 06:48

    【新品体验】飞腾派4G版基础套装免费试用

    飞腾派是由飞腾携手中电港萤火工场研发的一款面向行业工程师、学生和爱好者的开源硬件,采用飞腾嵌入式四核处理器,兼容ARM V8架构,板载64位 DDR4内存,分为2G和4G两个版本。主板板载WiFi
    发表于 10-25 11:44

    BM1684架构介绍

    一、概述 一图胜千言,先po一张架构图,如下所示: 二、TPU架构 2.1 DTCM DTCM是TPU内部的MCU ARM9的高速缓存空间(512KB),类似于CPU中的L1
    发表于 09-19 08:11

    ARM 1176JZ-S技术参考手册

    处理器使用Java扩展和TrustZone™安全扩展实现ARM架构V6。 该体系结构包括32位ARM指令集、16位Thumb指令集和8位Java指令集。 有关ARM和Thumb指令集的
    发表于 08-29 06:08

    将GICv2中断控制器与ARM Cortex-A5x和Cortex-A72处理器集成

    多达128个内核。 最多具有8个内核的Cortex-A5x和Cortex-A72系统可以在传统模式下配置,以支持实施GICv2架构规范的外部中断控制器。 在此功能模式下,禁用GICv3功能和接口
    发表于 08-23 07:21

    JLink V8仿真器能否用JLink的SWD来调试M051?

    手上有现成的JLink V8仿真器,能否用JLink的SWD来调试M051?求高手解答
    发表于 08-23 06:09

    Arm Cortex-R82处理器技术参考手册

    Cortex®-R82处理器是一款中等性能的多核有序超标量处理器,适用于实时嵌入式应用。 Cortex®-R82处理器采用ARM®V8-R AArch64
    发表于 08-17 07:45

    Arm CCA安全模型1.0架构与技术组

    --分配给领域的资源也受到保护,以防更高特权代理的访问。 这包括在更高异常级别上执行的软件或固件以及硬件代理,如DMA代理。
    发表于 08-11 07:39

    Armv8-R AArch32架构手册

    本体系结构参考手册描述的Arm体系结构定义了抽象机器,称为处理元件(PE)。符合Arm体系结构的实现必须符合所描述的PE行为。本手册没有描述如何构建实现 它也没有将这种实现的范围限制在定义的行为之外
    发表于 08-02 07:31

    ARMv8-M异常处理手册

    ARMv8-M异常模型描述了处理器如何响应异常与每个异常关联的属性,例如其优先级和异常返回行为。
    发表于 08-02 06:09

    JLINK V8不识别了

    我的JLINK v8不识别了,我网上搜解决办法。 先短接ERASE,后短接TST,都是照着网上说的干的。 安装了软件 我用第一个软件 选择AT91SAM7S64, 点击连接 提示ID不对。 我用
    发表于 05-29 09:39

    RISC-V异常处理机制复杂吗?

    RISC-V对于异常处理的实现复杂吗?应该没有ARM Cortex系列的那样复杂,有NVIC或GIC中断控制器吧。那么它执行异常处理的流程是
    发表于 04-21 15:00