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的缩写,DCC是debugcommunicationschannel的缩写。要明白上面这段代码意思,需要深入查看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
通过上面的分析和学习,了解了ARM的CP14调试协处理器,知道调试输出为什么区分不同的宏输出,以及相关的意义。
//QQ:9073204 EMAIL:9073204@qq.com
//蔡军生 2012-1-8