C8051关闭看门狗汇编语言,请教关于C8051F单片机看门狗程序问题

本文主要是介绍C8051关闭看门狗汇编语言,请教关于C8051F单片机看门狗程序问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看门狗程序,网上找了一个,看不懂,也不知道哪句有用,求大神帮忙分析,小弟不胜感激!

//-----------------------------------------------------------------------------

// F41x_Watchdog.c

//-----------------------------------------------------------------------------

// Copyright 2006 Silicon Laboratories, Inc.

// http://www.silabs.com

//

// Program Description:

//

// This program helps the user to learn about operating the Watch Dog Timer.

// The WDT is used to generate resets if the times between writes to the WDT

// update register (PCA0CPH5) exceed a specified limit. The WDT can be disabLED

// and enabled in the software as needed. When enabled the PCA Module 5 acts as

// the WDT. This program resets the MCU when P1.4 switch is pressed for 3

// seconds.  Also upon reset the LED blinks approximately five times faster

// when compared to before. The reset is caused due to a WDT oveRFlow and can

// be confirmed by checking the value of the RSTSRC register where bit 3 is

// set to indicate a reset caused by WDT.

//

// How to Test:

// 1) Compile and download code to a 'F410 device

// 2) Place shorting blocks on P2.1/D3 and P1.4/SW2 pin pairs on jumper J5.

// 3) Run the code:

//        - The test will blink the LED at a rate of 8Hz until the switch SW2

//          (P0.7) is pressed for at least 3 secs.

//        - Once the the switch is pressed and held for a long enough time,

//          it will prevent the WDT from being touched and the WDT will

//          cause a reset.

//        - Upon reset the code checks for a WDT reset and blinks the LED five

//          times faster than before to indicate the same.

//

//

// FID:            41X000031

// Target:         c8051f410

// Tool chain:     Keil C51 7.50 / Keil EVAL C51

// Command Line:   None

//

// Release 1.0

//    -Initial Revision SM

//    -20 JULY 2006

//-----------------------------------------------------------------------------

// Includes

//-----------------------------------------------------------------------------

#include                  // SFR declarations

//-----------------------------------------------------------------------------

// 16-bit SFR Definitions for 'F41x

//-----------------------------------------------------------------------------

sfr16 TMR2RL   = 0xca;                 // Timer2 reload value

sfr16 TMR2     = 0xcc;                 // Timer2 counter

//-----------------------------------------------------------------------------

// Global CONSTANTS

//-----------------------------------------------------------------------------

#define SYSCLK       24500000 / 8      // SYSCLK frequency in Hz

sbit LED = P2^1;                       // LED='1' means ON

sbit SW2 = P1^4;                       // SW2='0' means switch pressed

//-----------------------------------------------------------------------------

// Function PROTOTYPES

//-----------------------------------------------------------------------------

void OSCILLATOR_Init (void);

void PORT_Init (void);

void PCA_Init (void);

void Timer2_Init (int counts);

void Timer2_ISR (void);

//-----------------------------------------------------------------------------

// main() Routine

//-----------------------------------------------------------------------------

//

// The MAIN routine performs all the intialization, and then loops until the

// switch is pressed. When SW2 (P1.4) is pressed the code checks the RSTSRC

// register to make sure if the last reset is because of WDT.

//-----------------------------------------------------------------------------

void main (void)

