#include "TimIRQn.h"
void Tim_Init(void){
LED_Init();
RCC->APB1ENR |= 1 << 3;//时钟使能
TIM5->PSC = 0x1C1F;//分频系数7199
TIM5->ARR = 0x1378;//计数重装载值为4999
TIM5->CR1 |= 1<<4;//向下计数模式
TIM5->CR1 |= 1<<7;//允许自动重装载
TIM5->CR1 |= 0x01;//使能定时器
TIM5->DIER |= 0x01;//使能更新中断
TIM5->EGR &= 0x01;
TIM3->EGR|=1<<0; //产生更新事件
TIM3->SR=0; //清所有标志
Register_NVIC_Init(0,0,0,TIM5_IRQn);
}
void Register_NVIC_Init(u8 NVIC_Group,u8 NVIC_PreemptionPriority,u8 NVIC_SubPriority,u8 NVIC_Channel)
{
u32 temp;
Register_NVIC_PriorityGroupConfig(NVIC_Group);
/*设置分组,具体操作看下面的分组设置函数*/
temp=NVIC_PreemptionPriority<<(4-NVIC_Group); //保存抢占优先级
temp|=NVIC_SubPriority&(0x0f>>NVIC_Group); //保存响应优先级
temp&=0xf; //取低四位
NVIC->ISER[NVIC_Channel/32]|=(1<<NVIC_Channel%32);//使能中断位(要清除的话,相反 操作就OK)
NVIC->IP[NVIC_Channel]|=temp<<4; //设置响应优先级和抢断优先级
}
void Register_NVIC_PriorityGroupConfig(u8 NVIC_Group)
{
u32 temp,Group_Set; /*temp是传递变量,Group_Set是分组设置的值*/
Group_Set=(~NVIC_Group)&0x07;//取后三位
Group_Set<<=8; /*Bits 10:8 PRIGROUP[2:0]*/
temp=SCB->AIRCR; //读取先前的设置
temp&=0X0000F8FF; //清空先前分组
temp|=0X05FA0000; //写入钥匙
temp|=Group_Set;
SCB->AIRCR=temp; //设置分组
}
void LED_Init(void){
RCC->APB2ENR|=1<<5;
GPIOD->CRL&=0XFFFFF0FF;
GPIOD->CRL|=0X00000300;
GPIOD->ODR|=1<<2;
LED1 = 0;
RCC->APB2ENR|=1<<2;
GPIOA->CRH&=0XFFFFFFF0;
GPIOA->CRH|=0X00000003;
GPIOA->ODR|=1<<8;
LED2 = 1;
}
void TIM5_IRQHandler(void)
{
//if(TIM5->SR&0X0001)
{
LED2=!LED2;
LED1=!LED1;
}
TIM5->SR&=~(1<<0);
}
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
UIF: 更新中断标记 (Update interrupt flag)
当产生更新事件时该位由硬件置’1’。它由软件清’0’。
0:无更新事件产生;
1:更新中断等待响应。当寄存器被更新时该位由硬件置’1’:
− 若TIMx_CR1寄存器的UDIS=0、 URS=0,当TIMx_EGR寄存器的UG=1时产生更新事件
(软件对计数器CNT重新初始化);
− 若TIMx_CR1寄存器的UDIS=0、 URS=0,当计数器CNT被触发事件重初始化时产生更新
事件。 (参考同步控制寄存器的说明)
一周热门 更多>