s3c44b0x的启动代码分析.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
这两天把 S3C44B0X 的 bootloader 通读了 一遍,也在网上查了很多资料,其中有几段看得 人吐血。把我理解到的注释一遍,望高手指点, 酱油党的帮顶!! 先来个 bootloader 扫盲吧。传说中的 bootloader 就是在我们 程序运行前要运行的一段程序呀, 或者说系统上电后最先执行的一段 程序。首先它用来初始化软硬件 ( 存储器,堆栈, I/O, 定时器 ) , 反正就是为程序运行建立合适的环境吧。接下来 bootloader 把我们 的系统内核 (image) 加载到内存中,然后把控制权交给 image, 这样 image 就可以运行了。 PC机的启动也可以这样解释, 但是它还多了个 BIOS在前面。 BIOS主要完成硬件检测与资源分配,过后他就会把控 制权交给我们操作系统的 bootloader 了,bootloader 过后我们的系 统就启动了。 要知道,根据具体 CPU体系结构和硬件设备来编写自己的 bootloader 可以达到高效节省存储空间的目的。但是也有些功能很 强大的 bootloader 它们可以支持很多的体系结构。 比如 U-Boot 就很 强大,它支持 ARM,powerPC,还有 x86, 所以在我们的 PC机启动的时 候经常会看到 U-Boot.. 了。另一个比较常用的 bootloader 就是 GRUB, 可以用来引导 LINUX哈。 1 / 24 下载文档可编辑 当然,我们可以在 ARM上移植 U-Boot, 但是如果不在 ARM板上 跑系统的话,完全可以自己编写一个短小精悍的 bootloader 。我买 的 S3C44B0X的一块板子,里面的许多实验程序就是用它自己定义的 一个 bootloader ,这段 bootloader 全部用汇编写成,所以执行效率 还是很高的。 好了,步入正题。 这个简单的 bootloader 主要包含两个汇编文 件 Vecter.s 和 Sysinit.s 。先来看看 Vecter.s 。。。 开始 ( 对 ARM汇编还不太熟啊,要多写些关于这方面的东东 ) : ModeMask EQU 0x1F;EQU,这么弱智的就不说了, x86 里面 也有,这个 ModeMask是什么呢 ?我们可以把它看做一个掩码, ARM体 系有个 32 位程序状态寄存器 CPSR(x86中叫 PSW啦!) ,其中 CPSR[4..0] 这五位叫模式位,这些位记录了处理器的工作模式 , 在不同模式下资 源的访问权限是有差别的。具体有 : 管理模式 (10011), IRQ 模式 (10010),FIQ 模式 (10001), 用户模式 (10000), 终止模式 (10111), 未定 义模式 (10111), 系统模式 (11111) 七种。所以 ModeMask也可以看成是 系统模式时 CPSR[4..0] 的值啦。同时可以把 ModeMask各

文档评论(0)

二哥 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档