关于定时器标志位的问题,新手求助

2019-08-14 17:01发布

#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);
}


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
26条回答
爱学习的猫
1楼-- · 2019-08-15 21:33
顶顶顶顶顶顶
爱学习的猫
2楼-- · 2019-08-15 23:07
没有人吗
472983460
3楼-- · 2019-08-16 04:07
你可以看看中文参考手册第P:287  
UIF: 更新中断标记 (Update interrupt flag)
当产生更新事件时该位由硬件置’1’。它由软件清’0’。
0:无更新事件产生;
1:更新中断等待响应。当寄存器被更新时该位由硬件置’1’:
&#8722; 若TIMx_CR1寄存器的UDIS=0、 URS=0,当TIMx_EGR寄存器的UG=1时产生更新事件
(软件对计数器CNT重新初始化);
&#8722; 若TIMx_CR1寄存器的UDIS=0、 URS=0,当计数器CNT被触发事件重初始化时产生更新
事件。 (参考同步控制寄存器的说明)
黎明雨林
4楼-- · 2019-08-16 05:33
 精彩回答 2  元偷偷看……
爱学习的猫
5楼-- · 2019-08-16 08:50
黎明雨林 发表于 2017-8-3 21:07
是不是读状态寄存器可以清除中断标志位的?所以效果一样

我看寄存器描述里并没有说明会清除,如果会清除一般会说明的吧
爱学习的猫
6楼-- · 2019-08-16 14:48
472983460 发表于 2017-8-3 20:57
你可以看看中文参考手册第P:287  
UIF: 更新中断标记 (Update interrupt flag)
当产生更新事件时该位由 ...

这个我看过了,但是不能说明这个问题的原因所在啊

一周热门 更多>