打印
[应用相关]

关于波特率的设置

[复制链接]
1791|8
手机看帖
扫描二维码
随时随地手机跟帖
跳转到指定楼层
楼主
shashaa|  楼主 | 2016-9-6 20:26 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
在设置波特率的时候,通过写寄存器USART_BRR来实现。USART_BRR的11:4这8位为USARTDIV的整数部分,USART_BRR的3:0这4位为USARTDIV的小数部分。如:
设置USART_BRR=0x01BC,则有,USARTDIV的整数部分为0x1B=27,USARTDIV的小数部分为0x0C=12,转换成十进制为12/16=0.75。综上,USARTDIV=27.75。
同理,如果要设置USARTDIV=25.7,则USART_BRR的11:4为0x19,其3:0为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_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++;
  }
}

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++;
  }
}
沙发
feiqi1| | 2016-9-6 20:29 | 只看该作者
当USART_DR数据发送完成时,TC被置位。此时,需要读一次USART_SR状态寄存器后,再次写入USART_DR数据时,TC被自动清零。

使用特权

评论回复
板凳
androidbus| | 2016-9-6 20:42 | 只看该作者
由于没有读USART_SR的操作,所以,如果发送数组数据时,有可能因为发送时间过快,而TC没有被清零,所以,导致数组数据发送不正确。

使用特权

评论回复
地板
litengg| | 2016-9-6 20:42 | 只看该作者
在连续调用USART_SENDDATA(USART1,'A')发送字符A时,同样会出现数据丢失吧。

使用特权

评论回复
5
qiangweii| | 2016-9-6 20:47 | 只看该作者
一些数据处理的方式很值得学习的。

使用特权

评论回复
6
shashaa|  楼主 | 2016-9-6 20:48 | 只看该作者
feiqi1 发表于 2016-9-6 20:29
当USART_DR数据发送完成时,TC被置位。此时,需要读一次USART_SR状态寄存器后,再次写入USART_DR数据时,TC ...

恩。这个是初始化代码中需要说明的。

使用特权

评论回复
7
shashaa|  楼主 | 2016-9-6 20:48 | 只看该作者
androidbus 发表于 2016-9-6 20:42
由于没有读USART_SR的操作,所以,如果发送数组数据时,有可能因为发送时间过快,而TC没有被清零,所以,导 ...

什么时候呢?

使用特权

评论回复
8
shashaa|  楼主 | 2016-9-6 20:49 | 只看该作者
litengg 发表于 2016-9-6 20:42
在连续调用USART_SENDDATA(USART1,'A')发送字符A时,同样会出现数据丢失吧。

是的 ,这方面还是很值得学习的。。

使用特权

评论回复
9
xia00| | 2016-9-6 20:55 | 只看该作者
USART1,USART_FLAG_TC)==0);放到USART_SENDDATA()函数里面,从而在USART_SENDSTRING()里面可以不要;另外,将sizeof返回的数值减1

使用特权

评论回复
发新帖 我要提问
您需要登录后才可以回帖 登录 | 注册

本版积分规则

142

主题

1494

帖子

6

粉丝