OpenEdv-开源电子网

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

再次求救,stm32串口,为什么同样的程序,用串口1接收ok,但是串口2接收不了

[复制链接]

11

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2016-9-23
在线时间
20 小时
发表于 2017-6-28 15:41:01 | 显示全部楼层 |阅读模式
2金钱
原子兄,你也 出来帮忙解决下呗
求救,本人在做32的串口时发现利用串口1接收数据时没有问题,但是串口2就接收不到,为什么。

最佳答案

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

问题已解决,没有使用正点原子所给的程序。自加传输方式
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

11

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2016-9-23
在线时间
20 小时
 楼主| 发表于 2017-6-28 15:41:02 | 显示全部楼层
问题已解决,没有使用正点原子所给的程序。自加传输方式
回复

使用道具 举报

1

主题

14

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2017-6-2
在线时间
5 小时
发表于 2017-6-28 15:59:51 | 显示全部楼层
贴代码啊,不然没法给你分析
回复

使用道具 举报

11

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2016-9-23
在线时间
20 小时
 楼主| 发表于 2017-6-28 16:04:14 | 显示全部楼层
郝周周 发表于 2017-6-28 15:59
贴代码啊,不然没法给你分析

串口函数:
#if 1
#pragma import(__use_no_semihosting)            
//标准库需要的支持函数                 
struct __FILE
{
        int handle;

};

FILE __stdout;      
//定义_sys_exit()以避免使用半主机模式   
_sys_exit(int x)
{
        x = x;
}
//重定义fputc函数
int fputc(int ch, FILE *f)
{      
        while((USART2->SR&0X40)==0);//循环发送,直到发送完毕   
    USART2->DR = (u8) ch;      
        return ch;
}
#endif

/*使用microLib的方法*/
/*
int fputc(int ch, FILE *f)
{
        USART_SendData(USART1, (uint8_t) ch);

        while (USART_GetFlagStatus(USART1, USART_FLAG_TC) == RESET) {}       
   
    return ch;
}
int GetKey (void)  {

    while (!(USART1->SR & USART_FLAG_RXNE));

    return ((int)(USART1->DR & 0x1FF));
}
*/

#if EN_USART1_RX   //如果使能了接收
                                                                        //串口1中断服务程序
                                                                        //注意,读取USARTx->SR能避免莫名其妙的错误   
   
u8 USART_RX_BUF[USART_REC_LEN];     //接收缓冲,最大USART_REC_LEN个字节.
//接收状态
//bit15,        接收完成标志
//bit14,        接收到0x0d
//bit13~0,        接收到的有效字节数目
u16 USART_RX_STA=0;       //接收状态标记          
  
void uart_init(u32 bound){
  //GPIO端口设置
  GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;
        NVIC_InitTypeDef NVIC_InitStructure;
         
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);        //使能USART1,GPIOA时钟
  RCC_APB1PeriphClockCmd(RCC_APB1Periph_USART2, ENABLE);
        //USART1_TX   GPIOA.9
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_2;               //PA.9
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;                //复用推挽输出
  GPIO_Init(GPIOA, &GPIO_InitStructure);                  //初始化GPIOA.9
   
  //USART1_RX          GPIOA.10初始化
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_3;              //PA10
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;   //浮空输入
  GPIO_Init(GPIOA, &GPIO_InitStructure);                  //初始化GPIOA.10  

  //Usart1 NVIC 配置
  NVIC_InitStructure.NVIC_IRQChannel = USART2_IRQn;
        NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=3 ;//抢占优先级3
        NVIC_InitStructure.NVIC_IRQChannelSubPriority = 3;                  //子优先级3
        NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;                            //IRQ通道使能
        NVIC_Init(&NVIC_InitStructure);                                //根据指定的参数初始化VIC寄存器
  
  //USART 初始化设置
        USART_InitStructure.USART_BaudRate = bound;                //串口波特率
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;//字长为8位数据格式
        USART_InitStructure.USART_StopBits = USART_StopBits_1;     //一个停止位
        USART_InitStructure.USART_Parity = USART_Parity_No;        //无奇偶校验位
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;//无硬件数据流控制
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;                       //收发模式

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

}

