[其他ST产品] stm32串口与定时器不能同时使用

[复制链接]
1064|16
 楼主| 无法去污粉 发表于 2023-11-30 23:47 | 显示全部楼层 |阅读模式
前几天stm32写了一个通用定时器,和一个串口,但是在使用的时候发现了:初始化定时器的函数在就不能运行串口
  1. 定时器的相关配置:
  2. void TIM3_Int_Init(u16 arr,u16 psc)
  3. {
  4.     TIM_TimeBaseInitTypeDef  TIM_TimeBaseStructure;
  5.     NVIC_InitTypeDef NVIC_InitStructure;

  6.     RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM3, ENABLE); //时钟使能
  7.    
  8.     //定时器TIM3初始化
  9.     TIM_TimeBaseStructure.TIM_Period = arr; //设置在下一个更新事件装入活动的自动重装载寄存器周期的值   
  10.     TIM_TimeBaseStructure.TIM_Prescaler =psc; //设置用来作为TIMx时钟频率除数的预分频值
  11.     TIM_TimeBaseStructure.TIM_ClockDivision = TIM_CKD_DIV1; //设置时钟分割:TDTS = Tck_tim
  12.     TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;  //TIM向上计数模式
  13.     TIM_TimeBaseInit(TIM3, &TIM_TimeBaseStructure); //根据指定的参数初始化TIMx的时间基数单位

  14.     TIM_ITConfig(TIM3,TIM_IT_Update,ENABLE ); //使能指定的TIM3中断,允许更新中断

  15.     //中断优先级NVIC设置
  16.     NVIC_InitStructure.NVIC_IRQChannel = TIM3_IRQn;  //TIM3中断
  17.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 1;  //先占优先级0级
  18.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;  //从优先级3级
  19.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE; //IRQ通道被使能
  20.     NVIC_Init(&NVIC_InitStructure);  //初始化NVIC寄存器
  21.     TIM_Cmd(TIM3, ENABLE);  //使能TIMx                     
  22. }
  23. 串口的相关配置:
  24. void uart_init(u32 bound){
  25.   //GPIO端口设置
  26.   GPIO_InitTypeDef GPIO_InitStructure;
  27.     USART_InitTypeDef USART_InitStructure;
  28.     NVIC_InitTypeDef NVIC_InitStructure;
  29.      
  30.     RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1|RCC_APB2Periph_GPIOA, ENABLE);    //使能USART1,GPIOA时钟
  31.   
  32.     //USART1_TX   GPIOA.9
  33.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9; //PA.9
  34.   GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  35.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;    //复用推挽输出
  36.   GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.9
  37.    
  38.   //USART1_RX      GPIOA.10初始化
  39.   GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;//PA10
  40.   GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;//浮空输入
  41.   GPIO_Init(GPIOA, &GPIO_InitStructure);//初始化GPIOA.10  

  42.   //Usart1 NVIC 配置
  43.   NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
  44.     NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0 ;//抢占优先级0
  45.     NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;        //子优先级3
  46.     NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;            //IRQ通道使能
  47.     NVIC_Init(&NVIC_InitStructure);    //根据指定的参数初始化VIC寄存器
  48.   
  49.    //USART 初始化设置

  50.     USART_InitStructure.USART_BaudRate = bound;//串口波特率
  51.     USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
  52.     USART_InitStructure.USART_StopBits = USART_StopBits_1;//一个停止位
  53.     USART_InitStructure.USART_Parity = USART_Parity_No;//无奇偶校验位
  54.     USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
  55.     USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;    //收发模式

  56.   USART_Init(USART1, &USART_InitStructure); //初始化串口1
  57.   USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//开启串口接受中断
  58.   USART_Cmd(USART1, ENABLE);                    //使能串口1

  59. }

  60. void USART1_IRQHandler(void)                    //串口1中断服务程序
  61.     {
  62.     u8 Res;
  63. #if SYSTEM_SUPPORT_OS         //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
  64.     OSIntEnter();   
  65. #endif
  66.     if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)  //接收中断(接收到的数据必须是0x0d 0x0a结尾)
  67.         {
  68.         Res =USART_ReceiveData(USART1);    //读取接收到的数据
  69.         
  70.         if((USART_RX_STA&0x8000)==0)//接收未完成
  71.             {
  72.             if(USART_RX_STA&0x4000)//接收到了0x0d
  73.                 {
  74.                 if(Res!=0x0a)USART_RX_STA=0;//接收错误,重新开始
  75.                 else USART_RX_STA|=0x8000;    //接收完成了
  76.                 }
  77.             else //还没收到0X0D
  78.                 {   
  79.                 if(Res==0x0d)USART_RX_STA|=0x4000;
  80.                 else
  81.                     {
  82.                     USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
  83.                     USART_RX_STA++;
  84.                     if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收数据错误,重新开始接收      
  85.                     }         
  86.                 }
  87.             }            
  88.      }
  89. #if SYSTEM_SUPPORT_OS     //如果SYSTEM_SUPPORT_OS为真,则需要支持OS.
  90.     OSIntExit();                                               
  91. #endif


tpgf 发表于 2023-12-15 10:02 | 显示全部楼层
这个就涉及到引脚复用的功能了
木木guainv 发表于 2023-12-15 11:03 | 显示全部楼层
是不是串口的引脚和定时器的引脚冲突了
晓伍 发表于 2023-12-15 11:46 | 显示全部楼层
可以避让开这个引脚啊 进行引脚重映射啊
观海 发表于 2023-12-15 21:49 | 显示全部楼层
是不是在引脚配置的时候没有启用引脚的第二功能呢
八层楼 发表于 2023-12-15 22:22 | 显示全部楼层
这两个功能的初始化函数是不是顺序有问题
磨砂 发表于 2023-12-15 22:58 | 显示全部楼层
对于引脚复用的情况 需要每次使用的时候都重新初始化吗
远山寻你 发表于 2023-12-20 22:10 | 显示全部楼层
看看你的主函数部分咋处理的?
淡漠安然 发表于 2023-12-21 01:00 | 显示全部楼层
可能是你定时器中断函数没做吧
别乱了阵脚 发表于 2023-12-21 03:00 | 显示全部楼层
看你的配置函数好像也没啥问题啊
冰春彩落下 发表于 2023-12-21 05:00 | 显示全部楼层
定时器中断函数在哪儿呢?
一秒落纱 发表于 2023-12-21 07:00 | 显示全部楼层
直接抄个原子的例程函数多好,应该就没啥问题吧
三生万物 发表于 2023-12-21 09:00 | 显示全部楼层
你仿真的时候看看程序在哪儿死掉了?
暖了夏天蓝了海 发表于 2023-12-21 09:00 | 显示全部楼层
程序的逻辑的问题,串口和定时器3一起用是没问题的
江河千里 发表于 2023-12-21 11:00 | 显示全部楼层
能一起用,我之前都这么使用的,你要是初始化定时器函数放在串口后面,串口能运行,定时器还不好用,就是定时器函数有问题
光辉梦境 发表于 2023-12-21 13:00 | 显示全部楼层
你看看你的初始化函数吧,是不是缺啥项了
夜阑风雨 发表于 2023-12-21 22:00 | 显示全部楼层
把你工程压缩发出来看看,看看是哪里的问题
您需要登录后才可以回帖 登录 | 注册

本版积分规则

57

主题

808

帖子

1

粉丝
快速回复 在线客服 返回列表 返回顶部