使用xcom串口通信在没有发送的情况下持续接收

2019-10-15 02:55发布

以下是我的代码,附件是xcom,我也不知道怎么回事,还没有在串口发送数据,结果串口就收到了一大堆数据..........
求原子哥解毒

#include"stm32f10x.h"

void GPIO_Configuration(void);
void RCC_Configuration(void);
void USART_Configuration(void);

int main(void)
{
        vu16 t = 0;
        RCC_Configuration();
        GPIO_Configuration();
        USART_Configuration();
       
        while(1)
        {
                if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET)
                {
                        USART_SendData(USART1,USART_ReceiveData(USART1));
                        for(t;t<500;++t);
                }
        }
}


友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
3条回答
zkqiu
1楼-- · 2019-10-15 06:50
我知道了,应该把   if(USART_GetFlagStatus(USART1,USART_IT_RXNE) == SET)改为   if(USART_GetFlagStatus(USART1,USART_FLAG_RXNE) == SET)
zkqiu
2楼-- · 2019-10-15 11:12
#include"stm32f10x.h"

void USART_Configuration(void)
{
        USART_InitTypeDef USART_InitStructure;
       
        USART_InitStructure.USART_BaudRate = 9600;
        USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
        USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;
        USART_InitStructure.USART_Parity = USART_Parity_No;
        USART_InitStructure.USART_StopBits = USART_StopBits_1;
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;
       
        USART_Init(USART1,&USART_InitStructure);
       
        USART_Cmd(USART1,ENABLE);
}

#include"stm32f10x.h"

void RCC_Configuration(void)
{
        ErrorStatus HSEStartUpStatus;
        RCC_DeInit();                                                                                                //&#184;′&#206;&#187;&#207;μí3ê±&#214;óéè&#214;&#195;
        RCC_HSEConfig(RCC_HSE_ON);                                        //′ò&#191;aía2&#191;&#184;&#223;&#203;ùê±&#214;ó&#212;′
        HSEStartUpStatus = RCC_WaitForHSEStartUp();                        //&#197;D&#182;&#207;ê&#199;·&#241;&#198;e&#213;&#241;3é1|
       
        if(HSEStartUpStatus == SUCCESS)
        {
                RCC_HCLKConfig(RCC_SYSCLK_Div1);                //AHBê±&#214;ó&#206;aSYSCLK 1·&#214;&#198;μ
                RCC_PCLK2Config(RCC_HCLK_Div1);                        //APB2ê±&#214;ó&#206;aAHBê±&#214;ó1·&#214;&#198;μ
                RCC_PCLK1Config(RCC_HCLK_Div2);
                FLASH_SetLatency(FLASH_Latency_2);
                FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable);
                RCC_PLLConfig(RCC_PLLSource_HSE_Div1,RCC_PLLMul_9);
                RCC_PLLCmd(ENABLE);
                while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET);
                RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);
                while(RCC_GetSYSCLKSource() != 0x08);
        }
        RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA | RCC_APB2Periph_USART1,ENABLE);
}


#include"stm32f10x.h"

void GPIO_Configuration(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;
        GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
        GPIO_Init(GPIOA,&GPIO_InitStructure);
       
        GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;
        GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
        GPIO_Init(GPIOA,&GPIO_InitStructure);
}


这是另外几段代码
zkqiu
3楼-- · 2019-10-15 15:56
 精彩回答 2  元偷偷看……

一周热门 更多>