void USART_IRQHandler(void)                        //串口1中断服务程序
        {
        u8 Res;
        if(USART_GetITStatus(USART2, USART_IT_RXNE) != RESET)  //接收中断(接收到的数据必须是0x0d 0x0a结尾)
                {
                Res =USART_ReceiveData(USART2);        //读取接收到的数据
               
                if((USART_RX_STA&0x8000)==0)//接收未完成
                        {
                        if(USART_RX_STA&0x4000)//接收到了0x0d
                                {
                                if(Res!=0x0a)USART_RX_STA=0;//接收错误,重新开始
                                else USART_RX_STA|=0x8000;        //接收完成了
                                }
                        else //还没收到0X0D
                                {       
                                if(Res==0x0d)USART_RX_STA|=0x4000;
                                else
                                        {
                                        USART_RX_BUF[USART_RX_STA&0X3FFF]=Res ;
                                        USART_RX_STA++;
                                        if(USART_RX_STA>(USART_REC_LEN-1))USART_RX_STA=0;//接收数据错误,重新开始接收          
                                        }                 
                                }
                        }                    
     }
}
#endif

主函数:
int main(void)
{               
        u16 t;  
        u16 len;       
        u16 times=0;
        delay_init();                                                            //延时函数初始化          
       
        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);             //设置NVIC中断分组2:2位抢占优先级,2位响应优先级
        uart_init(9600);
                     

        LED_Init();                                                                  //LED端口初始化  
         
                                          
        while(1)
        {
                if(USART_RX_STA&0x8000)
                {                                          
                        len=USART_RX_STA&0x3fff;                                //得到此次接收到的数据长度
                        printf("\r\n您发送的消息为:\r\n\r\n");
                        for(t=0;t<len;t++)
                        {
                                USART_SendData(USART2, USART_RX_BUF[t]);               //向串口1发送数据
                                while(USART_GetFlagStatus(USART2,USART_FLAG_TC)!=SET); //等待发送结束
                        }
                        printf("\r\n\r\n");                                       //插入换行
                        USART_RX_STA=0;

                }else
                {
                        times++;
                        if(times%5000==0)
                        {
                                printf("\r\n通信工程\r\n");
                                printf("智防物联@mxj\r\n\r\n");
                        }
                        if(times%200==0)printf("请输入数据,以回车键结束\n");  
                        if(times%30==0)LED0=!LED0;//闪烁LED,提示系统正在运行.
                        delay_ms(10);   
                }
        }         
}
回复

使用道具 举报

1

主题

14

帖子

0

精华

新手上路

积分
48
金钱
48
注册时间
2017-6-2
在线时间
5 小时
发表于 2017-6-28 16:07:40 | 显示全部楼层
#if EN_USART1_RX   //如果使能了接收  这地方改过来,仔细修改吧usart1改为usart2
回复

使用道具 举报

58

主题

6296

帖子

1

精华

资深版主

Rank: 8Rank: 8

积分
11600
金钱
11600
注册时间
2014-4-1
在线时间
1326 小时
发表于 2017-6-28 16:10:23 | 显示全部楼层

先假设配置是正常的,
main函数中连续不停地发送一个常数,发完一个再接着发,也可以延迟一点时间,一般发 0x55 或者 0xAA,
用示波器观察Txd引脚有没有波形。
如果有波形,看波特率对不对,如果波特率也是对的,说明发送端基本没问题,要去查接收端,如果波特率不对,重新计算。
如果没有波形,说明配置有问题,一般是GPIO、AF方面有问题。

提醒你一下,两个串口的时钟源很可能不一样,要搞清各自的频率,然后才计算波特率常数。


回复

使用道具 举报

11

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2016-9-23
在线时间
20 小时
 楼主| 发表于 2017-6-28 17:14:35 | 显示全部楼层
xuande 发表于 2017-6-28 16:10
先假设配置是正常的,
main函数中连续不停地发送一个常数,发完一个再接着发,也可以延迟一点时间,一般 ...

都一样,没有问题,查询发现按照正点原子给的程序一直进不判断最后的标志位
回复

使用道具 举报

10

主题

172

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1479
金钱
1479
注册时间
2016-1-25
在线时间
260 小时
发表于 2017-6-28 17:24:50 | 显示全部楼层
估计是哪边配置不对  你可以去看看原子哥485的例程,用的就是串口2.
回复

使用道具 举报

2

主题

28

帖子

0

精华

初级会员

Rank: 2

积分
93
金钱
93
注册时间
2017-4-13
在线时间
12 小时
发表于 2017-6-28 17:27:32 | 显示全部楼层
代码没问题的话可以考虑检查一下板子硬件
回复

使用道具 举报

11

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
99
金钱
99
注册时间
2016-9-23
在线时间
20 小时
 楼主| 发表于 2017-6-28 17:48:49 | 显示全部楼层
highrunning 发表于 2017-6-28 17:27
代码没问题的话可以考虑检查一下板子硬件

已解决,我用自己的传输协议写的,不用给的方法测了一下,正常
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-8-17 13:37

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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