Chinaunix首页 | 论坛 | 博客
  • 博客访问: 1706678
  • 博文数量: 98
  • 博客积分: 667
  • 博客等级: 上士
  • 技术积分: 1631
  • 用 户 组: 普通用户
  • 注册时间: 2009-04-27 15:59
个人简介

一沙一世界 一树一菩提

文章分类

全部博文(98)

文章存档

2021年(8)

2020年(16)

2019年(8)

2017年(1)

2016年(11)

2015年(17)

2014年(9)

2013年(4)

2012年(19)

2011年(1)

2009年(4)

分类: LINUX

2009-04-27 16:39:16

最近项目刚了结,是关于adi blackfin平台的,资料还没有整理好,由于比较着急,所以也没有时间写出来。这几天可以轻松点啦。所以把以前的arm板拿出来,琢磨琢磨。今天理解2440的启动部分了,有很多不解的地方。上网也查询了好多资料,还是很有收获的。主要来说说ARM BOOT的启动时候的关于中断向量的一点理解。
 
;=======================================================================================
;下面这个宏是用于第一次查表过程的实现中断向量的重定向,如果你比较细心的话就是发现
;在_ISR_STARTADDRESS=0x33FF_FF00里定义的第一级中断向量表是采用型如Handle***的方式的.
;而在程序的ENTRY处(程序开始处)采用的是b Handler***的方式.
;在这里Handler***就是通过HANDLER这个宏和Handle***进立联系的.
;这种方式的优点就是正真定义的向量数据在内存空间里,而不是在ENTRY处的ROM(FLASH)空间里,
;这样,我们就可以在程序里灵活的改动向量的数据了.
;========================================================================================

MACRO
$HandlerLabel HANDLER $HandleLabel

$HandlerLabel
sub sp,sp,#4 ;减少sp(用于存放转跳地址)
stmfd sp!,{r0} ;把工作寄存器压入栈(lr does not push because it return to original address)
ldr     r0,=$HandleLabel;将HandleXXX的址址放入r0
ldr     r0,[r0] ;把HandleXXX所指向的内容(也就是中断程序的入口)放入r0
str     r0,[sp,#4]      ;把中断服务程序(ISR)压入栈
ldmfd   sp!,{r0,pc}     ;用出栈的方式恢复r0的原值和为pc设定新值(也就完成了到ISR的转跳)
MEND 
 
===================================================================
 
b ResetHandler ;设成FALSE的话就来到这了,转跳到复位程序入口 
b HandlerUndef ;转跳到Undefined mode程序入口
b HandlerSWI ;转跳到SWI 中断程序入口
b HandlerPabort ;转跳到PAbort(指令异常)程序入口
b HandlerDabort ;转跳到DAbort(数据异常)程序入口
b . ;保留
b HandlerIRQ ;转跳到IRQ 中断程序入口
b HandlerFIQ ;转跳到FIQ 中断程序入口
=================================================================
 
 
HandleReset #   4
HandleUndef #   4
HandleSWI #   4
HandlePabort    #   4
HandleDabort    #   4
HandleReserved  #   4 

关于以上三部分,我是这样理解的,不知道是否正确,只是希望大家共同学习。
 
 b HandlerUndef  ,我认为类似B要跳转的这个函数是需要我们自己来写的。而我们要实现的中断函数的首地址放在哪呢?放在HandleUndef(注意没有“r”)定义的地方,一般在sdram的高地址。而执行 b HandlerUndef命令,就跳到我们定义的中断函数了。为什么呢?原因应该就是关于那个很烦人的宏定义。也就是以下这段:
 MACRO
$HandlerLabel HANDLER $HandleLabel

$HandlerLabel
sub sp,sp,#4 ;减少sp(用于存放转跳地址)
stmfd sp!,{r0} ;把工作寄存器压入栈(lr does not push because it return to original address)
ldr     r0,=$HandleLabel;将HandleXXX的址址放入r0
ldr     r0,[r0] ;把HandleXXX所指向的内容(也就是中断程序的入口)放入r0
str     r0,[sp,#4]      ;把中断服务程序(ISR)压入栈
ldmfd   sp!,{r0,pc}     ;用出栈的方式恢复r0的原值和为pc设定新值(也就完成了到ISR的转跳)
MEND 
 
具体怎么跳,我也说不清楚,但是就是找到函数了。
阅读(1559) | 评论(0) | 转发(0) |
0

上一篇:没有了

下一篇:CP15 与 MPLL的半点解释

给主人留下些什么吧!~~