请教高手一个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);            
}  
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
16条回答
lnskngdc
1楼-- · 2019-12-29 01:09
串口助手设置的是9bit还是8bit?

波特率很可能有误差,你算一下
deiwgah
2楼-- · 2019-12-29 04:43
lsx007 发表于 2017-6-12 22:51
波特率没有配对吧,看下初始化函数里面,设置波特率时用到了stm32f10x.h 里面宏(定义外部或内部晶振频率的 ...

我感觉也是波特率的问题,用示波器量波形,一位的宽度大概是130us左右,根本不是9600的波特率,但是就是找不到哪里导致波特率不准。
JnzGoto
3楼-- · 2019-12-29 04:48
 精彩回答 2  元偷偷看……
JnzGoto
4楼-- · 2019-12-29 10:23
有条件挂个晶振验证一下,9600是104us,现在是130us偏差比较大,但是又不像配错设置
deiwgah
5楼-- · 2019-12-29 13:30
JnzGoto 发表于 2017-6-13 10:02
有条件挂个晶振验证一下,9600是104us,现在是130us偏差比较大,但是又不像配错设置 ...

果然是内部晶振的问题,外挂了个8M晶振,没问题了,折腾了三天了
JnzGoto
6楼-- · 2019-12-29 15:41
deiwgah 发表于 2017-6-13 11:21
果然是内部晶振的问题,外挂了个8M晶振,没问题了,折腾了三天了

解决就好,RC一般都不太准,但是目前有许多芯片已经敢承诺内部RC1%的精度。。。

一周热门 更多>