博客
关于我
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/

你可能感兴趣的文章
MySQL中一条SQL语句到底是如何执行的呢?
查看>>
MySQL中你必须知道的10件事,1.5万字!
查看>>
MySQL中使用IN()查询到底走不走索引?
查看>>
Mysql中使用存储过程插入decimal和时间数据递增的模拟数据
查看>>
MySql中关于geometry类型的数据_空的时候如何插入处理_需用null_空字符串插入会报错_Cannot get geometry object from dat---MySql工作笔记003
查看>>
mysql中出现Incorrect DECIMAL value: '0' for column '' at row -1错误解决方案
查看>>
mysql中出现Unit mysql.service could not be found 的解决方法
查看>>
mysql中出现update-alternatives: 错误: 候选项路径 /etc/mysql/mysql.cnf 不存在 dpkg: 处理软件包 mysql-server-8.0的解决方法(全)
查看>>
Mysql中各类锁的机制图文详细解析(全)
查看>>
MySQL中地理位置数据扩展geometry的使用心得
查看>>
Mysql中存储引擎简介、修改、查询、选择
查看>>
Mysql中存储过程、存储函数、自定义函数、变量、流程控制语句、光标/游标、定义条件和处理程序的使用示例
查看>>
mysql中实现rownum,对结果进行排序
查看>>
mysql中对于数据库的基本操作
查看>>
Mysql中常用函数的使用示例
查看>>
MySql中怎样使用case-when实现判断查询结果返回
查看>>
Mysql中怎样使用update更新某列的数据减去指定值
查看>>
Mysql中怎样设置指定ip远程访问连接
查看>>
mysql中数据表的基本操作很难嘛,由这个实验来带你从头走一遍
查看>>
Mysql中文乱码问题完美解决方案
查看>>