vxWorks中基于mips架构当中断了后执行的第一个指令是什么?

2024-05-13 04:38

本文主要是介绍vxWorks中基于mips架构当中断了后执行的第一个指令是什么?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在基于mips架构的vxworks中,中断来了之后执行的第一个指令再那里?

一,初始化

关于中断以及tlb异常函数存储再palDesc中,当然了其地址也再其中。

MIPS_PAL_DESC palDesc = { "unknown" };
相关的结构体设置:
typedef struct{char		*version;	/* PAL version string */int			coreNum;	/* processor number */MIPS_EXC_VECTOR	tVec;MIPS_EXC_VECTOR	xVec;MIPS_EXC_VECTOR	cVec;MIPS_EXC_VECTOR	eVec;MIPS_MMU_INFO	tlb;  MIPS_CACHE_INFO	iCache;MIPS_CACHE_INFO	dCache;MIPS_CACHE_INFO	l2Cache;MIPS_CACHE_INFO	l3Cache;int			mmuType;	/* CR bits 9:7 */BOOL		hasCP2;BOOL		hasWatch;BOOL		hasFPU;} MIPS_PAL_DESC;
typedef struct{VIRT_ADDR * vectorAddr;	/* typically [T,X,C,E]_Vec */VIRT_ADDR * excHandler;	/* typically exc[Tlb,Xtlb,Cache,Norm]Vec */UINT      excSize;		/* size of handler copied to vectorAddr */} MIPS_EXC_VECTOR;
其初始化的函数调用:
usrInit-->sysStart-->palInit-->palDescInit
写入的中断的向量的地址:
void palDescInit (void){bzero((char *)&palDesc, sizeof(palDesc));palDesc.coreNum = 0;palDesc.version = "1.0";/* executing a mapped kernel */palDesc.tVec.vectorAddr = (VIRT_ADDR *)T_VEC;palDesc.tVec.excHandler = (VIRT_ADDR *)mmuMipsTlbVec;palDesc.tVec.excSize    = mmuMipsTlbVecSize;palDesc.xVec.vectorAddr = (VIRT_ADDR *)X_VEC;palDesc.xVec.excHandler = (VIRT_ADDR *)mmuMipsXtlbVec;palDesc.xVec.excSize    = (UINT)mmuMipsXtlbVecSize;palDesc.cVec.vectorAddr = (VIRT_ADDR *)C_VEC;palDesc.cVec.excHandler = (VIRT_ADDR*)excCacheVec;palDesc.cVec.excSize    = (UINT)excCacheVecSize;palDesc.eVec.vectorAddr = (VIRT_ADDR *)E_VEC;palDesc.eVec.excHandler = (VIRT_ADDR *)excNormVmVec;palDesc.eVec.excSize    = (UINT)excNormVmVecSize;
}
#define	K0BASE		0x80000000
#define	T_VEC		K0BASE			/* tlbmiss vector */
#define	X_VEC		(K0BASE+0x80)		/* xtlbmiss vector */
#define	C_VEC		(K1BASE+0x100)		/* cache exception vector */
#define	E_VEC		(K0BASE+0x180)		/* exception vector */

二,把函数写入地址


把函数写入到对应地址的函数调用:

usrInit-->excVecinit-->vecInit
STATUS excVecInit(void)
{.../* Load tlb and Xtlb vectors */vecInit (&palDesc.tVec);vecInit (&palDesc.xVec);/* Load cache exception vector */vecInit (&palDesc.cVec);/* Load normal/interrupt vector */vecInit (&palDesc.eVec);...
}
/*把函数写入到对应的地址中去*/
LOCAL void vecInit(MIPS_EXC_VECTOR * vectorDesc){/* load the handler routine and invalidate the I-cache */if (vectorDesc->excSize){bcopy ((const char *) vectorDesc->excHandler,(char *) vectorDesc->vectorAddr, vectorDesc->excSize);CACHE_TEXT_UPDATE (vectorDesc->vectorAddr, vectorDesc->excSize);}}

也就是说当中断来了之后,cpu会自动调转到地址E_VEC(0X8000_0180),去执行E_VEC地址出存储的函数excNormVmVec,进行最初的中断分发。



这篇关于vxWorks中基于mips架构当中断了后执行的第一个指令是什么?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984699

相关文章

C# 预处理指令(# 指令)的具体使用

《C#预处理指令(#指令)的具体使用》本文主要介绍了C#预处理指令(#指令)的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学... 目录1、预处理指令的本质2、条件编译指令2.1 #define 和 #undef2.2 #if, #el

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点

CPython与PyPy解释器架构的性能测试结果对比

《CPython与PyPy解释器架构的性能测试结果对比》Python解释器的选择对应用程序性能有着决定性影响,CPython以其稳定性和丰富的生态系统著称;而PyPy作为基于JIT(即时编译)技术的替... 目录引言python解释器架构概述CPython架构解析PyPy架构解析架构对比可视化性能基准测试测

MySQL集群高可用架构的两种使用小结

《MySQL集群高可用架构的两种使用小结》本文介绍了MySQL的两种高可用解决方案:组复制(MGR)和MasterHighAvailability(MHA),文中通过示例代码介绍的非常详细,对大家的学... 目录一、mysql高可用之组复制(MGR)1.1 组复制核心特性与优势1.2 组复制架构原理1.3

MyBatis Plus中执行原生SQL语句方法常见方案

《MyBatisPlus中执行原生SQL语句方法常见方案》MyBatisPlus提供了多种执行原生SQL语句的方法,包括使用SqlRunner工具类、@Select注解和XML映射文件,每种方法都有... 目录 如何使用这些方法1. 使用 SqlRunner 工具类2. 使用 @Select 注解3. 使用

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

java中ssh2执行多条命令的四种方法

《java中ssh2执行多条命令的四种方法》本文主要介绍了java中ssh2执行多条命令的四种方法,包括分号分隔、管道分隔、EOF块、脚本调用,可确保环境配置生效,提升操作效率,具有一定的参考价值,感... 目录1 使用分号隔开2 使用管道符号隔开3 使用写EOF的方式4 使用脚本的方式大家平时有没有遇到自

Spring Boot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)

《SpringBoot分层架构详解之从Controller到Service再到Mapper的完整流程(用户管理系统为例)》本文将以一个实际案例(用户管理系统)为例,详细解析SpringBoot中Co... 目录引言:为什么学习Spring Boot分层架构?第一部分:Spring Boot的整体架构1.1

mybatis直接执行完整sql及踩坑解决

《mybatis直接执行完整sql及踩坑解决》MyBatis可通过select标签执行动态SQL,DQL用ListLinkedHashMap接收结果,DML用int处理,注意防御SQL注入,优先使用#... 目录myBATiFBNZQs直接执行完整sql及踩坑select语句采用count、insert、u

一个Java的main方法在JVM中的执行流程示例详解

《一个Java的main方法在JVM中的执行流程示例详解》main方法是Java程序的入口点,程序从这里开始执行,:本文主要介绍一个Java的main方法在JVM中执行流程的相关资料,文中通过代码... 目录第一阶段:加载 (Loading)第二阶段:链接 (Linking)第三阶段:初始化 (Initia