博客
关于我
rtthread使用uart外设(不需要bsp和env工具)
阅读量:664 次
发布时间:2019-03-15

本文共 1001 字,大约阅读时间需要 3 分钟。

本次练习是使用rttthread studio写uart外设驱动,文末有不用积分的例程链接,f103的sdk版本是0.1.9(在studio的包管理器那查看),导入我的例程需参考,祝君顺利。

在这里插入图片描述
图中的控制台就是调试用的终端,单片机调试常用printf(),rtthread中使用rt_kprintf(),在上图的界面配置好就可以使用PA9、PA10的串口看到如下调试用到的信息:
1、rt_kprint()调试信息
2、LOG日志信息
也可以执行finsh命令,rtt studio有一个putty终端,如下
在这里插入图片描述
上面介绍了一会终端,言归正传,怎么使用uart外设?
drv_common.c里有硬件uart初始化函数rt_hw_usart_init(),进入函数定义,将可以看到
在这里插入图片描述
for循环里面注册所有的uart外设,uart的数量由sizeof(uart_obj)/sizeof(struct stm32_uart)计算得出。
在这里插入图片描述
直接上操作方法
在这里插入图片描述
在board.h文件里增加uart2的引脚定义和 #define BSP_USING_UART2,编译即可,iic、spi外设没试过。这次学习到注册设备的过程,也是有收获的。

精力有限,没做流程图这些,望各位海涵,有问题在评论区评论,我看到会回复,一起学习和进步。

2021/2/10更新
花了一天的时间研究了一下rtthread的驱动开发方法,回去看了一下rtthread的开发文档。我上面的做法能够成功,手册中是有说到的。开发者要想学习rtthread,应该多访问
下面开始采用科学的方法重做一遍,绕了一圈最后发现,学习还是应该以手册开始,,,不说废话,直接开始。
步骤只有两步

  1. 新建rtthread完整版工程
  2. 在board.c增加打开uart外设的宏#define BSP_USING_UART1和输入输出引脚TX/RX,见下图
    在这里插入图片描述
    编译下载,即可验证,我总结一下:rtthread的自动化实现机制就跟stm32的标准库配置stm32_xxxx_hal_config.h文件一样,需要什么功能就使能对应的宏,本例中使用的方法就是#define BSP_USING_UART2这个宏,再有两个TX/RX引脚配置的宏就大功告成。
    效果如下,我将rttread编程手册里的uart的外设的例子代码敲写进main.c文件里,PA2\PA3连接串口转USB。效果如下:
    在这里插入图片描述

转载地址:http://nphmz.baihongyu.com/

你可能感兴趣的文章
mysqldump备份时忽略某些表
查看>>
mysqldump实现数据备份及灾难恢复
查看>>
mysqldump数据库备份无法进行操作只能查询 --single-transaction
查看>>
mysqldump的一些用法
查看>>
mysqli
查看>>
MySQLIntegrityConstraintViolationException异常处理
查看>>
mysqlreport分析工具详解
查看>>
MySQLSyntaxErrorException: Unknown error 1146和SQLSyntaxErrorException: Unknown error 1146
查看>>
Mysql_Postgresql中_geometry数据操作_st_astext_GeomFromEWKT函数_在java中转换geometry的16进制数据---PostgreSQL工作笔记007
查看>>
mysql_real_connect 参数注意
查看>>
mysql_secure_installation初始化数据库报Access denied
查看>>
MySQL_西安11月销售昨日未上架的产品_20161212
查看>>
Mysql——深入浅出InnoDB底层原理
查看>>
MySQL“被动”性能优化汇总
查看>>
MySQL、HBase 和 Elasticsearch:特点与区别详解
查看>>
MySQL、Redis高频面试题汇总
查看>>
MYSQL、SQL Server、Oracle数据库排序空值null问题及其解决办法
查看>>
mysql一个字段为空时使用另一个字段排序
查看>>
MySQL一个表A中多个字段关联了表B的ID,如何关联查询?
查看>>
MYSQL一直显示正在启动
查看>>