Chinaunix首页 | 论坛 | 博客
  • 博客访问: 456986
  • 博文数量: 362
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 10
  • 用 户 组: 普通用户
  • 注册时间: 2015-07-26 17:08
文章分类

全部博文(362)

文章存档

2015年(362)

我的朋友

分类:

2015-12-10 23:51:44

for(i=_RAM_STARTADDRESS;i<(_RAM_STARTADDRESS+0x20);i+=4)
    {
 *((volatile unsigned *)i)=0xEA000000+0x1FFE;
    }
--  作者:sparkle_ke
--  时间:2005-12-29 14:23:29
--  
 for(i=_RAM_STARTADDRESS;i<(_RAM_STARTADDRESS+0x20);i+=4)
    {
 *((volatile unsigned *)i)=0xEA000000+0x1FFE;
    }
这部分还是不懂啊?能不能详细一点阿 ?
谢谢啦!
--  作者:hankuu
--  时间:2005-12-29 14:56:03
--  
跳转指令的格式为

31  282725 24 23                       0
 __________________________
|cond |101| L |Signed_immed_24|
|___  |___|_  |______________ |

其中cond为该条指令执行的条件码
    101 是25,26,27三位的固定值
    L   决定是非保存返回地址,以便返回使用
    signed_immed_24是跟跳转目标地址有关的值,呆会讲该值的计算方法


那么
0xEA000000+0x1FFE
就是一条跳转指令,它的条件码为1110,表示无条件跳转;L为0表示不保存返回值(因为这里修改的是异常处理入口,不用返回值);0x1FFE指定跳转目的地址。

下面我们看看signed_immed_24的计算方法:
1.将PC寄存器作为该条跳转指令的基地址;
2.用目标地址减去基地址,生成跳转偏移量(程序要保证该偏移量小于33554432);
3.将这个值的bit[25:2]填入signed_immed_24中。
因此0x1FFE的意义就是目标地址相对当前地址为 0x1FFE*4+8=0x8000

现在我们就明白了这段代码是将RAM开始的32个字节中填入了8个跳转指令,跳转的目标地址为当前指令地址+0x8000
如果你把你的程序加载到_RAM_STARTADDRESS+0x8000(在这块板子上就是0x0C008000),那么这几个异常中断都会跳转到你自己程序中的异常中断处理处,执行你自己的处理过程。
阅读(437) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~