《linux是这样“被”移植的》新书试读之U-Boot启动代码分析

《linux是这样“被”移植的》新书试读之U-Boot启动代码分析

华清远见非著名讲师 O(_)O 牛牛猛

点击链接加我好友!

http://student.csdn.net/invite.php?u=111047&c=758a60d66d3a92d1

欢迎大家去我CSDN博客上踩踩

http://blog.csdn.net/mistyeyed

前几天写了关于CE的驱动分析,好像难了点,今天发个稍微简单的点的,就是传说中嵌入式Linux中常用的U-boot启动代码分析,这是我平时我讲课时的讲义,将要整理成书,这里先和大家分享一下,也许您的意见会体现在我的新书里哦!

分析cpu/arm920t/start.s文件

打开cpu/arm920t/start.s文件

s3c2440复位之后,pc指针会指向0x0地址。在u-boot代码中,该0x0地址是一个向量表,第一条指令跳转branch到复位代码start_code 位于cpu/arm920t/start.S汇编语言文件最开始的地方:

.globl _start /*定义一个全局变量,_start,也就是程序的入口点*/

_start: b start_code /*程序入口点是一条跳转指令,跳转到start_code 入口执行*/

/*定义中断向量表*/

ldr pc, _undefined_instruction

ldr pc, _software_interrupt

ldr pc, _prefetch_abort

ldr pc, _data_abort

ldr pc, _not_used

ldr pc, _irq

ldr pc, _fiq

按照上面定义的异常模式,当发生异常时,执行cpu/arm920t/interrupts.c中定义的中断处理函数。

复位指令跳转之后标号为start_code处开始执行,开始执行arm920t处理器的基本初始化。首先修改当前程序状态寄存器CPSR,使处理器进入Supervisor|32 bit ARM模式,

并关闭ARM9TDMI中断和快速中断,这是通过设置CPSR相应掩码实现的:

start_code: /* * set the cpu to SVC32 mode */

mrs r0,cpsr

bic r0,r0,#0x1f

orr r0,r0,#0xd3

msr cpsr,r0

紧接着,将S3C2410特有的WTCON寄存器清零,此举仅为关闭看门狗,因为系统启动时一般不需要看门狗的支持。

ldr r0, =pWTCON

mov r1, #0x0

str r1, [r0]

然后将S3C2410中断控制器INTMSK寄存器置为全1INTSUBMSK置为0x7ff,禁止全部中断源。S3C2410手册中对此有详细描述:

mov r1, #0xffffffff

ldr r0, =INTMSK

str r1, [r0]

# if defined(CONFIG_S3C2410) || defined(CONFIG_S3C2440) || defined(CONFIG_S3C2442) || / defined(CONFIG_S3C2443)

ldr r1, =INTSUBMSK_val

ldr r0, =INTSUBMSK

str r1, [r0]

# endif

接下来,访问arm920t控制寄存器CP15,并置位最高两位

31,30]。此两位置为0b11后,处理器时钟被设置为异步模式,

许处理器异步访问总线:

mrc p15, 0, r1, c1, c0, 0

orr r1, r1, #0xc0000000

mcr p15, 0, r1, c1, c0, 0

至此arm920t相关的配置完成。

你可能感兴趣的:(c,PHP,.net,linux,嵌入式)