{

PCA0MD &= ~0x40;                    // WDTE = 0 (clear watchdog timer

// enable)

OSCILLATOR_Init ();                 // Initialize system clock to 24.5/8 MHz

PCA_Init();                         // Intialize the PCA

PORT_Init();                        // Initialize crossbar and GPIO

if ((RSTSRC & 0x02) == 0x00)        // First check the PORSF bit. if PORSF

{                                   // is set, all other RSTSRC flags are

// invalid

// Check if the last reset was due to the Watch Dog Timer

if (RSTSRC == 0x08)

{

// Make LED blink at 12Hz

Timer2_Init (SYSCLK / 12 / 6);

// Enable global interrupts

EA = 1;

while(1);                   // wait forever

}

else

{

// Init Timer2 to generate interrupts at a 4Hz rate.

Timer2_Init (SYSCLK / 12 / 4);

}

}

// Calculate Watchdog Timer Timeout

// Offset calculated in PCA clocks

// Offset = ( 256 x PCA0CPL5 ) + 256 - PCA0L

//        = ( 256 x 255(0xFF)) + 256 - 0

// Time   = Offset * (12/SYSCLK)

//        = ~255 ms ( PCA uses SYSCLK/12 as its clock source)

PCA0MD  &= ~0x40;                   // WDTE = 0 (clear watchdog timer

// enable)

PCA0L    = 0x00;                    // Set lower byte of PCA counter to 0

PCA0H    = 0x00;                    // Set higher byte of PCA counter to 0

PCA0CPL5 = 0xFF;                    // Write offset for the WDT

PCA0MD  |= 0x40;                    // Enable the WDT

EA = 1;                             // Enable global interrupts

//--------------------------------------------------------------------------

// Main Application Loop/Task Scheduler

//--------------------------------------------------------------------------

while (1)

{

//----------------------------------------------------------------------

// Task #1 - Check Port I/O

//----------------------------------------------------------------------

while(!SW2);                     // Force the MCU to stay in this task as

// long as SW2 is pressed. This task

// must finish before the watchdog timer

// timeout expires.

//-----------------------------------------------------------------------

// Task #2 - Reset Watchdog Timer

//-----------------------------------------------------------------------

PCA0CPH5 = 0x00;                 // Write a 'dummy' value to the PCA0CPH5

// register to reset the watchdog timer

// timeout. If a delay longer than the

// watchdog timer delay occurs between

// successive writes to this register,

// the device will be reset by the watch

// dog timer.

}

}

//-----------------------------------------------------------------------------

// Initialization Subroutines

//-----------------------------------------------------------------------------

//-----------------------------------------------------------------------------

// OSCILLATOR_Init

//-----------------------------------------------------------------------------

// Return Value : None

// Parameters   : None

// This routine initializes the system clock to use the internal 24.5MHz / 8

// oscillator as its clock source.  Also enables missing clock detector reset.

//-----------------------------------------------------------------------------

void OSCILLATOR_Init (void)

{

OSCICN = 0x84;                      // Configure internal oscillator

RSTSRC = 0x04;                      // Enable missing clock detector

}

//-----------------------------------------------------------------------------

// PCA_Init

//-----------------------------------------------------------------------------

// Return Value : None

// Parameters   : None

// This routine initializes the PCA to use the SYSCLK / 12

// as its clock source.  It also sets the offset value by writing to PCA0CPL2.

//-----------------------------------------------------------------------------

void PCA_Init()

{

PCA0CN     =  0x40;                        // PCA counter enable

PCA0MD    &= ~0x40 ;                       // Watchdog timer disabled-clearing bit 6

PCA0MD    &=  0xF1;                        // Timebase selected - System clock / 12

PCA0CPL5   =  0xFF;                        // Offset value

}

//-----------------------------------------------------------------------------

// PORT_Init

//-----------------------------------------------------------------------------

// Return Value : None

// Parameters   : None

//

// This function configures the Crossbar and GPIO ports.

// P2.1   digital   push-pull     LED

//-----------------------------------------------------------------------------

void PORT_Init (void)

{

XBR0     = 0x00;                    // No digital peripherals selected

XBR1     = 0x40;                    // Enable crossbar and weak pull-ups

P2MDOUT |= 0x02;                    // Enable LED as a push-pull output

}

//-----------------------------------------------------------------------------

// Timer2_Init

//-----------------------------------------------------------------------------

// Return Value : None

// Parameters   :

//   1)  int counts - calculated Timer overflow rate

//                    range is positive range of integer: 0 to 32767

//

// Configure Timer2 to 16-bit auto-reload and generate an interrupt at

// interval specified by using SYSCLK/48 as its time base.

//-----------------------------------------------------------------------------

void Timer2_Init (int counts)

