OpenEdv-开源电子网

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

485卡死在 while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET)

[复制链接]

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
发表于 2016-4-5 09:58:26 | 显示全部楼层 |阅读模式
5金钱
画了个板子 485电路如图 使用串口1, 485发送时卡死在while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET)

程序用的原子的
大家帮忙看看问题在哪儿??
[mw_shl_code=c,true]#include "sys.h"
#include "rs485.h"         
#include "delay.h"
//////////////////////////////////////////////////////////////////////////////////         
//RS485Çy¶ˉ ′úÂë                                                                             
//////////////////////////////////////////////////////////////////////////////////          


#if EN_USART1_RX                   //èç1ûê1Äüá˽óêÕ             
//½óêÕ»o′æÇø        
u8 RS485_RX_BUF[64];          //½óêÕ»o3å,×î′ó64¸ö×Ö½ú.
//½óêÕμ½μÄêy¾Y3¤¶è
u8 RS485_RX_CNT=0;   
void USART1_IRQHandler(void)
{
        u8 res;            
        if(USART_GetITStatus(USART1, USART_IT_RXNE) != RESET)//½óêÕμ½êy¾Y
        {                
          res =USART_ReceiveData(USART1);//;¶á衽óêÕμ½μÄêy¾YUSART1->DR
                if(RS485_RX_CNT<64)
                {
                        RS485_RX_BUF[RS485_RX_CNT]=res;                //&#188;&#199;&#194;&#188;&#189;óê&#213;μ&#189;μ&#196;&#214;μ
                        RS485_RX_CNT++;                                                //&#189;óê&#213;êy&#190;Y&#212;&#246;&#188;ó1
                }
        }                                                                                           
}
#endif                                                                                 
//3&#245;ê&#188;&#187;ˉIO ′&#174;&#191;ú1
//bound:2¨ì&#216;&#194;ê          
void RS485_Init(u32 bound)
{           
       
  GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
       
        RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); //ê1&#196;üGPIOAê±&#214;ó
        RCC_APB1PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);//ê1&#196;üUSART1ê±&#214;ó
       
  //′&#174;&#191;ú1òy&#189;&#197;&#184;′ó&#195;ó3é&#228;
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource9,GPIO_AF_USART1); //GPIOA9&#184;′ó&#195;&#206;aUSART1
        GPIO_PinAFConfig(GPIOA,GPIO_PinSource10,GPIO_AF_USART1); //GPIOA10&#184;′ó&#195;&#206;aUSART1
       
        //USART1   
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9 | GPIO_Pin_10; //GPIOA9ó&#235;GPIOA10
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF;//&#184;′ó&#195;1|&#196;ü
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;        //&#203;ù&#182;è100MHz
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //í&#198;íì&#184;′ó&#195;ê&#228;3&#246;
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //é&#207;à-
        GPIO_Init(GPIOA,&GPIO_InitStructure); //3&#245;ê&#188;&#187;ˉPA9£&#172A10
       
        //PA11í&#198;íìê&#228;3&#246;£&#172;485&#196;£ê&#189;&#191;&#216;&#214;&#198;  
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11; //GPIOA11
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;//ê&#228;3&#246;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_100MHz;        //&#203;ù&#182;è100MHz
        GPIO_InitStructure.GPIO_OType = GPIO_OType_PP; //í&#198;íìê&#228;3&#246;
        GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_UP; //é&#207;à-
        GPIO_Init(GPIOA,&GPIO_InitStructure); //3&#245;ê&#188;&#187;ˉPA11
       

   //USART1 3&#245;ê&#188;&#187;ˉéè&#214;&#195;
        USART_InitStructure.USART_BaudRate = bound;//2¨ì&#216;&#194;êéè&#214;&#195;
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//×&#214;3¤&#206;a8&#206;&#187;êy&#190;Y&#184;&#241;ê&#189;
        USART_InitStructure.USART_StopBits = USART_StopBits_1;//ò&#187;&#184;&#246;í£&#214;1&#206;&#187;
        USART_InitStructure.USART_Parity = USART_Parity_No;//&#206;T&#198;&#230;&#197;&#188;D£&#209;é&#206;&#187;
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//&#206;Tó2&#188;têy&#190;Yá÷&#191;&#216;&#214;&#198;
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;        //ê&#213;·¢&#196;£ê&#189;
  USART_Init(USART1, &USART_InitStructure); //3&#245;ê&#188;&#187;ˉ′&#174;&#191;ú1
       
  USART_Cmd(USART1, ENABLE);  //ê1&#196;ü′&#174;&#191;ú 1
       
        USART_ClearFlag(USART1, USART_FLAG_TC);
       
