OpenEdv-开源电子网

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

串口2接收数据串口1发送数据的功能无法实现

[复制链接]

1

主题

5

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2020-9-6
在线时间
1 小时
发表于 2020-9-8 10:30:15 | 显示全部楼层 |阅读模式
1金钱
#include <stdio.h>
#include "stm32f10x.h"
#include "led.h"
#include "delay.h"
#include "key.h"
#include "timer.h"
#include "beep.h"
void My_USART1_Init()        //串口初始化
{
        /*
        在使用IO口之前需要对相应的IO口进行初始化,
        此时需要使用到GPIO_InitTypeDef结构体和GPIO_Init函数进行相应的初始化工作
        同时还要对时钟和串口进行使能操作(使能啥意思)
        */
        GPIO_InitTypeDef GPIO_InitStrue;        //创建一个GPIO口的配置结构体
        USART_InitTypeDef USART_InitStruct;        //创建一个配置串口的结构体
//        NVIC_InitTypeDef NVIC_InitStruct;        //创建一个中断配置结构体
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);        //时钟使能        //第一步:使能相应时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);        //串口1使能
       
        //PA9口输出初始化
        GPIO_InitStrue.GPIO_Mode = GPIO_Mode_AF_PP;        //推挽复用输出模式                //第二步:初始化IO口
        GPIO_InitStrue.GPIO_Pin = GPIO_Pin_9;                //被设置的接口
        GPIO_InitStrue.GPIO_Speed = GPIO_Speed_10MHz;        //GPIO口的速度
        GPIO_Init(GPIOA,&GPIO_InitStrue);        //GPIO口初始化函数
       
        //PA10口输入初始化
        GPIO_InitStrue.GPIO_Mode = GPIO_Mode_IN_FLOATING;        //浮空输入模式
        GPIO_InitStrue.GPIO_Pin = GPIO_Pin_10;        //被设置的接口
        GPIO_InitStrue.GPIO_Speed = GPIO_Speed_10MHz;        //GPIO口的速度
        GPIO_Init(GPIOA,&GPIO_InitStrue);        //GPIO口初始化函数
       
        USART_InitStruct.USART_BaudRate = 9600;        //波特率为9600                                                //第三步:初始化串口
        USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None;        //控制流为无
        USART_InitStruct.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;        //发送/接收使能
        USART_InitStruct.USART_Parity = USART_Parity_No;        //无校验位
        USART_InitStruct.USART_StopBits = USART_StopBits_1;        //停止位为1位
        USART_InitStruct.USART_WordLength = USART_WordLength_8b;        //八位数据传输
        USART_Init(USART1,&USART_InitStruct);        //串口初始化
       
        USART_Cmd(USART1,ENABLE);        //串口使能函数
        //以上为不使用中断时所需要初始化的串口相关设置
                                                                                                                                                                                                                                                                                //第四步:中断设置
//          USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);        //串口中断配置,开启接收中断
//          NVIC_InitStruct.NVIC_IRQChannel = USART1_IRQn;        //中断通道设置
//          NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;        //是否开启中断通道
//          NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 1;        //抢占优先级
//          NVIC_InitStruct.NVIC_IRQChannelSubPriority = 1;        //子优先级
//          NVIC_Init(&NVIC_InitStruct);        //中断初始化
       
