STM8L USART串口使用

本文详细介绍了STM8L微控制器中USART串口的使用方法,包括USART1~USART5的配置,特别以STM8L052R8为例,讲解了USART1的管脚映射、初始化设置及异步读写过程。通过示例代码,读者可以了解到如何通过修改SYSCFG寄存器来选择不同的RX/TX管脚,并实现串口的开启、关闭以及读写操作。
摘要由CSDN通过智能技术生成

STM8L USART串口使用
STM8L上有多个串口,最多可达5个,分别为USART1~USART5,但依据型号不同,搭载数量并不相同。
以STM8L052R8为例,其只具有USART1~USART3。
因为STM8系列功能众多,很多Pin都是复用的,因此使用前必须检查STML的参考手册。
通过手册可知,以USART1为例,RX/TX可以使用以下的管脚,默认是PC2/PC3,
如果要变更,需要修改SYSCFG remap control register 1 (SYSCFG_RMPCR1)的5:4位进行切换。

Bits 5:4 USART1TR_REMAP[1:0]: USART1_TX and USART1_RX remapping
00: USART1_TX on PC3 and USART1_RX on PC2
01: USART1_TX on PA2 and USART1_RX on PA3
10: USART1_TX on PC5 and USART1_RX on PC6
11: Reserved

初始化:

// USART init
 USART_DeInit(USART1);  

 // PC2-RX PC3-TX 端口上拉
GPIO_ExternalPullUpConfig(GPIOC, GPIO_Pin_2 | GPIO_Pin_3, ENABLE);

 // 初始化参数
USART_Init(USART1, 
             (uint32_t)9600, 
             USART_WordLength_8b, 
             USART_StopBits_1, 
             USART_Parity_No, 
             USART_Mode_Rx | USART_Mode_Tx);  // 允许读和写

// 开中断
// 一般需要写时再开写中断,否则写中断会非常频繁以至于始终在执行中断
// 读中断看具体业务
//USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);    
 //USART_ITConfig(USART1, USART_IT_TC, ENABLE);

 /* Enable USART 使能 */
 USART_Cmd(USART1, ENABLE);

关闭串口

GPIO_ExternalPullUpConfig(GPIOC, GPIO_Pin_2 | GPIO_Pin_3, DISABLE);
 USART_Cmd(USART1, DISABLE );
 USART_ITConfig(USART1, USART_IT_RXNE, DISABLE);
 USART_ITConfig(USART1, USART_IT_TC, DISABLE);

读写处理(异步)

void uart_begin_read(uint8_t len)
{
// prepare send data
USART_ITConfig(USART1, USART_IT_RXNE, DISABLE);

 // 初始化读缓冲
read_idx = 0;
 read_len = len;

 // 开始读(开读中断)
USART_ITConfig(USART1, USART_IT_RXNE, ENABLE);

}

void uart_begin_write(uint8_t* data, uint8_t len)
{
// prepare send data
USART_ITConfig(USART1, USART_IT_TC, DISABLE);

 // 初始化写缓冲(复制待写数据等)
memcpy(writ_buffer, data, len);
 writ_idx = 0;
 writ_len = len;

 // 开始写(开写中断)
USART_ITConfig(USART1, USART_IT_TC, ENABLE);

 return;

}

中断处理

// 写中断处理
INTERRUPT_HANDLER(USART1_TX_TIM5_UPD_OVF_TRG_BRK_IRQHandler, 27)
{
// 发送1字节
USART_SendData8(USART1, writ_buffer[writ_idx++]);
USART_ClearITPendingBit(USART1, USART_IT_TC);

 // 等待缓冲数据全部写出后,关写中断
if( writ_idx == writ_len ) {
     USART_ITConfig(USART1, USART_IT_TC, DISABLE);
     // 你的处理
}

}

// 读中断处理
INTERRUPT_HANDLER(USART1_RX_TIM5_CC_IRQHandler, 28)
{
uint8_t temp = 0;

 // 读1字节,存入读缓区
temp = USART_ReceiveData8(USART1);
 read_buffer[read_idx++] = temp;

 // 等待全部读完后(如果有设定读长度的话)关读中断
// 这里根据具体业务,可以不关中断一直接受数据
if( read_idx == read_len ) {
     USART_ITConfig(USART1, USART_IT_RXNE, DISABLE);
 }

}

上面示例是异步读写,加一个状态等待的循环判断,可改为同步读写。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值