SPCE061A使用时基,实现从8Hz到1024Hz的定时器

本文介绍了一个基于SPCE061A微控制器的定时中断程序实例,通过配置时间基准与时钟频率,实现了每秒中断一次的功能。该程序使用了C语言编写,并详细展示了如何设置中断控制寄存器及处理中断服务例程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

本文来自http://blog.youkuaiyun.com/hellogv/
#include "SPCE061A.H" unsigned int g_uiOutput=0,iii=0; void IRQ6(void) __attribute__ ((ISR)); void IRQ6(void) { if(*P_INT_Ctrl&C_IRQ6_TMB1)//C_IRQ6_TMB1对应于main()中的*P_INT_Ctrl_New|=XXXXXXX { if(g_uiOutput==64)//用于查看是否真的以秒为累加,64为频率数 { g_uiOutput=0; iii++; } g_uiOutput++; *P_Watchdog_Clear=0x0001; *P_INT_Clear=C_IRQ6_TMB1;//C_IRQ6_TMB1对应于main()中的*P_INT_Ctrl_New|=XXXXXXX } } main() { *P_SystemClock = 0x0080; //设置高的CPU主频,可以操作得更快 asm("INT OFF"); *P_TimeBase_Setup=C_TMB1_64Hz; //这里可以选择C_TMB1_8Hz、C_TMB1_16Hz、C_TMB1_32Hz、C_TMB1_64Hz //以及C_TMB2_128Hz、C_TMB2_256Hz、C_TMB2_512Hz、C_TMB2_1024Hz *P_INT_Ctrl_New|=C_IRQ6_TMB1;//这里对应于C_TMB2_XXXX用C_IRQ6_TMB1,C_TMB1_XXXX用C_IRQ6_TMB1 asm("INT IRQ"); while(1) { *P_Watchdog_Clear = C_WDTCLR; } }
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值