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

相关文章

mybatis的整体架构

mybatis的整体架构分为三层: 1.基础支持层 该层包括:数据源模块、事务管理模块、缓存模块、Binding模块、反射模块、类型转换模块、日志模块、资源加载模块、解析器模块 2.核心处理层 该层包括:配置解析、参数映射、SQL解析、SQL执行、结果集映射、插件 3.接口层 该层包括:SqlSession 基础支持层 该层保护mybatis的基础模块,它们为核心处理层提供了良好的支撑。

百度/小米/滴滴/京东,中台架构比较

小米中台建设实践 01 小米的三大中台建设:业务+数据+技术 业务中台--从业务说起 在中台建设中,需要规范化的服务接口、一致整合化的数据、容器化的技术组件以及弹性的基础设施。并结合业务情况,判定是否真的需要中台。 小米参考了业界优秀的案例包括移动中台、数据中台、业务中台、技术中台等,再结合其业务发展历程及业务现状,整理了中台架构的核心方法论,一是企业如何共享服务,二是如何为业务提供便利。

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

第10章 中断和动态时钟显示

第10章 中断和动态时钟显示 从本章开始,按照书籍的划分,第10章开始就进入保护模式(Protected Mode)部分了,感觉从这里开始难度突然就增加了。 书中介绍了为什么有中断(Interrupt)的设计,中断的几种方式:外部硬件中断、内部中断和软中断。通过中断做了一个会走的时钟和屏幕上输入字符的程序。 我自己理解中断的一些作用: 为了更好的利用处理器的性能。协同快速和慢速设备一起工作

maven 编译构建可以执行的jar包

💝💝💝欢迎莅临我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」👈,「stormsha的知识库」👈持续学习,不断总结,共同进步,为了踏实,做好当下事儿~ 专栏导航 Python系列: Python面试题合集,剑指大厂Git系列: Git操作技巧GO

系统架构设计师: 信息安全技术

简简单单 Online zuozuo: 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo 简简单单 Online zuozuo :本心、输入输出、结果 简简单单 Online zuozuo : 文章目录 系统架构设计师: 信息安全技术前言信息安全的基本要素:信息安全的范围:安全措施的目标:访问控制技术要素:访问控制包括:等保

工作常用指令与快捷键

Git提交代码 git fetch  git add .  git commit -m “desc”  git pull  git push Git查看当前分支 git symbolic-ref --short -q HEAD Git创建新的分支并切换 git checkout -b XXXXXXXXXXXXXX git push origin XXXXXXXXXXXXXX

利用命令模式构建高效的手游后端架构

在现代手游开发中,后端架构的设计对于支持高并发、快速迭代和复杂游戏逻辑至关重要。命令模式作为一种行为设计模式,可以有效地解耦请求的发起者与接收者,提升系统的可维护性和扩展性。本文将深入探讨如何利用命令模式构建一个强大且灵活的手游后端架构。 1. 命令模式的概念与优势 命令模式通过将请求封装为对象,使得请求的发起者和接收者之间的耦合度降低。这种模式的主要优势包括: 解耦请求发起者与处理者

jenkins 插件执行shell命令时,提示“Command not found”处理方法

首先提示找不到“Command not found,可能我们第一反应是查看目标机器是否已支持该命令,不过如果相信能找到这里来的朋友估计遇到的跟我一样,其实目标机器是没有问题的通过一些远程工具执行shell命令是可以执行。奇怪的就是通过jenkinsSSH插件无法执行,经一番折腾各种搜索发现是jenkins没有加载/etc/profile导致。 【解决办法】: 需要在jenkins调用shell脚