串口调试关于波特率的设置

,关于波特率的设置
 
在设置波特率的时候,通过写寄存器USART_BRR来实现。USART_BRR1148位为USARTDIV的整数部分,USART_BRR304位为USARTDIV的小数部分。如:
设置USART_BRR=0x01BC,则有,USARTDIV的整数部分为0x1B=27USARTDIV的小数部分为0x0C=12,转换成十进制为12/16=0.75。综上,USARTDIV=27.75
同理,如果要设置USARTDIV=25.7,则USART_BRR1140x19,其30mdi格式为0.7*16=11.2,取11,即为0x0B。综上,若要设置USART_DIV=25.7,则只需设置USART_BRR=0x19B即可。 
在初始化USART之后,发现串口并没有数据输出。初始化代码如下:
 
#include"stm32f10x.h"
#include"io_control.h"
 
 
void GPIO_Config(void);
void USART_Config(void);
 
 
int main()
{
GPIO_Config();
USART_Config();
while(1)
{
USART_SendData(USART1,0x41) ;
   LED4_OFF();
delay(800000);
LED4_ON();
delay(800000);
}
}
 
void GPIO_Config(void)
{
GPIO_InitTypeDef GPIO_Structure;
RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA|RCC_APB2Periph_GPIOC,ENABLE);
//LED-->>PC6   U1_TX-->PA9  U1_RX-->>PA10  U2_TX-->>PA2  U2_RX-->>PA3
 
 
GPIO_Structure.GPIO_Pin = GPIO_Pin_2|GPIO_Pin_9;
GPIO_Structure.GPIO_Speed = GPIO_Speed_2MHz;
GPIO_Structure.GPIO_Mode = GPIO_Mode_AF_PP;
GPIO_Init(GPIOA,&GPIO_Structure);   //USART_AFIO_Config
 
GPIO_Structure.GPIO_Pin = GPIO_Pin_3|GPIO_Pin_10;
GPIO_Structure.GPIO_Speed = GPIO_Speed_2MHz;
毕节学院图书馆GPIO_Structure.GPIO_Mode = GPIO_Mode_AF_OD;
GPIO_Init(GPIOA,&GPIO_Structure);
 
GPIO_Structure.GPIO_Pin = GPIO_Pin_6;
GPIO_Structure.GPIO_Speed = GPIO_Speed_2MHz;
GPIO_Structure.GPIO_Mode = GPIO_Mode_Out_PP;
GPIO_Init(GPIOC,&GPIO_Structure);  //LED4 Config
}
 
void USART_Config(void)
{
USART_InitTypeDef USART_Structure;
RCC_APB2PeriphResetCmd(RCC_APB2Periph_USART1,ENABLE);
USART_Structure.USART_BaudRate = 115200;
USART_Structure.USART_WordLength = USART_WordLength_8b;
USART_Structure.USART_StopBits = USART_StopBits_1;
USART_Structure.USART_Parity = USART_Parity_No;
USART_Structure.USART_Mode = USART_Mode_Rx|USART_Mode_Tx;
USART_Structure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;
USART_Init(USART1,&USART_Structure);
USART_Cmd(USART1,ENABLE);
}
对比官方代码,并没有大的区别。因此,推断是否需要配置时钟。
问题出现在void USART_Config(void)里面的时钟使能函数:RCC_APB2PeriphResetCmd(RCC_APB2Periph_USART1,ENABLE);应该更改为
RCC_APB2periphClockCmd(RCC_APB2Periph_USART1,ENABLE);
 
在使用USART_SendData()发送数组时,中国涂料论坛
void USART_SendString(USART_TypeDef* USARTx,uint8_t *point, uint16_t strlen)
{
  // Check the parameters 
生存主义
  uint16_t i;   
  // Transmit Data 
  for(i=0;i<strlen;i++)
  {
   USART_SendData(USARTx, (*point));
// USART_ClearFlag(USARTx,USART_FLAG_TC);
point++;
  }
}
USART_DR数据发送完成时,TC被置位。此时,需要读一次USART_SR状态寄存器后,再次写入USART_DR数据时,TC被自动清零。在上面的数组发送函数里面,由于没
有读USART_SR的操作,所以,如果发送数组数据时,有可能因为发送时间过快,而TC没有被清零,所以,导致数组数据发送不正确。
对其修正后如下:
 
 
void USART_SendString(USART_TypeDef* USARTx,uint8_t *point, uint16_t strlen)
{
  // Check the parameters 
  uint16_t i;   
  // Transmit Data 
  for(i=0;i<strlen;i++)
  {
   USART_SendData(USARTx, (*point));
while(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==0);
// USART_ClearFlag(USARTx,USART_FLAG_TC);
point++;
身毒丸
  }
}
事实上,因为读一次USART_SR然后再写USART_DR时,TC会自动清零,所以,USART_ClearFlag(USARTx,USART_FLAG_TC)
该语句可以不要。
由于在FW3.5的固件库里,USART_SendData()函数里面没有读USART_SR的函数:while
(USART_GetFlagStatus(USARTx,USART_FLAG_TC)==0);
所以,在连续调用USART_SENDDATA(USART1,'A')发送字符A时,同样会出现数据丢失。如:
USART_SendData(USART1,'A');
delay(1000);
USART_SendData(USART1,'B');
delay(1000);
USART_SendData(USART1,'C');
delay(1000);
加入delay1000)是为了证明数据丢失并非因为没有延时而引起的。当连续调用发送单个字符函数改成:
工频电场
USART_SendData(USART1,'A');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'B');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'C');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
数据没有丢失。因此可以推断,如果使用USART_SENDDATA()时,必须读一次USART_SR状态寄存器。这里,不适合用USART_ClearFlag(USARTx,USART_FLAG_TC)人为清零。
 
存在一个问题:
USART_SendData(USART1,'A');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'B');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'C');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'D');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'E');
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
    i=sizeof(tab);
for(k=0;k<i;k++)
{
   USART_SendData(USART1, tab[k]);
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
}
// USART_SendString(USART1,tab,sizeof(tab));
// delay(2000000);
while(USART_GetFlagStatus(USART1,USART_FLAG_TC)==0);
USART_SendData(USART1,'F');

本文发布于:2024-09-21 19:30:31,感谢您对本站的认可!

本文链接:https://www.17tex.com/xueshu/570779.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:数据   发送   没有   寄存器   丢失
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2024 Comsenz Inc.Powered by © 易纺专利技术学习网 豫ICP备2022007602号 豫公网安备41160202000603 站长QQ:729038198 关于我们 投诉建议