{

TMR2CN  = 0x00;                     // Stop Timer2; Clear TF2;

// use SYSCLK/12 as timebase

CKCON   = 0x30;                     // Timer2 clocked based on SYSCLK

TMR2RL  = -counts;                  // Init reload values

TMR2    = 0xffff;                   // Set to reload immediately

ET2     = 1;                        // Enable Timer2 interrupts

TR2     = 1;                        // Start Timer2

}

//-----------------------------------------------------------------------------

// Interrupt Service Routines

//-----------------------------------------------------------------------------

//-----------------------------------------------------------------------------

// Timer2_ISR

//-----------------------------------------------------------------------------

// This routine changes the state of the LED whenever Timer2 overflows.

//-----------------------------------------------------------------------------

void Timer2_ISR (void) interrupt 5

{

TF2H = 0;                           // Clear Timer2 interrupt flag

LED = ~LED;                         // Change state of LED

}

//-----------------------------------------------------------------------------

// End Of File

//-----------------------------------------------------------------------------

699ba7046c51816a17b33a7caa85f179.png

1

97b4b3417991aabde46fdac613e34292.png

已退回1积分

这篇关于C8051关闭看门狗汇编语言,请教关于C8051F单片机看门狗程序问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/546375

相关文章

怎样通过分析GC日志来定位Java进程的内存问题

《怎样通过分析GC日志来定位Java进程的内存问题》:本文主要介绍怎样通过分析GC日志来定位Java进程的内存问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、GC 日志基础配置1. 启用详细 GC 日志2. 不同收集器的日志格式二、关键指标与分析维度1.

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

Redis出现中文乱码的问题及解决

《Redis出现中文乱码的问题及解决》:本文主要介绍Redis出现中文乱码的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 问题的产生2China编程. 问题的解决redihttp://www.chinasem.cns数据进制问题的解决中文乱码问题解决总结

全面解析MySQL索引长度限制问题与解决方案

《全面解析MySQL索引长度限制问题与解决方案》MySQL对索引长度设限是为了保持高效的数据检索性能,这个限制不是MySQL的缺陷,而是数据库设计中的权衡结果,下面我们就来看看如何解决这一问题吧... 目录引言:为什么会有索引键长度问题?一、问题根源深度解析mysql索引长度限制原理实际场景示例二、五大解决

Springboot如何正确使用AOP问题

《Springboot如何正确使用AOP问题》:本文主要介绍Springboot如何正确使用AOP问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录​一、AOP概念二、切点表达式​execution表达式案例三、AOP通知四、springboot中使用AOP导出

Python中Tensorflow无法调用GPU问题的解决方法

《Python中Tensorflow无法调用GPU问题的解决方法》文章详解如何解决TensorFlow在Windows无法识别GPU的问题,需降级至2.10版本,安装匹配CUDA11.2和cuDNN... 当用以下代码查看GPU数量时,gpuspython返回的是一个空列表,说明tensorflow没有找到

解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题

《解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘问题》:本文主要介绍解决未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4... 目录未解析的依赖项:‘net.sf.json-lib:json-lib:jar:2.4‘打开pom.XM

IDEA Maven提示:未解析的依赖项的问题及解决

《IDEAMaven提示:未解析的依赖项的问题及解决》:本文主要介绍IDEAMaven提示:未解析的依赖项的问题及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录IDEA Maven提示:未解析的依编程赖项例如总结IDEA Maven提示:未解析的依赖项例如

Redis分片集群、数据读写规则问题小结

《Redis分片集群、数据读写规则问题小结》本文介绍了Redis分片集群的原理,通过数据分片和哈希槽机制解决单机内存限制与写瓶颈问题,实现分布式存储和高并发处理,但存在通信开销大、维护复杂及对事务支持... 目录一、分片集群解android决的问题二、分片集群图解 分片集群特征如何解决的上述问题?(与哨兵模

SpringBoot+Redis防止接口重复提交问题

《SpringBoot+Redis防止接口重复提交问题》:本文主要介绍SpringBoot+Redis防止接口重复提交问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不... 目录前言实现思路代码示例测试总结前言在项目的使用使用过程中,经常会出现某些操作在短时间内频繁提交。例