合泰单片机之时基中断

时基中断(Time Base Interrupt)是一种基于硬件定时器的周期性中断机制,由特定定时器的溢出信号触发。在合泰单片机中,主要通过TB0和TB1两个定时器模块实现时基中断功能。

具体工作流程如下:

  1. 定时器溢出触发:

    • 当TB0/TB1定时器计数达到预设周期时,会产生溢出信号
    • 此时对应的中断请求标志位(TB0F或TB1F)被硬件自动置位
  2. 中断使能控制:

    • 总中断使能位EMI必须为1(使能状态)
    • 相应时基中断使能位(TB0E或TB1E)需设为1
    • 例如:设置TB0E=1允许TB0定时器中断
  3. 中断响应过程:

    • 满足上述条件时,CPU会暂停当前程序
    • 将程序计数器PC值压入堆栈
    • 跳转到对应的中断向量地址(如TB0中断向量地址为0x0008)
    • 执行中断服务子程序(ISR)
  4. 中断标志管理:

    • 进入ISR后,硬件自动清除TBnF标志
    • EMI位被清零,暂时禁止其他中断嵌套
    • 典型应用场景:需要周期性执行的任务(如LED闪烁、数据采样等)
  5. 中断返回:

    • ISR执行完毕后通过RETI指令返回
    • 恢复EMI位状态
    • 从堆栈恢复PC值继续主程序

注意:使用时基中断时需确保堆栈空间足够,避免堆栈溢出导致程序异常。

时基中断的目的时提供一个固定周期的中断信号。其时钟源来自内部时钟源fTB.fTB输入时钟首先经过分频器,分频率由程序设置TBC寄存器相关位获取合适的分频值以提供更长的时基中断周期。不同来源的时钟源fTB依次控制时基中断周期。

首先我们需要设置时基中断,通过上面示意图,我们需要进行以下几步:

  1. 选择时钟源
  2. 选择合适的分频器
  3. 编写中断处理函数
  4. 开启中断包括EMI、TBnE、TBON;

参考代码如下:

该功能主要实现了通过时基中断设置一个周期为1.024ms的中断,然后通过累加计数方式实现LED灯不断闪烁,周期为1.024s。

c 复制代码
#include "HT66F0185.h"



#define u8 unsigned char
#define u16 unsigned int

#define CLED _pa3

void delay_ms(u16 ms)
{
	while(ms--)
	{
		GCC_DELAY(2000);//编译器自带延时指定个周期,在主频8Mhz下,一个指令周期为0.5us	
		GCC_CLRWDT();
	}
}


void main()
{
	_wdtc=0xa8;//关闭看门狗
	_pac3=0;//设置为输出
	_cos=1;//设置pa3管脚为IO,而不是比较器输出

	_tbon = 1;	//enable TBC
	_tbck = 1;	//Ftb = Fsys/4

	_tb02 = 0;
	_tb01 = 1;
	_tb00 = 1;	//2^11/Ftb 2024/2000000 = 1.024ms
	
	_emi = 1;
	_tb0e = 1;
	

	while(1)
	{

	}
}


DEFINE_ISR(tb0,0x1c)
{
	static u16 ms = 0;
	if(++ms > 1000)
	{
		ms = 0;
		CLED = ~CLED;
	}
}
相关推荐
steins_甲乙2 小时前
stm32入门篇(6)
stm32·单片机·嵌入式硬件
刻BITTER11 小时前
用EXCEL 将单色屏幕的Bitmap 字模数据还原回图形
单片机·嵌入式硬件·excel·arduino
撬动未来的支点13 小时前
【嵌入式】MCU和MPU的区别
单片机·嵌入式硬件
一支闲人14 小时前
CAN:STM32 CAN外设2
stm32·单片机·基础知识·can协议·stm外设
雅欣鱼子酱15 小时前
两种电流检测电路设计方案 高侧,低侧,最高耐压90V
单片机·嵌入式硬件·芯片·电子元器件·电流检测芯片
平凡灵感码头15 小时前
经典按键扫描程序算法实现方式
单片机·矩阵·计算机外设
d111111111d16 小时前
STM32--SPI通讯外设-学习笔记
笔记·stm32·单片机·嵌入式硬件·学习
bai54593616 小时前
STM32旋转编码计次
stm32·单片机·嵌入式硬件
d111111111d16 小时前
在STM32中有参宏定义define该怎么使用
笔记·stm32·单片机·嵌入式硬件·学习
KWTXX16 小时前
STM32工作原理与数电模电的紧密联系【主要是介绍电路,模数电,想看STM32的工作原理可以不用看】
stm32·单片机·嵌入式硬件