【RH850U2A芯片】Reset Vector和Interrupt Vector介绍

本文详细探讨了S32K144和RH850芯片中ResetVector与InterruptVector的区别,强调了它们在系统启动过程中的作用,以及它们在ECU初始化中的重要性。作者指出,尽管两者在某些情况下基地址可能相同,但它们是独立的概念,用于不同的功能,如系统启动和中断处理。
摘要由CSDN通过智能技术生成

目录

前言

正文

1. 什么是Reset Vector

1.1 S32K144芯片的Reset Vector

1.2 RH850芯片的Reset Vector

2. 什么是Interrupt Vector

2.1 S32K144芯片的Interrupt Vector

2.2 RH850芯片的Interrupt Vector

3. Reset Vector等价于Interrupt Vector吗

4. 总结


前言

最近在研究符合AUTOSAR架构的OS(代码级别),系统在EcuM_Init调用OS标准接口StartOS之前还做了非常多的准备工作,感觉不把这些地方搞明白就去研究OS有点基础不牢呀,而且后面还发现OS在开始任务调度之前还完成了中断向量表(Interrupt Vector)的重映射,然后ECU第一次上电后还会有一个Reset Vector的概念,二者有什么联系了?本文讲基于NXP的S32K144芯片和Renesas的RH850-U2A芯片谈谈自己对Reset Vector和Interrupt Vector的理解。

ECU系统从上电到运行到main函数之前一般经历了初始化堆栈,初始化RAM,系统初始化等操作,具体可以参考:

S32K平台学习(1)-S32K144启动流程分析

本文参考文档:

1.RH850/U2A-EVA GroupUser’s Manual: Hardware

瑞萨电子 (Renesas Electronics Corporation)

2.Cortex-M4 Devices Generic User Guide

3.ARM Cortex-M4 Processor Technical reference manal

3.ARMv7-M Architecture

4.S32K1xx Series Reference Manual

正文

1. 什么是Reset Vector

Reset Vector也就是系统上电后存放第一个PC指针程序地址的存储空间的首地址值。

1.1 S32K144芯片的Reset Vector

S32K144芯片采用Cotex-M4内核,ARMV7架构,对于系统复位重启后上电的默认操作需要查看ARM相关的的手册,如下图所示:

R13是堆栈寄存器(stack Pointer),在Thread mode下,COTROL寄存器的bit[1]控制stack pointer作为Main Stack Pointer(MSP 这个是reset 值)还是Process Stack Pointer(PSP)

系统复位Reset后,处理器装载0x00000000地址处的四字节值到MSP寄存器。也就是说系统启动的时候,0地址处存放的是MSP寄存器的值。

R15是程序计数器(Program Counter PC)。存储当前程序地址。Reset重启的时候,处理器装载0x00000004地址处的值到PC指针,也就是装载Reset handler的地址到PC指针,PC指针跳转到Reset Handler标号/地址处开始执行Reset Hander标号下的操作

也就是说,对于S32K144芯片,Reset Vector也就是Reset Handler,也就是以0x0000_0004为首地址的四字节(.long)存储的Reset Handler标号的地址。

Reset Vector/Handler下的具体操作就是跳入到main函数之前的一些系统级操作,如初始化堆栈,初始化RAM,系统初始化等。具体参考前言部分关于S32K启动流程的参考文章。

1.2 RH850芯片的Reset Vector

RH850芯片采用瑞萨公司自定义的内核IP架构(不是ARM,PowerPc,X86等常见嵌入式芯片架构),有自己一套独立的指令集。

但是,关键核寄存器(SP,PC,LR等)和ARMV7架构的核寄存差不多。

RH850-U2A有四个核,每个核的Reset Vector地址可以通过Option Byte(RH850特有的配置字,可以配置系统时钟,Reset Vector地址等很多关键信息)配置,核0(PE0)和核1(PE1)的默认(default)Reset Vector地址是0x0000_0000(也就是说,系统上电后PC指针把0x0000_0000起始地址处存放的程序所在地址装载到PC指针),核2(PE2)和核3(PE3)的默认(default)Reset Vector地址是0x0080_0000(也就是说,系统上电后PC指针把0x0080_0000起始地址处存放的程序所在地址装载到PC指针)。

也就是说,对于RH850芯片,Reset Vector也就是以0x0000_0000/0x0080_0000为首地址的四字节(.long)存储的Reset Handler标号的地址。

