S5PV210系列(裸机五)之关看门狗、设置栈、开iCache

来源:互联网 发布:淘宝会员有什么用 编辑:程序博客网 时间:2024/06/06 01:48

1、汇编写启动代码之关看门狗

1.1 什么是看门狗?

   看门狗(watch dog timer 看门狗定时器)。大家想象这样一个场景:家门口有一只狗,这个狗定时会饿(譬如说2小时一饿),够饿了会胡乱咬死人。人进进出出要想保证安全必须提前喂狗(必须在上次喂过后的2小时内喂狗才行)。如果超时没喂狗就会被咬死,如果提前喂狗没关系,但是本次喂狗时间就会从这里开始计算。   现实中因为一些外部因素,电子设备经常会跑飞或者死机(譬如极端炎热、极端寒冷、工业复杂场合)。在这种情况下我们希望设备自动复位而不需要人工干预(无人值守)。看门狗用来完成这个工作。看门狗其实是我们SoC内部的一个定时器(类似于闹钟,类似于门口的狗),定好时间之后看门狗定时器会去计时,时间到之前(狗饿了之前)必须去重新置位看门狗定时器(喂狗),如果没有喂狗则系统会被强制复位。   系统在正常工作时,系统软件会自己去喂狗,所以看门狗定时器不会复位。但是系统一旦故障跑飞啥的,看门狗就没人喂了,然后下一个周期就会自动复位,达到我们期望的效果。

1.2 为什么要关看门狗?

   一般CPU设计,在CPU启动后看门狗默认是工作的(为什么默认不关闭而要工作?我猜测是因为怕你的程序在启动代码前端就死机了或者跑飞了没人管),好处就是没有空当和漏洞,坏处就是在启动代码段我们不方便去喂狗(或者说懒得去喂狗)时看门狗会复位,所以为了偷懒我们就在启动代码前端先去关闭看门狗,然后在后面系统启动起来之后再根据需要决定是否要打开看门狗(一旦打开就必须同时提供喂狗)。    在S5PV210内部的iROM代码(BL0)中,其实已经关过看门狗了。所以我们的启动代码实际上是不用去关也没事的,也就是说今天写的关闭看门狗的代码运行后没有任何现象(没有现象就是正常现象)。很多CPU内部是没有BL0的,因此也没人给你关看门狗,都要在启动代码前段自己写代码关看门狗,所以今天学习的内容也是有价值的。

1.3 硬件物理特性

看门狗其实是个定时器(跟现实中的闹钟类似),硬件上就是SoC内部的一个内部外设。

1.4 数据手册

这里写图片描述

这里写图片描述

1.5 汇编代码

#define WTCON   0xE2700000    ldr r0, =WTCON    ldr r1, =0x0    str r1, [r0]

2、汇编写启动代码之设置栈

2.1 C语言运行时需要和栈的意义

  “C语言运行时(runtime)”需要一定的条件,这些条件由汇编来提供。C语言运行时主要是需要栈。  C语言与栈的关系:C语言中的局部变量都是用栈来实现的。如果我们汇编部分没有给C部分预先设置合理合法的栈地址,那么C代码中定义的局部变量就会落空,整个程序就死掉了。   我们平时在编写单片机程序(譬如51单片机)或者编写应用程序时并没有去设置栈,但是C程序还是可以运行的。原因是:在单片机中由硬件初始化时提供了一个默认可用的栈,在应用程序中我们编写的C程序其实并不是全部,编译器(gcc)在链接的时候会帮我们自动添加一个头,这个头就是一段引导我们的C程序能够执行的一段汇编实现的代码,这个代码中就帮我们的C程序设置了栈及其他的运行时需要。

2.2 CPU模式和各种模式下的栈

  在ARM中37个寄存器中,每种模式下都有自己的独立的SP寄存器(r13),为什么这么设计?  如果各种模式都使用同一个SP,那么就意味着整个程序(操作系统内核程序、用户自己编写的应用程序)都是用一个栈的。你的应用程序如果一旦出错(譬如栈溢出),就会连累操作系统的栈也损坏,整个操作系统的程序就会崩溃。这样的操作系统设计是非常脆弱的,不合理的。  解决方案就是各种模式下用不同的栈。我的操作系统内核使用自己的栈,每个应用程序也使用自己独立的栈,这样各是各的,一个损坏不会连累其他人。  我们现在要设置栈,不可能也懒的而且也没有必要去设置所有的栈,我们先要找到自己的模式,然后设置自己的模式下的栈到合理合法的位置,即可。  注意:系统在复位后默认是进入SVC模式的  我们如何访问SVC模式下的SP呢?很简单,先把模式设置为SVC,再直接操作SP。但是因为我们复位后就已经是SVC模式了,所以直接设置SP即可。

2.3 查阅文档并设置栈指针至合法位置

  在ARM中,ATPCS(ARM关于程序应该怎么实现的一个规范)要求使用满减栈,所以不出意外都是用满减栈  结合iROM_application_note中的memory map,可知SVC栈应该设置为0xd0037D80

2.4 数据手册

由图, SVC stack

这里写图片描述

2.5 汇编实现

#define SVC_STACK   0xd0037d80ldr sp, =SVC_STACK

3、汇编写启动代码之开iCache

3.1 iROM中BL0对cache的操作

  首先,icache的一切动作都是自动的,不需人为干预。我们所需要做的就是打开/关闭icache。  其次,在210的iROM中BL0已经打开了icache。所以之前看到的现象都是icache打开时的现象。

3.2 汇编代码读写cp15以开关icache

    mrc p15,0,r0,c1,c0,0;           // 读出cp15的c1到r0中    //bic r0, r0, #(1<<12)          // bit12 置0  关icache    orr r0, r0, #(1<<12)            // bit12 置1  开icache    mcr p15,0,r0,c1,c0,0;
阅读全文
2 0
原创粉丝点击