- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
WinCEWinCE1ARM9硬件接口学习之一 WatchDog Watchdog是整个ARM体系结构中相对比较简单的接口,控制代码只有几行,写起来比较容易。首先选择学习watchdog,可以快速入门,先对底层硬件工作原理有个初步的认识。(Watchdog即通常我们所说的“看门狗”)
?
Watchdog原理上就是一个定时器。定时器timer对时钟进行计数,当定时器溢出时,产生复位信号,使得整个系统复位。在程序或嵌入式系统中,需要定期的对看门狗timer进行复位重新计数,定时器不会溢出复位系统,从而保证系统的正常运行。当某种原因(例如干扰)引起程序跑飞或者进入死循环时,程序不能定期的复位看门狗timer,?计数溢出产生复位信号,导致系统复位。从上面的解释中可以看出,Watchdog的作用就是为了防止系统因意外“跑飞”,导致整个系统瘫痪时,恢复(reset)系统运行
?
下面认真分析一下Watchdog的Datasheet。这一步不可省,要想对硬件寄存器赋值,操作硬件工作,必须对硬件的datasheet及其工作原理相当熟悉,了解该硬件对应的每个寄存的作用以及每一位的含义,这样才能对其赋值。
?
这里简要的概括Watchdog的特性,详细的WatchDog及寄存器各位定义参考S3c2410 Datasheet的第18章WATCHDOG TIMER。
Watchdog Timer Block Diagram:
1.输入时钟为PCLK(该时钟频率等于系统的主频),它经过两级分频(Prescaler和frequency division factor),最后将分频后的时钟作为该定时器的输入时钟,当计数器期满后可以产生中断或者复位信号。
?
2.S3C2410的看门狗定时器有两个功能
1)作为常规定时器使用,并且可以产生中断
2)作为看门狗定时器使用,期满时,它可以产生128个时钟周期的复位信号
?
3.看门狗定时器计数值?????-----重要
1)输入到计数器的时钟周期
t_watchdog = 1/( PCLK / (Prescaler value + 1) / Division_factor )
预分频器Prescaler及分频因子Division factor的值由用户在WTCON(看门狗时钟控制寄存器)中设置。PCLK为系统运行频率,如200MHZ。
2)看门狗的定时周期
T = WTCNT * t_watchdog
WTCNT为看门狗数据寄存器,用来设置定时多少个时钟周期。乘以时钟周期就是定时的总长度了。
?
4.看门狗定时器寄存器
1)控制寄存器(WTCON)?????????设置预分频器及分频因子值等?----重要
2)数据寄存器(WTDAT)?????????若不设置WTCNT,会使用这里的初始值(0x8000)。
(注:这里我也不太确定,从datasheet上来看,好象是这个意思。但应该不影响使用。只要设置了WTCNT就行)
3)计数器寄存器(WTCNT)???????用来设置定时多少个时钟周期(t_watchdog)??----重要
总的定时长度即T = WTCNT * t_watchdog
?
要控制Watchdog工作,我们只需要向这三个寄存器赋相应的值,Watchdog会按这些寄存器配置的值进行工作。
?
注:详细的WatchDog寄存器各位定义参考S3c2410 Datasheet的第18章WATCHDOG TIMER。
?
5.下面我们分析一下这些寄存器:
1)控制寄存器(WTCON)
?
?
??? 这里比较重要的是Prescaler Value位和Clock Select位(即division factor),计算定时器时钟周期的公式里用到这两个值。
公式为:t_watchdog = 1/( PCLK / (Prescaler value + 1) / Division_factor )?。另外,因为我们没有进行任何系统时钟频率设定,即没有使用PLL。系统默认工作频率PCLK为12MHZ(时钟设置,以后实验会介绍)。通过这三个值的设定,我们可以计算出Watchdog的时钟周期。接着再在WTCNT寄存器中设置定时的时钟周期数,根据公式T = WTCNT * t_watchdog就可以计算出整个定时时间。
2)计数器寄存器(WTCNT)
用来设置定时多少个时钟周期(t_watchdog)
3)数据寄存器(WTDAT)
通常采用Reset value或和WTCNT值一样即可。
?
?
实例分析
1.实验目的:使用watchdog实现系统每隔2.66S左右就复位一次。
?
这里有必要先介绍一下ADS下ARM接口程序的结构。通常我们的接口程序代码结构如下:
包含head.s和main.c两个文件
he
原创力文档


文档评论(0)