Android培训班(89)内核解压过程2

接着下来这段代码,是跟调试有关的,如下:

/*

* Debugging stuff

*

* Note that these macros must notcontain any code which is not

* 100% relocatable. Any attemptto do so will result in a crash.

* Please select one of thefollowing when turning on debugging.

*/

这段注释意思是说下面的宏定义代码只能包括100%可重定位的代码,否则会导致运行崩溃的危险。如果要调试时,要选择合适的宏来使用。



#ifdefDEBUG

如果定义了宏变量DEBUG,就选择编译调试宏代码。


#ifdefined(CONFIG_DEBUG_ICEDCC)

如果定义使用CP14调试协处理器,就使用下面的宏定义。


#ifdefCONFIG_CPU_V6

.macro loadsp,rb

.endm

.macro writeb,ch, rb

mcr p14,0, \ch, c0, c5, 0

.endm

#else

.macro loadsp,rb

.endm

.macro writeb,ch, rb

mcr p14,0, \ch, c1, c0, 0

.endm

#endif

这段代码主要根据CONFIG_DEBUG_ICEDCC宏定义来处理,如果编译时定义了CONFIG_DEBUG_ICEDCC宏,那么就使用这些调试宏。这个宏CONFIG_DEBUG_ICEDCC是什么意思呢?从那里冒出来的呢?先从字面上解释一下,CONFIG是配置的意思,DEBUG是调试,ICEDCC是什么呢?ICE其实是isee you的缩写,DCCdebugcommunicationschannel的缩写。要明白上面这段代码意思,需要深入查看ARM公司的ARM9EJ-S的嵌入式调试文档,就可以看到与CP14调试通信通道协处理器相关内容。调试通信通道协处理DCC提供了两个32位寄存器用于传送数据,还提供了6位通信数据控制寄存器,其中两位用于目标和主机调试器之间进行同步握手作用。

其中使用指令:

MRC p14, 0,Rd, c0, c0

上面这条指令用来向调试处理器获取数据保存到Rd里。


MCR p14, 0,Rd, c1, c0

上面这条指令用来向调试处理器输出数据Rd

因此,上面的V6版本的CPU,就是采用下面的指令输出调试信息:

mcr p14, 0,\ch, c0, c5

而其它版本的CPU使用下面的指令输出:

mcr p14, 0,\ch, c1, c0


通过上面的分析和学习,了解了ARMCP14调试协处理器,知道调试输出为什么区分不同的宏输出,以及相关的意义。



//QQ:9073204 EMAIL:9073204@qq.com

//蔡军生  2012-1-8


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

caimouse

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值