STM32学习笔记3-串口控制台
2015-03-24 16:10
459 查看
http://blog.sina.com.cn/s/blog_7077264c0100lvwg.html
1、在STM32_Init.c中使能串口,波特率设到115200(最大只能设这么大了)。
2、USART1的寄存器跟AVR几乎相同,直接代码替换。宏定义替换
#define usart1_UDR_int_open() USART1->CR1|=USART_FLAG_TXE
//开启UDR空中断
#define usart1_UDR_int_close() USART1->CR1&=~USART_FLAG_TXE
//关闭UDR空中断
#define usart1_TX_int_open() USART1->CR1|=USART_FLAG_TC
//开启发数据中断
#define usart1_TX_int_close() USART1->CR1&=~USART_FLAG_TC
//关闭发数据中断
#define usart1_RX_int_open() USART1->CR1|=USART_FLAG_RXNE
//开启收数据中断
#define usart1_RX_int_close() USART1->CR1&=~USART_FLAG_RXNE
//关闭收数据中断
3、中断入口就一个
if ((USART1->SR&USART_FLAG_TXE)) //UDR空
{
//发送已经空了,发送下一个吧。
}
if ((USART1->SR&USART_FLAG_RXNE))
{
//接到数据了,往缓冲区放吧
}
4、FIFO
#define IN_BUF_MAX 16 //串口接收缓冲大小
#define OUT_BUF_MAX 16 //串口发送缓冲大小
typedef struct
{
U8 front; //队列头元素
U8 rear; //队列尾元素
U8 length; //队列填充长度
U8 buf[IN_BUF_MAX];
} USART_IN_BUF_TYPE; //串口接收缓冲变量类型
typedef struct
{
U8 front; //队列头元素
U8 rear; //队列尾元素
U8 length; //队列填充长度
U8 buf[OUT_BUF_MAX];
} USART_OUT_BUF_TYPE; //串口发送缓冲变量类型
传统的UART只有发送完成中断,用FIFO非常别扭,因为FIFO清空后,下次必须先写到串口,再写缓冲区才能保证,正常运行。
而有数据空中断就好多了,直接填缓冲区,一旦使能中断立即,中断启动发送。
5、控制台的代码可以参考U-boot的代码。做完后几乎与硬件无关,直接移植。
1、在STM32_Init.c中使能串口,波特率设到115200(最大只能设这么大了)。
2、USART1的寄存器跟AVR几乎相同,直接代码替换。宏定义替换
#define usart1_UDR_int_open() USART1->CR1|=USART_FLAG_TXE
//开启UDR空中断
#define usart1_UDR_int_close() USART1->CR1&=~USART_FLAG_TXE
//关闭UDR空中断
#define usart1_TX_int_open() USART1->CR1|=USART_FLAG_TC
//开启发数据中断
#define usart1_TX_int_close() USART1->CR1&=~USART_FLAG_TC
//关闭发数据中断
#define usart1_RX_int_open() USART1->CR1|=USART_FLAG_RXNE
//开启收数据中断
#define usart1_RX_int_close() USART1->CR1&=~USART_FLAG_RXNE
//关闭收数据中断
3、中断入口就一个
if ((USART1->SR&USART_FLAG_TXE)) //UDR空
{
//发送已经空了,发送下一个吧。
}
if ((USART1->SR&USART_FLAG_RXNE))
{
//接到数据了,往缓冲区放吧
}
4、FIFO
#define IN_BUF_MAX 16 //串口接收缓冲大小
#define OUT_BUF_MAX 16 //串口发送缓冲大小
typedef struct
{
U8 front; //队列头元素
U8 rear; //队列尾元素
U8 length; //队列填充长度
U8 buf[IN_BUF_MAX];
} USART_IN_BUF_TYPE; //串口接收缓冲变量类型
typedef struct
{
U8 front; //队列头元素
U8 rear; //队列尾元素
U8 length; //队列填充长度
U8 buf[OUT_BUF_MAX];
} USART_OUT_BUF_TYPE; //串口发送缓冲变量类型
传统的UART只有发送完成中断,用FIFO非常别扭,因为FIFO清空后,下次必须先写到串口,再写缓冲区才能保证,正常运行。
而有数据空中断就好多了,直接填缓冲区,一旦使能中断立即,中断启动发送。
5、控制台的代码可以参考U-boot的代码。做完后几乎与硬件无关,直接移植。
相关文章推荐
- STM32学习笔记8——串口输出数据丢失问题
- stm32学习笔记---串口(原子开发板)
- STM32学习笔记——USART串口
- STM32学习笔记 - 串口的初始设置
- STM32学习笔记-配置串口,printf重定向
- STM32学习笔记5——串口
- 通过串口实现stm32的IAP功能————stm32学习笔记
- STM32学习笔记3——怎样将整型变量转换为字符变量 然后串口 或者LCD发送出来(STM32) 以及sprintf的用法
- STM32学习笔记3——怎样将整型变量转换为字符变量 然后串口 或者LCD发送出来(STM32) 以及sprintf的用法
- STM32学习笔记-ADC采集-串口2发送至上位机
- cortex_m3_stm32嵌入式学习笔记(三):串口实验(串口通信)
- STM32学习笔记:USART串口的…
- STM32学习笔记之简易Bootloader串口升级设计
- STM32与上位机串口通讯的学习笔记(简明的数据帧设计方法)
- STM32学习笔记——USART串口(向原子哥和火哥学习)
- STM32学习笔记:串口一键下载电路(CH340)的理解
- STM32学习笔记-串口
- STM32学习笔记之-串口中断接收不定数据buff
- STM32-串口实验学习笔记
- stm32学习笔记----双串口同时打开时的printf()问题