#if EN_USART1_RX       
        USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);//&#191;a&#198;&#244;&#189;óêü&#214;D&#182;&#207;

        //USART1 NVIC &#197;&#228;&#214;&#195;
  NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3;//&#199;à&#213;&#188;ó&#197;&#207;è&#188;&#182;3
        NVIC_InitStructure.NVIC_IRQChannelSubPriority =3;                //×óó&#197;&#207;è&#188;&#182;3
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                        //IRQí¨μàê1&#196;ü
        NVIC_Init(&NVIC_InitStructure);        //&#184;ù&#190;Y&#214;&#184;&#182;¨μ&#196;2&#206;êy3&#245;ê&#188;&#187;ˉVIC&#188;&#196;′&#230;&#198;÷&#161;¢

#endif       
       
        RS485_TX_EN=0;                                //&#196;&#172;è&#207;&#206;a&#189;óê&#213;&#196;£ê&#189;       
}

//RS485·¢&#203;ílen&#184;&#246;×&#214;&#189;ú.
//buf:·¢&#203;í&#199;&#248;ê×μ&#216;&#214;·
//len:·¢&#203;íμ&#196;×&#214;&#189;úêy(&#206;aá&#203;oí±&#190;′ú&#194;&#235;μ&#196;&#189;óê&#213;&#198;¥&#197;&#228;,&#213;aà&#239;&#189;¨òé2&#187;òa3&#172;1y64&#184;&#246;×&#214;&#189;ú)
void RS485_Send_Data(u8 *buf,u8 len)
{
        u8 t;
        RS485_TX_EN=1;                        //éè&#214;&#195;&#206;a·¢&#203;í&#196;£ê&#189;
          for(t=0;t<len;t++)                //&#209;-&#187;··¢&#203;íêy&#190;Y
        {
          while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET); //μè′y·¢&#203;í&#189;áê&#248;               
    USART_SendData(USART1,buf[t]); //·¢&#203;íêy&#190;Y
        }         
        while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET); //μè′y·¢&#203;í&#189;áê&#248;               
        RS485_RX_CNT=0;          
        RS485_TX_EN=0;                                //éè&#214;&#195;&#206;a&#189;óê&#213;&#196;£ê&#189;       
}
//RS4852é&#209;ˉ&#189;óê&#213;μ&#189;μ&#196;êy&#190;Y
//buf:&#189;óê&#213;&#187;o′&#230;ê×μ&#216;&#214;·
//len:&#182;áμ&#189;μ&#196;êy&#190;Y3¤&#182;è
void RS485_Receive_Data(u8 *buf,u8 *len)
{
        u8 rxlen=RS485_RX_CNT;
        u8 i=0;
        *len=0;                                //&#196;&#172;è&#207;&#206;a0
        delay_ms(10);                //μè′y10ms,á&#172;D&#248;3&#172;1y10ms&#195;&#187;óD&#189;óê&#213;μ&#189;ò&#187;&#184;&#246;êy&#190;Y,&#212;òè&#207;&#206;a&#189;óê&#213;&#189;áê&#248;
        if(rxlen==RS485_RX_CNT&&rxlen)//&#189;óê&#213;μ&#189;á&#203;êy&#190;Y,&#199;ò&#189;óê&#213;íê3éá&#203;
        {
                for(i=0;i<rxlen;i++)
                {
                        buf=RS485_RX_BUF;       
                }               
                *len=RS485_RX_CNT;        //&#188;&#199;&#194;&#188;±&#190;′&#206;êy&#190;Y3¤&#182;è
                RS485_RX_CNT=0;                //&#199;&#229;á&#227;
        }
}[/mw_shl_code]

D~G[)S6DTS1$VA5VX]@JW0R.png

最佳答案

查看完整内容[请看2#楼]

仔细看了一下你的程序,如果你是用的stm32f103系列芯片的话,可能有以下几个问题: 1,RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE); 这句应该是 RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE); ??? 2,串口引脚定义那边, GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11; //PA11端口配置 GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推完输出 GPIO_InitStructure.GPIO_Spee ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

3

主题

31

帖子

0

精华

初级会员

Rank: 2

积分
136
金钱
136
注册时间
2015-8-8
在线时间
24 小时
发表于 2016-4-5 09:58:27 | 显示全部楼层
仔细看了一下你的程序,如果你是用的stm32f103系列芯片的话,可能有以下几个问题:

1,RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOA,ENABLE);
这句应该是  RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);    ???

2,串口引脚定义那边,
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_11;                                 //PA11端口配置
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP;                  //推完输出
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_InitStructure);

        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;        //PA9
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;        //复用推完输出
  GPIO_Init(GPIOA, &GPIO_InitStructure);
   
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;//PA10
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入
  GPIO_Init(GPIOA, &GPIO_InitStructure);  
你那个我实在没看懂,又不想库函数里的,你试试看。。
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-5 10:17:54 | 显示全部楼层
在线等
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-5 17:06:54 | 显示全部楼层
烦躁 怎么没有人来说两句
回复

使用道具 举报

3

主题

31

帖子

0

精华

