- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
6.Realview MDK中编译器对中断处理的过程详解.pdf
RealviewMDK中编译器对中断处理的过程详解
在ARM程序的开发过程中,对中断的处理是很普遍的、也是相当重要的。RealviewMDK使用的
RVCT编译器提供了__irq关键字,用此关键字修饰的函数被作为中断出来函数编译,即在编译的过程
中,编译器会自动添加中断处理过程中现场保护和恢复的代码,减小程序的开发难度,加快软件的开发
过程。
在理解__irq 关键字的作用之前,先看一下ARM核对异常的处理过程。当产生异常时,ARM核拷
贝CPSR寄存器的内容SPSR_mode寄存器中,同时设置适当的CPSR 位、改变处理器状态进入ARM
态和处理器模式,从而进入相应的异常模式。在设置中断禁止位禁止相应中断(如果需要)后,ARM核
保存返回地址到 LR_mode,同时设置PC 为相应的异常向量。当异常返回时, 异常处理需要从
SPSR_mode寄存器中恢复CPSR的值,同时从LR_mode恢复PC,具体的异常返回指令如下:
� 从SWI和Undef异常返回时使用:
movs pc, LR
movs pc, LR
mmoovvssppcc,,LLRR;
� 从FIQ、IRQ和预取终止返回时使用:
SUBSPC, LR #4
SUBSPC, LR #4
SSUUBBSSPPCC,,LLRR,##44;
� 从数据异常返回时使用:
SUBSPC, LR #8
SUBSPC, LR #8
SSUUBBSSPPCC,,LLRR,##88
∧
在使用上述指令异常返回时,如果LR之前被压栈的话使用LDM“ ”, 例如:
LDMFDSP!, {PC}∧
LDMFDSP!, {PC}
LLDDMMFFDDSSPP!!,,{{PPCC}}
理解了ARM异常处理的过程以后,RealviewMDK中__irq关键字的作用就容易理解了。下面的函
数为一个中断处理函数,其前面加了__irq关键字。
__irq void pwm0_irq_handler(void)
{
//Deassert PWM0 interrupt signal
unsigned int i=AT91F_PWMC_GetInterruptStatus(AT91C_BASE_PWMC);
// Clear the LEDs. On the Board we must apply a 1 to turn off LEDs
AT91F_PIO_SetOutput(AT91C_BASE_PIOA, led_mask[0]);
AT91F_PWMC_StopChannel(AT91C_BASE_PWMC,AT91C_PWMC_CHID1);
AT91F_AIC_ClearIt(AT91C_BASE_AIC,AT91C_ID_PWMC);
AT91F_AIC_AcknowledgeIt(AT91C_BASE_AIC);
}
当编译器器编译这个函数时,除了保存ATPCS规则规定的寄存器以外,还保存了CPSR及PC的值。
在函数的返回时,还自动添加了SUBSPC,LR,#4和从SPSR寄存器恢复CPSR寄存器值的指令。用这
种方式处理以后,中断处理函数可以和普通函数一样的使用。
注意:中断处理都是在ARM模式下进行的,当源程序欲编译成Thumb指令时,这时,用__irq关
键字修饰的函数仍然会被编译成ARM指令。如果源程序编译成在CORTEXM3上运行的指令时,关键
字__irq对函数的编译没有任何影响,即编译器不会自动保存CPSR及PC的值,也不会添加SUBSPC,LR,
#4和从SPSR寄存器恢复CPSR寄存器值的指令,因为CORTEXM3处理器硬件会自动处理这些问题,
无需软件开发人员关心。
- 1 -
您可能关注的文档
- 5549.职业技术教育结合竞赛课程改革新规划教材·数控技术应用专业MasterCAM编程与加工项目教程.pdf
- 555 定时器是一种模拟和数字功能相结合的中规模集成器件.doc
- 5568.21世纪高等学校规划教材·数据库技术与应用面向业务分析的Access 2003.pdf
- 5575.网络用户行为的安全可信分析与控制.pdf
- 55°非密封管螺纹的基本尺寸及其公差.doc
- 55×3000卷板机的改造.pdf
- 55【工程实验室】【利用IP标准ACL进行网络流量的控制】.pdf
- 55三类股民应该学习的技术指标(下).doc
- 5632.大学计算机基础上机实验指导与习题解答.pdf
- 5639.单片机C51技术应用.pdf
最近下载
- GST-XG9000A消防应急广播设备调试使用说明书A.doc VIP
- 访谈美国医学生.doc VIP
- 13美丽中国我们的家第2课时 课件 2025道德与法治二年级上册.ppt
- 新疆天山群吉萨依铜多金属矿床地质特征及成因.docx VIP
- 8.6《数学锯木头+爬楼梯问题》三年级上册.doc VIP
- 22g101-3独立基础、条形基础、筏板基础、桩基础.pptx VIP
- 消防鉴定考试承诺书下载.docx VIP
- 2025年06月英语四级真题及答案(共三套).pdf VIP
- 八年级上册数学-全册全套试卷易错题(Word版-含答案).doc VIP
- 广东省深圳市宝安区2024-2025学年三年级上学期Units1-4学业中段复习.docx VIP
原创力文档


文档评论(0)