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

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 16
    评论
所有资料来源网上,与朋友分享 u-boot-1.1.6之cpu/arm920t/start.s分析 2 u-boot中.lds连接脚本文件的分析 12 分享一篇我总结的uboot学习笔记(转) 15 U-BOOT内存布局及启动过程浅析 22 u-boot中的命令实现 25 U-BOOT环境变量实现 28 1.相关文件 28 2.数据结构 28 3.ENV 的初始化 30 3.1env_init 30 3.2 env_relocate 30 3.3*env_relocate_spec 31 4. ENV 的保存 31 U-Boot环境变量 32 u-boot代码链接的问题 35 ldr和adr在使用标号表达式作为操作数的区别 40 start_armboot浅析 42 1.全局数据结构的初始化 42 2.调用通用初始化函数 43 3.初始化具体设备 44 4.初始化环境变量 44 5.进入主循环 44 u-boot编译过程 44 mkconfig文件的分析 47 从NAND闪存中启动U-BOOT的设计 50 引言 50 NAND闪存工作原理 51 从NAND闪存启动U-BOOT的设计思路 51 具体设计 51 支持NAND闪存的启动程序设计 51 支持U-BOOT命令设计 52 结语 53 参考文献 53 U-boot给kernel传参数和kernel读取参数—struct tag (以及补充) 53 1 、u-boot 给kernel 传RAM 参数 54 2 、Kernel 读取U-boot 传递的相关参数 56 3 、关于U-boot 中的bd 和gd 59 U-BOOT源码分析移植 60 一、u-boot工程的总体结构: 61 1、源代码组织 61 2.makefile简要分析 61 3、u-boot的通用目录是怎么做到与平台无关的? 63 4、smkd2410其余重要的文件 : 63 二、u-boot的流程、主要的数据结构、内存分配 64 1、u-boot启动流程: 64 2、u-boot主要的数据结构 66 3、u-boot重定位后的内存分布: 68 三、u-boot的重要细节 。 68 关于U-boot中命令相关的编程 : 73 四、U-boot在ST2410的移植,基于NOR FLASH和NAND FLASH启动。 76 1、从smdk2410到ST2410: 76 2、移植过程: 76 3、移植要考虑的问题: 77 4、SST39VF1601: 77 5、我实现的flash.c主要部分: 78 6、增加从Nand 启动代码 : 82 7、添加网络命令。 87

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值