《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相关的配置完成。

 

 

 

 

 

 

 

 

 

 

 

你可能感兴趣的:(《linux是这样“被”移植的》新书试读之U-Boot启动代码分析)