OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 4713|回复: 3

通用定时器为什么在设置(初始化)之后就会立马产生中断。原子哥求助!

[复制链接]

33

主题

92

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
280
金钱
280
注册时间
2013-6-18
在线时间
15 小时
发表于 2013-7-2 17:52:38 | 显示全部楼层 |阅读模式
在原子的教程第7讲,通用定时器中断时候发现教程中的定时器在设置之后就产生了中断,为什么?
//程序都是例程里的。
void TIM4_IRQHandler(void)
{          
if(TIM4->SR&0X0001)//溢出中断
{
LED1=!LED1;              
}   
TIM4->SR&=~(1<<0);//清除中断标志位    
}
//通用定时器中断初始化
//这里时钟选择为APB1的2倍,而APB1为36M
//arr:自动重装值。
//psc:时钟预分频数
//这里使用的是定时器3!
void Timerx_Init(u16 arr,u16 psc)
{
RCC->APB1ENR|=1<<2;//TIM3时钟使能    
  TIM4->ARR=arr;  //设定计数器自动重装值//刚好1ms    
TIM4->SC=psc;  //预分频器7200,得到10Khz的计数时钟
//这两个东东要同时设置才可以使用中断
TIM4->DIER|=1<<0;   //允许更新中断
// TIM3->DIER|=1<<6;   //允许触发中断   
  MY_NVIC_Init(1,3,TIM4_IRQChannel,2);//抢占1,子优先级3,组2  
}
////////////////////////////////////////////////////////////////
int main(void)
{
   Stm32_Clock_Init(9);//系统时钟9倍频,72M
   delay_init(72);
   uart_init(72,9600);//串口波特率9600
   Timerx_Init(9999,7199);//7200分频率,计数10000下
   LED_Init();//初始化
   //LED初始化时LED0,LED1都是灭的!   
   while(1)
   {
//printf("Welcome!\r\n"); 
delay_ms(1000);
LED0=!LED0;
   }
}
//////////////////////////////////////////////////////////////////////////////
困惑:
1.程序应该一开始2个LED都灭掉,过1s后应该一起亮,事实是中断的LED一开始就亮了,也就是一开始就产生了中断!

2.就是“printf("Welcome!\r\n");”,想通过串口输出个字符串,(能输出)发现输出字符串好像很占时间。
吧主程序改了下,让两灯一起闪烁。同时打印
  while(1)
   {
printf("Welcome!\r\n"); 
                
LED0=!LED0; 
delay_ms(1000);
   }
//////////////////////////////////////////////////////////////////////
开始还好是一起闪烁的,在闪了3-4次之后就会发现一快一慢很是明显,难道打印字符发了很多的时间(目测大概有100MS),这是为什么




一知半解!
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-7-2 22:33:05 | 显示全部楼层
1,这个立马中断的问题,我表示也很无奈...因为我也不知道为什么,他就是发生了....
2,你这句发送大概占用十几ms,多次累计,效果就明显了.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

33

主题

92

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
280
金钱
280
注册时间
2013-6-18
在线时间
15 小时
 楼主| 发表于 2013-7-3 08:32:59 | 显示全部楼层
回复【2楼】正点原子:
-------------------------------------
1.例程中是不是本身就会产生中?
2.串口打印为什么会占这么多时间?还有听说STM32有2大漏洞分别是什么?
请原子哥简单讲解一下。
一知半解!
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2013-7-3 10:27:22 | 显示全部楼层
回复【3楼】liawei123:
---------------------------------
1,这个很常见,STM32的初次启动,比如定时器,外部中断等会莫名其妙的进中断,我也曾想解决,但是没找到解决办法,最后不了了之....第一次进中断,后续就好了,不影响整个使用,也没再研究了.
2,波特率9600,你可以计算出1秒钟大概发送9600字节,平均1ms多一个字节,那么发送你的那段字符串,十几个字节,不就要十几ms了么?
想要快,可以波特率设置高点.比如115200.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-7-18 06:45

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表