//        USART_ITConfig(USART2,USART_IT_RXNE,ENABLE);        //串口中断配置,开启接收中断
//        NVIC_InitStruct.NVIC_IRQChannel = USART1_IRQn;        //中断通道设置
//        NVIC_InitStruct.NVIC_IRQChannelCmd = ENABLE;        //是否开启中断通道
//        NVIC_InitStruct.NVIC_IRQChannelPreemptionPriority = 0;        //抢占优先级
//        NVIC_InitStruct.NVIC_IRQChannelSubPriority = 0;        //子优先级
//        NVIC_Init(&NVIC_InitStruct);        //中断初始化
}
void My_USART2_Init()        //串口初始化
{
        /*
        在使用IO口之前需要对相应的IO口进行初始化,
        此时需要使用到GPIO_InitTypeDef结构体和GPIO_Init函数进行相应的初始化工作
        同时还要对时钟和串口进行使能操作(使能啥意思)
        */
        GPIO_InitTypeDef GPIO_InitStrue;        //创建一个GPIO口的配置结构体
        USART_InitTypeDef USART_InitStruct;        //创建一个配置串口的结构体
//        NVIC_InitTypeDef NVIC_InitStruct;        //创建一个中断配置结构体
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);        //时钟使能        //第一步:使能相应时钟
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB1Periph_USART2,ENABLE);        //串口2使能
       
        //PA2口输出初始化
        GPIO_InitStrue.GPIO_Mode = GPIO_Mode_AF_PP;        //推挽复用输出模式                //第二步:初始化IO口
        GPIO_InitStrue.GPIO_Pin = GPIO_Pin_2;                //被设置的接口
        GPIO_InitStrue.GPIO_Speed = GPIO_Speed_10MHz;        //GPIO口的速度
        GPIO_Init(GPIOA,&GPIO_InitStrue);        //GPIO口初始化函数
       
        //PA3口输入初始化
        GPIO_InitStrue.GPIO_Mode = GPIO_Mode_IN_FLOATING;        //浮空输入模式
        GPIO_InitStrue.GPIO_Pin = GPIO_Pin_3;        //被设置的接口
        GPIO_InitStrue.GPIO_Speed = GPIO_Speed_10MHz;        //GPIO口的速度
        GPIO_Init(GPIOA,&GPIO_InitStrue);        //GPIO口初始化函数
       
        USART_InitStruct.USART_BaudRate = 9600;        //波特率为9600                                                //第三步:初始化串口
        USART_InitStruct.USART_HardwareFlowControl = USART_HardwareFlowControl_None;        //控制流为无
        USART_InitStruct.USART_Mode = USART_Mode_Tx|USART_Mode_Rx;        //发送/接收使能
        USART_InitStruct.USART_Parity = USART_Parity_No;        //无校验位
        USART_InitStruct.USART_StopBits = USART_StopBits_1;        //停止位为1位
        USART_InitStruct.USART_WordLength = USART_WordLength_8b;        //八位数据传输
        USART_Init(USART2,&USART_InitStruct);        //串口初始化
       
        USART_Cmd(USART2,ENABLE);        //串口使能函数
}
//void USART1_IRQHandler()        //中断函数
//{
//        unsigned char date;
//        if(USART_GetITStatus(USART1,USART_IT_RXNE))        //判断串口的状态(是否接收到数据)
//        {
//                date = USART_ReceiveData(USART1);        //将数据读到date中
//                USART_SendData(USART1,date);                //将数据从串口1发送出去
//        }
//        if(USART_GetITStatus(USART2,USART_IT_RXNE))        //判断串口的状态(是否接收到数据)
//        {
//                date = USART_ReceiveData(USART2);        //将数据读到date中
//                USART_SendData(USART1,date);                //将数据从串口1发送出去
//        }
//}
int main()
{
        unsigned char date;
//        NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);        //中断优先级设置
        My_USART1_Init();
        My_USART2_Init();
        while(1)
        {
                if(USART_GetFlagStatus(USART1,USART_FLAG_RXNE))        //判断串口的状态(是否接收到数据)
                {
                        date = USART_ReceiveData(USART1);        //将数据读到date中
                        USART_SendData(USART1,date);                //将数据从串口1发送出去
                }
                if(USART_GetFlagStatus(USART2,USART_FLAG_RXNE))        //判断串口的状态(是否接收到数据)
                {
                        date = USART_ReceiveData(USART2);        //将数据读到date中
                        USART_SendData(USART1,date);                //将数据从串口1发送出去
                }
        }
}
GM65模块连接到串口二,STM32从串口2接收数据然后通过串口1发送出去,但是实际情况是如果我把线直接接到串口1就没问题,接到串口2数据就死活传不出去

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2020-9-6
在线时间
1 小时
 楼主| 发表于 2020-9-8 10:31:01 | 显示全部楼层
回复

使用道具 举报

3

主题

808

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3888
金钱
3888
注册时间
2017-3-7
在线时间
1694 小时
发表于 2020-9-8 10:57:18 | 显示全部楼层
首先在main里接收数据这么处理不对,最好有debug工具类似jlink或stlink这种,可以加断点,知道具体哪行有问题
回复

使用道具 举报

51

主题

2166

帖子

2

精华

论坛元老

Rank: 8Rank: 8

积分
10653
金钱
10653
注册时间
2017-4-14
在线时间
2780 小时
发表于 2020-9-8 11:05:18 | 显示全部楼层
这种代码建议还是找个能用的对对吧
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2020-9-6
在线时间
1 小时
 楼主| 发表于 2020-9-8 11:13:48 | 显示全部楼层
a5820736 发表于 2020-9-8 10:57
首先在main里接收数据这么处理不对,最好有debug工具类似jlink或stlink这种,可以加断点,知道具体哪行有问 ...

最开始我是设中断的,但是后来发现实现不了功能我就先把中断给关掉了
回复

使用道具 举报

1

主题

5

帖子

0

精华

新手入门

积分
10
金钱
10
注册时间
2020-9-6
在线时间
1 小时
 楼主| 发表于 2020-9-8 11:14:29 | 显示全部楼层
a5820736 发表于 2020-9-8 10:57
首先在main里接收数据这么处理不对,最好有debug工具类似jlink或stlink这种,可以加断点,知道具体哪行有问 ...

KEIL我还真不知道有啥调试工具,不然我早就调试去了
回复

使用道具 举报

3

主题

808

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3888
金钱
3888
注册时间
2017-3-7
在线时间
1694 小时
发表于 2020-9-8 11:48:15 | 显示全部楼层
Manco 发表于 2020-9-8 11:14
KEIL我还真不知道有啥调试工具,不然我早就调试去了

jlink啥的,淘宝多了去了。
加debug信息也能调试
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-1 03:58

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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