请教高手一个stm32串口的问题,所收非所发,崩溃了。

2019-12-27 18:55发布

很简单的一个测试程序,串口发送简单的字符,结果上位机收到的数据就是不对,麻烦高手给指点指点,先行谢过。
使用内部振荡器,8M,串口1发送,波特率9600,本来发送的是“1111”,串口助手收到的数据是“14 14 ”
程序如下:
int main(void)
{           RCC_Configuration();
        USART1_Config(); //USART1 配置                
               
  while (1)
  {         
                USART_SendData(USART1,'1111');
                 }
}

void RCC_Configuration(void)  
{  
    //----------使用外部RC晶振-----------  
    RCC_DeInit();           //初始化为缺省值  
    RCC_HSICmd(ENABLE);
   RCC_SYSCLKConfig(RCC_SYSCLKSource_HSI);//选择内部高速时钟作为系统时钟SYSCLOCK=8MHZ
  while(RCC_GetFlagStatus(RCC_FLAG_HSIRDY) == RESET);  
             
    FLASH_PrefetchBufferCmd(FLASH_PrefetchBuffer_Enable); //Enable Prefetch Buffer  
    FLASH_SetLatency(FLASH_Latency_2);        //Flash 2 wait state  
      
    RCC_HCLKConfig(RCC_SYSCLK_Div1);        //HCLK = SYSCLK  
    RCC_PCLK2Config(RCC_HCLK_Div1);         //PCLK2 =  HCLK  
    RCC_PCLK1Config(RCC_HCLK_Div2);         //PCLK1 = HCLK/2  
    RCC_PLLConfig(RCC_PLLSource_HSI_Div2,RCC_PLLMul_9);
    RCC_PLLCmd(ENABLE);         //Enable PLLCLK  
  
    while(RCC_GetFlagStatus(RCC_FLAG_PLLRDY) == RESET); //Wait till PLLCLK is ready  
    RCC_SYSCLKConfig(RCC_SYSCLKSource_PLLCLK);  //Select PLL as system clock  
    while(RCC_GetSYSCLKSource()!=0x08);     //Wait till PLL is used as system clock source  
          //---------打开相应外设时钟--------------------  
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);    //使能APB2外设的GPIOA的时钟   
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_AFIO,ENABLE);   
    RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);  
               
}
void USART1_Config(void)
{
        GPIO_InitTypeDef GPIO_InitStructure;
        USART_InitTypeDef USART_InitStructure;

        /* USART1 使用IO端口配置 */   
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP; //复用推挽输出
  GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  GPIO_Init(GPIOA, &GPIO_InitStructure);   
  
  GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;
  GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING;        //浮空输入
  GPIO_Init(GPIOA, &GPIO_InitStructure);   //初始化GPIOA
          
        /* USART1 工作模式配置 */
        USART_InitStructure.USART_BaudRate = 9600;       
        USART_InitStructure.USART_WordLength = USART_WordLength_8b;        //数据位数设置:8位
        USART_InitStructure.USART_StopBits = USART_StopBits_1;         //停止位设置: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(USART1, &USART_InitStructure);  //初始化USART2
        USART_Cmd(USART1, ENABLE);// USART2使能
       
}
void UART1SendByte(unsigned char SendData)
{          
        USART_SendData(USART1,SendData);
        while(USART_GetFlagStatus(USART1, USART_FLAG_TXE) == RESET);            
}  
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。