STM8 UART中断发,中断收

2020-02-14来源: eefocus关键字:STM8  UART  中断发  中断收

STM8 UART 初始化

配置STM8 UART的几个常用寄存器分别为: 

UART1_CR1:控制寄存器1 

UART1_CR3:控制寄存器3 

UART1_BRR2:波特率寄存器2 

UART1_BRR1:波特率寄存器1


利用控制寄存器1,2,3可以配置UART数据传输的具体帧格式,这里将UART配置为1个起始位,8个数据位,1个停止位,无校验位。具体操作代码如下:


      UART1_CR1=0x00;

      UART1_CR3=0x00;


在UART1_CR1中第4位,定义了数据字的长度,该位写0将设置UART为一个起始位,8个数据位,n个停止位,停止位n的数量可在UART1_CR3中设置。 

UART1_CR3的第4位和第五位用于设置停止位,这里写入00设置为1个停止位。


接下来,就是配置UART的波特率了.UART的波特率由UART的分频系数决定,波特率的计算公式为baudrate=Fmaster/UARTdiv,这里baudrate为要设置的波特率,Fmaster为主时钟频率,UARTdiv为UART分频系数。STM8上电主时钟默认使用经过8分频之后的内部16M HSI时钟源,即在不改变时钟配置的情况下,Fmaster=2MHz。 

如果要将波特率设置为9600,那么只要设置UART分频系数UARTdiv=2MHz/9600,约为:208.33333这里取整数208,其十六进制表示为0xD0,这要将这个值写入波特率寄存器中即可。


UART1_BRR2寄存器中的第0位到第3位存放了UART分频系数的第0位到第三位,UART1_BRR2寄存器中的第4位到第7位存放了UART分频系数的第12位到第15位。 

UART1_BRR1寄存器中的第0位到第7位存放了UART分频系数的第4位到第11位,


由此,我们可以得到写入波特率寄存器UART1_BRR1中的数据位0x0D,写入波特率寄存器UART1_BRR2中的数据位0x00。


另外,需要注意的是,必须先写寄存器UART1_BRR2,再写UART1_BRR1


 UART1_BRR2=0x00;

 UART1_BRR1=0x0d;


到这里就完成了对UART的配置过程,


STM8 UART 发送

对于STM8 UART发送,循环等待发送单个字节的方式这里不做详细解释。 

这里笔者利用UART的串口发送完成中断完成串口的发送过程。以提高CPU的工作效率以及降低功耗。 

首先必须要打开发送完成中断:


UART1_CR2|=(1<<7);


打开发送完成中断之后,UART会发送一个空白帧,此时在我们的中断服务处理程序中会产生一个UART发送中断,我们只需要响应这个中断,并在产生这个中断中发送我们的数据,直到所有数据发送完毕,则禁止发送中断即可。UART中断发送部分完整代码如下:


u8* UartSendBuffer;

u8 UartSendDataLength;

void UART1_SendBuffer(u8* buffer){

  UartSendBuffer=buffer;

  UartSendDataLength=strlen((const char*)buffer);

  UART1_CR2|=(1<<7);

}

#pragma vector= UART1_T_TC_vector//UART1 Tx complete 中断

__interrupt void SYS_UART1_TX_IRQHandler(void){

  u8 status=UART1_SR;

  if(status & UART_IRQ_TXE){

    if(UartSendDataLength!=0){

      UART1_DR=*UartSendBuffer;

      UartSendBuffer++;

      UartSendDataLength--;

    }else{

      UART1_CR2&=~(1<<7);

    }

  }

}


注意:笔者使用的是IAR而不是STVP,使用STVP的童鞋,需要参照代码另做修改。


STM8 UART接收

STM8 UART中断接收只需要在初始化部分使能串口接收中断,响应中断服务程序读取数据即可:


UART1_CR2|=(1<<6);

关键字:STM8  UART  中断发  中断收 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic488227.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:STM8S103F3实现串口中断接,中断发功能
下一篇:STM8L USART串口调试

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

STM8S库文件判断指定IO输入引脚电平GPIO_ReadInputPin有问题
/**  * @brief  Reads the specified GPIO input data pin.  * @param  GPIOx : Select the GPIO peripheral number (x = A to I).  * @param  GPIO_Pin : Specifies the pin number.  * @retval BitStatus : GPIO input pin status.  */BitStatus GPIO_ReadInputPin(GPIO_TypeDef* GPIOx, GPIO_Pin_Ty
发表于 2020-02-08
STM8 GPIO输入输出模式
悬浮输入悬浮输入,也叫浮空输入,顾名思义,即引脚悬空。这种方式的输入阻抗很高。当悬浮输入的引脚上加上信号时,单片机所得到的信号并不确定是高电平或是低电平,是一个不确定的信号。悬浮输入的典型应用就是模数转换,外部的任何一个小信号都要经过A/D采样转换为数字信号。上拉输入上拉就是把电位拉高,比如拉到Vcc。上拉就是将不确定的信号通过一个电阻嵌位在高电平!电阻同时起限流作用!强弱只是上拉电阻的阻值不同。上拉输入最典型的应用就是外部按键,当按键未按下时,我们要保证它是高电平,当按键按下时才被拉低。推挽输出推挽输出(Push-pull output),也称为互补输出,推拉式输出。推挽输出模式导通损耗小,效率高。在此模式下,N-MOS、P-MO
发表于 2020-02-08
STM8 GPIO输入输出模式
STM8L的USART1串口通信详解 含例程
。/****************************************************************************************开发环境:IAR for stm8 v1.40.1*硬件平台:STM8L-DISCOVERY*功能说明:每隔500ms通过PC3引脚向上位机发送一组数据。串口配置为:波特为9600,8个数据位,1个停止位,无奇偶校验。*作    者:茗风****************************************************************************************/#include"
发表于 2020-02-08
使用STM8S105K4T6C 模数转换器的12通道
分享今天遇到的一个stm8s模数转换的小问题~~~这款单片机一共提供了7个模数转换通道,他们分别是AIN0-AIN5和AIN12。stm8s105k4t6c的管脚图其中AIN0-AIN5的配置和使用方法如下,配置为连续转换、扫描模式(代码写的不好,大神请见谅~):[mw_shl_code=c,true]/*---------------------------------包含头文件---------------------------------*/#include "adc.h" #define        ADC     
发表于 2020-02-08
stm8——LED流水灯实现
最近接触并学习了一款STM8系列的芯片。以前学习了的ARM9+Linux后,再来学习单片机就感到上手很快了。 芯片基本信息:Type:STM8L151G68-bit ultralow power MCU, up to 32 KB Flash, 1 KB Data EEPROM RTC, LCD, timers, USART, I2C, SPI, ADC, DAC, comparators具体可以查看datasheet:http://pdf-file.ic37.com/pdf4/STMICROELECTRONICS
发表于 2020-02-08
MCU程序设计之STM8S的optionbytes
今天使用STM8S在程序中修改optionbyte遇到问题一直读取为0,不能进入设置流程,之前的程序今天重新修改东西,使用新的片子,原来程序如下:  AFR_TEMP = (uint16_t)((uint16_t)0x01 << 8);  AFR_TEMP = AFR_TEMP | (uint16_t)0xFE;  AFR_TEMP = (AFR_TEMP >> 8);之所以直接赋值而不调用函数,是因为程序代码空间有限,使用函数调用方法修改没有问题,如下:  AFR_TEMP = FLASH_ReadOptionByte(0X4803);  AFR_TEMP
发表于 2020-02-08
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 EEWORLD.com.cn, Inc. All rights reserved