初级会员

Rank: 2

积分
136
金钱
136
注册时间
2015-8-8
在线时间
24 小时
发表于 2016-4-5 20:27:53 | 显示全部楼层
本帖最后由 Denniky 于 2016-4-5 20:29 编辑

你的A和B有没有接反了。。
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-5 21:32:16 | 显示全部楼层
Denniky 发表于 2016-4-5 20:27
你的A和B有没有接反了。。

确定没有
回复

使用道具 举报

9

主题

96

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
257
金钱
257
注册时间
2015-12-14
在线时间
50 小时
发表于 2016-4-5 21:37:14 | 显示全部楼层
有没有清除标志位?
Keep moving,to be NO.1!
回复

使用道具 举报

0

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
169
金钱
169
注册时间
2013-12-17
在线时间
66 小时
发表于 2016-4-6 09:17:03 | 显示全部楼层
就是因为串口初始化时清除了发送完成标志位;

建议在串口初始化后发送一个空数据,如果不介意的话;
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-6 09:44:27 | 显示全部楼层
Denniky 发表于 2016-4-6 09:35
仔细看了一下你的程序,如果你是用的stm32f103系列芯片的话,可能有以下几个问题:

1,RCC_AHB1PeriphCl ...

谢谢!我用的STM32F407VET6,和103应该有些不一样,初始化IO参考的原子407的例程,例程串口2改成了串口1.  
现在在考虑硬件问题,试了一下把原来的偏置电阻10K拆了,,不行;换成了2K,还是不行;不知道是不是MAX485有问题,准备换一个试试
回复

使用道具 举报

15

主题

317

帖子

0

精华

高级会员

Rank: 4

积分
859
金钱
859
注册时间
2015-2-12
在线时间
353 小时
发表于 2016-4-6 09:58:43 | 显示全部楼层
发送数据(void RS485_Send_Data(u8 *buf,u8 len))与外接485硬件没有关系的。这仅关联MCU内部。
回复

使用道具 举报

15

主题

317

帖子

0

精华

高级会员

Rank: 4

积分
859
金钱
859
注册时间
2015-2-12
在线时间
353 小时
发表于 2016-4-6 10:17:24 | 显示全部楼层
Bit 6 TC: Transmission complete
This bit is set by hardware if the transmission of a frame containing data is complete and if
TXE is set. An interrupt is generated if TCIE=1 in the USART_CR1 register. It is cleared by a
software sequence (a read from the USART_SR register followed by a write to the
USART_DR register). The TC bit can also be cleared by writing a '0' to it. This clearing
sequence is recommended only for multibuffer communication.
0: Transmission is not complete
1: Transmission is complete

如上描述:
1、发送前,先清除TC标志:USART_ClearFlag(USART1,USART_FLAG_TC);
2、发送一个字节:USART_SendData(USART1,buf[t]);
3、判断发送是否完成:while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET);

若不放心第3步,可以如此:while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==RESET){ if(++send_timer_over > 60000)  break; };
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-6 16:03:58 | 显示全部楼层
Denniky 发表于 2016-4-6 09:35
仔细看了一下你的程序,如果你是用的stm32f103系列芯片的话,可能有以下几个问题:

1,RCC_AHB1PeriphCl ...

。。。        错在        RCC_APB1PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
应该是RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
痛啊!
回复

使用道具 举报

10

主题

68

帖子

0

精华

高级会员

Rank: 4

积分
500
金钱
500
注册时间
2014-9-1
在线时间
77 小时
 楼主| 发表于 2016-4-6 16:04:41 | 显示全部楼层
cheng8152 发表于 2016-4-6 09:44
谢谢!我用的STM32F407VET6,和103应该有些不一样,初始化IO参考的原子407的例程,例程串口2改成了串口1. ...

。。。        错在        RCC_APB1PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
应该是RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
痛啊!
回复

使用道具 举报

1

主题

15

帖子

0

精华

初级会员

Rank: 2

积分
50
金钱
50
注册时间
2016-11-27
在线时间
14 小时
发表于 2016-11-28 16:29:11 | 显示全部楼层
cheng8152 发表于 2016-4-6 16:03
。。。        错在        RCC_APB1PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);
应该是RCC_APB2PeriphClockCmd(RC ...

我也碰到这个问题了!!!!!!纠结了2天!!!痛啊!!!!
回复

使用道具 举报

9

主题

100

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1513
金钱
1513
注册时间
2016-7-28
在线时间
302 小时
发表于 2019-4-3 14:07:37 | 显示全部楼层
同样是楼主的问题
回复

使用道具 举报

2

主题

14

帖子

0

精华

初级会员

Rank: 2

积分
118
金钱
118
注册时间
2020-5-20
在线时间
44 小时
发表于 2021-7-13 10:31:58 | 显示全部楼层
感谢楼主,解决了我两天的问题,心痛啊
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-23 15:34

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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