很奇怪串口接收不到数据,所有的都设置了,也看了例程都一样啊,求大神帮忙

2019-08-13 18:53发布

新人,没办法就这么多金钱。
用的是攀藤pm2.5传感器,下面是我的程序主程序:

int main(void)
{
       bspgpioinit();         //引脚配置(这边是连接到74hc595的4个引脚配置)
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
13条回答
lvkanger
1楼-- · 2019-08-13 19:55
蛋白质khun 发表于 2017-10-14 16:53
我又试了一下发送,发现也无法发送,是我上面放入程序有哪边不对或者漏写什么了嘛。RXNE和txne都无法置1, ...

GPIO_initstructRX.GPIO_Pin=GPIO_Pin_10;
        GPIO_initstructRX.GPIO_Pin=GPIO_Mode_IN_FLOATING;
蛋白质khun
2楼-- · 2019-08-14 00:02
新人,没办法就这么多金钱。
用的是攀藤pm2.5传感器,下面是我的程序
主程序:
int main(void)
{
       bspgpioinit();         //引脚配置(这边是连接到74hc595的4个引脚配置)
        USART_Config();
        while(1)
        {
                        bsprecervebyte(USART1);  //接收数据显示到数码管
        }
}
引脚配置源文件:
void bspgpioinit(void)
{
        GPIO_InitTypeDef gpio_initoe,gpio_initser,gpio_initrck,gpio_initsck;
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOB, ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
  gpio_initoe.GPIO_Pin=GPIO_Pin_11;
        gpio_initoe.GPIO_Mode=GPIO_Mode_Out_OD;
        gpio_initoe.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_Init(GPIOB, &gpio_initoe);
  gpio_initser.GPIO_Pin=GPIO_Pin_7;
        gpio_initser.GPIO_Mode=GPIO_Mode_Out_PP;
        gpio_initser.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &gpio_initser);
  gpio_initrck.GPIO_Pin=GPIO_Pin_10;
        gpio_initrck.GPIO_Mode=GPIO_Mode_Out_PP;
        gpio_initrck.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_Init(GPIOB, &gpio_initrck);
  gpio_initsck.GPIO_Pin=GPIO_Pin_1;
        gpio_initsck.GPIO_Mode=GPIO_Mode_Out_PP;
        gpio_initsck.GPIO_Speed=GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &gpio_initsck);
        GPIO_SetBits(GPIOB, GPIO_Pin_11);
        GPIO_SetBits(GPIOA, GPIO_Pin_7);
        GPIO_SetBits(GPIOB, GPIO_Pin_10);
        GPIO_SetBits(GPIOA, GPIO_Pin_1);
}
串口配置源文件:
         static u16 tep,buf0,buf1,buf2,Res;
void USART_Config(void)
{
        GPIO_InitTypeDef GPIO_initstructRX,GPIO_initstructTX;
        USART_InitTypeDef USART_initstruct;
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA, ENABLE);
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1, ENABLE);
        GPIO_initstructRX.GPIO_Pin=GPIO_Pin_10;
        GPIO_initstructRX.GPIO_Pin=GPIO_Mode_IN_FLOATING;
        GPIO_Init(GPIOA, &GPIO_initstructRX);
        GPIO_initstructTX.GPIO_Pin=GPIO_Pin_9;
        GPIO_initstructTX.GPIO_Pin=GPIO_Mode_AF_PP;
  GPIO_initstructTX.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_Init(GPIOA, &GPIO_initstructTX);
        USART_initstruct.USART_BaudRate=9600;
        USART_initstruct.USART_WordLength=USART_WordLength_8b;
        USART_initstruct.USART_StopBits=USART_StopBits_1;
        USART_initstruct.USART_HardwareFlowControl=USART_Mode_Rx | USART_Mode_Tx;
        USART_initstruct.USART_HardwareFlowControl=USART_HardwareFlowControl_None;
        USART_initstruct.USART_Parity=USART_Parity_No;
        USART_Init(USART1, &USART_initstruct);
        USART_Cmd(USART1, ENABLE);
}

void bsprecervebyte(USART_TypeDef* pUSARTx)  //接收数据
{
         static char start=0;
         static uint16_t USART1_RX_STA;
         while(USART_GetFlagStatus(pUSARTx, USART_FLAG_RXNE)==RESET);
         
        Res =USART_ReceiveData(pUSARTx);     //读取接收到的数据  
        if(Res == 0x42)             //如果接收的第一位数据是0X42  
        {  
            USART1_RX_STA = 0;    //让数组索引值从0开始  
            start = 1;              //变量用于确定第二位是否接收到了0X4D  
        }  
        start = 1;
        if(start == 1)  
        {  
            switch (USART1_RX_STA)  
            {  
                case 1:  
                    buf0 = Res ;    break;      //接收0x4D  
                case 6:  
                    buf1 = Res ;    break;      //接收大气环境下PM2.5高8位  
                case 7:  
                    buf2 = Res ;    break;      //接收大气环境下PM2.5低8位  
                default:    break;  
            }  
            USART1_RX_STA++;  
            if(USART1_RX_STA >= 8 && (0x4d == buf0))  
            {   
                start  = 0;  
                USART1_RX_STA=0;                //对static类型赋初值  
                USART_ITConfig(USART1,USART_IT_RXNE,DISABLE);   //关闭接收终端,由定时器中断打开  
                tep = (buf1<<8) + buf2;  
               
                numdisplay(tep);     //把pm2.5值传给74hc595程序,整个程序没错,我验证过
            }  
        }                                               
}
这是所有程序,主要应该是卡在了等待接收到数据那边,不知道为什么。求大神啊
csmjmcc
3楼-- · 2019-08-14 05:50
没有仔细阅读楼主的程序,但提醒如下:
1、UART1 端口TXD RXD是重映射的,所以需要启用 RCC_APB2Periph_AFIO 即:RCC_APB2PeriphClockCmd( RCC_APB2Periph_AFIO, ENABLE);
2、最好使能接收中断,用中断方式去接收串口消息。从程序看楼主用的查询方式。
3、由第二条引申的注意事项:
                               (1)若采用查询方式,务必不要将接收中断方式使能。
                               (2)若采用中断方式接收数据,务必使能接收中断,并在中断函数void USART1_IRQHandler(void)中,加入你的接收程序调用。
蛋白质khun
4楼-- · 2019-08-14 08:57
csmjmcc 发表于 2017-10-13 17:53
没有仔细阅读楼主的程序,但提醒如下:
1、UART1 端口TXD RXD是重映射的,所以需要启用 RCC_APB2Periph_AF ...

我确实没有打开afio的时钟,可是pa9pa10的第二功能是usart1啊,不是重映射吧?这个也需要打开afio的时钟吗
来俩不甜的
5楼-- · 2019-08-14 12:27
 精彩回答 2  元偷偷看……
蛋白质khun
6楼-- · 2019-08-14 13:56
来俩不甜的 发表于 2017-10-13 21:37
软件没问题就看硬件

好的,我明天看看传感器和和串口助手通信吧,看看传感器还行不行

一周热门 更多>