STM32F10x的串口数据发送

//=====================================================================
//TITLE:
// STM32F10x的串口数据发送
//AUTHOR:
// norains
//DATE:
// Thursday 16-September-2010
//Environment:
// NULL
//=====================================================================

串口虽然在桌面电脑领域已经慢慢淡出日常应用领域,但在嵌入式设备,特别是在调试时,却还是有着无可替代的作用。如果我们需要调试一款嵌入式设备,那么最先应该完善的就是串口,特别是能够对外发送数据。这对于STM32F10x同样也是如此。

如果要另调试串口能够正常工作,免不了要对CPU的寄存器进行一番设置。这里为了简便,直接调用了ST提供的外围驱动库STM32F10x_StdPeriph_Lib,其下载地址位于http://www.st.com/mcu/devicedocs-STM32F101RC-110.html。接下来的讲解,都是基于该lib库。

首先我们需要对串口的寄存器做初始化。这里我们选用的串口是USART1,故代码如下:
RCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1 | RCC_APB2Periph_GPIOA, ENABLE);

如果是选用别的串口,那么只需要更改相应的标识符即可。

接下来则是配置中断寄存器:

// 配置中断寄存器的优先级 NVIC_PriorityGroupConfig(NVIC_PriorityGroup_0); //初始化数据 NVIC_InitTypeDef NVIC_InitInfo; NVIC_InitInfo.NVIC_IRQChannel = USART1_IRQn; NVIC_InitInfo.NVIC_IRQChannelSubPriority = 0; NVIC_InitInfo.NVIC_IRQChannelCmd = ENABLE; //写中断寄存器 NVIC_Init(&NVIC_InitInfo);

寄存器配置完毕之后,就轮到GPIO口。其实数据的发送,本质上就是GPIO不停拉高拉低的结果,所以这里要做如下相应GPIO的设置:

//初始化数据 GPIO_InitTypeDef GPIO_InitInfo; GPIO_InitInfo.GPIO_Pin = GPIO_Pin_9; GPIO_InitInfo.GPIO_Speed = GPIO_Speed_50MHz; GPIO_InitInfo.GPIO_Mode = GPIO_Mode_AF_PP; //写寄存器 GPIO_Init(GPIOA,&GPIO_InitInfo);

配置完毕之后,就可以使能USART1了:

USART_Cmd(USART1,ENABLE);

当然默认的波特率不一定符合实际需求,遇到这种情况的时候,自然是需要相应的更改了。设置很简单,如下所示:

USART_InitTypeDef USART_InitInfo; //波特率 USART_InitInfo.USART_BaudRate = 9600; //数据位 USART_InitInfo.USART_WordLength = USART_WordLength_8b; //无奇偶校验 USART_InitInfo.USART_Parity = USART_Parity_No; //一个停止位 USART_InitInfo.USART_StopBits = USART_StopBits_1; //无流控制 USART_InitInfo.USART_HardwareFlowControl = USART_HardwareFlowControl_None; //接收发送标志 USART_InitInfo.USART_Mode = USART_Mode_Rx | USART_Mode_Tx; //更新到寄存器 USART_Init(USART1,&USART_InitInfo); USART_ITConfig(USART1,USART_IT_RXNE,ENABLE);

  代码中的宏定义都是ST的库所定义好的,它位于STM32F10x_StdPeriph_Driver/inc/stm32f10x_usart.h文件中。
  
  最后,则是发送数据。这里为了说明简便,采用函数的形式:
  
  void SendData(u8 data)   {    while (!(USART1->SR & USART_FLAG_TXE));    USART1->DR = (data & (uint16_t)0x01FF);   }
  
  循环意义很简单,它一直持续在检查发送使能标志,只有其不为0时,才将数据发送到DR寄存器,让其通过GPIO发送出去。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值