2. 什么是Interrupt Vector

中断向量表就是一片地址空间,这段地址空间里面存放了系统所有的中断处理函数的入口地址,包括异常中断处理函数。通常我们在讲中断向量表的时候都是说中断向量表的入口地址。每个系统有自己的中断控制器及对应的中断控制寄存器,我们可以通过改变中断控制寄存器中保存的中断向量表的基地址来对中断向量表进行重映射(也就是在不同地地址空间存放中断向量表,然后在合适的时候把中断向量表地地址赋值给中断向量表寄存器)。

2.1 S32K144芯片的Interrupt Vector

S32K144芯片是ARM-Cotex M4内核,ARMV7架构的芯片,核寄存器VTOR(中断向量表寄存器)中存放的就算Interrupt Vector的起始地址。

也就是说,赋值给VTOR寄存器的地址就是Interrupt Vector的起始地址,在系统启动启动阶段我们把isr_vector的地址赋值给了VTOR寄存器,也就是说Interrupt Vector地起始地址就是isr_vector所在的地址。

2.2 RH850芯片的Interrupt Vector

RH850芯片有两个中断向量表基址寄存器,EBASE存放的是异常中断向量表基地址,INTBP存放的中断向量表的基地址。

也就是说,对于RH850芯片有两个中断向量表寄存器,EBASE存放的是异常中断向量表的基地址,INTBP存放的是正常中断向量表的基地址。

3. Reset Vector等价于Interrupt Vector吗

以RH850芯片为例,PE0的Reset Vector的基地址是0x0000_0000,如果我们赋值0x0000_0000给EBASE,这个时候Exception Handler地基地址从0x0000_00010开始,这个时候我们可以理解为Reset Vector的基地址值等于Exception Interrupt Vector基地址值。

但是如果我们重映射EBASE = 0x0000_0100,这个时候Reset Vector的基地址值不等于Exception Interrupt Vector基地址值。

也就是说,Reset Vector和Interrupt Vector是两个概念,二者的值可能相同

4. 总结

1. Reset Vector和Interrupt Vector是两个概念,二者的基地址的值可能相同。

2. S32K144的Reset Vector的地址是0x0000_0004,RH850-U2A PE0的Default Reset Vector是0x0000_0000。

3. 中断向量表控制寄存器中存储的值就说中断向量表的基地址,我们在系统开发的不同阶段(BootLoader和APP)会对其进行重映射,也就是BooLoader和APP中中断向量表的基地址是不一样。

4. 异常中断处理函数需要明确定义好,防止系统产生异常中断后找不到异常中断处理函数程序跑飞。

RH850芯片的IO口中断是指当IO口状态变化时,CPU能够及时响应和处理这一变化的功能。IO口中断可以用于很多场合,比如检测按键的按下和松开,检测传感器的信号等。 RH850芯片的IO口中断代码需要先定义相关的寄存器地址和对应的位,然后再编写中断服务函数。具体步骤如下: 1.定义寄存器地址和对应的位:RH850芯片的IO口中断需要操作的寄存器包括IO口方向寄存器(IODIR)、IO口状态寄存器(IOSTAT)和IO口中断使能寄存器(IOINTEN)。其中,IODIR寄存器用于控制IO口是输入还是输出,IOSTAT寄存器用于读取IO口的状态,IOINTEN寄存器用于使能IO口中断。定义寄存器地址和对应的位很重要,否则无法正确操作IO口。 2.编写中断服务函数:RH850芯片的IO口中断服务函数包括中断处理函数和中断服务函数。中断处理函数需要在设置中断向量表时设定,中断服务函数通常由中断向量表自动调用。中断服务函数的主要功能是读取IO口状态并进行相应的处理,例如响应按键按下或松开的事件。 3.配置NVIC:在RH850芯片中,中断向量表需要通过NVIC(Nested Vectored Interrupt Controller)来配置。因此,在编写IO口中断代码时,还需要配置NVIC。配置NVIC可以使CPU能够准确地识别和响应IO口的中断。 综上所述,RH850芯片的IO口中断代码需要涉及寄存器地址、中断服务函数和NVIC的配置。这些功能都需要深入了解硬件和软件,才能编写出正确、高效的代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

汽车电子嵌入式

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值