【正点原子STM32探索者】体验RT-Thread最新5.x版本

2024-04-23 09:12

本文主要是介绍【正点原子STM32探索者】体验RT-Thread最新5.x版本,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

【正点原子STM32探索者】体验RT-Thread最新5.x版本

    • 一、准备RT-Thread Env工具
    • 二、创建RT-Thread项目
      • 2.1 下载RT-Thread源码
      • 2.2 生成RT-Thread项目
    • 三、编译和运行RT-Thread项目
      • 3.1 编译RT-Thread项目
      • 3.2 下载程序到开发板
      • 3.3 运行RT-Thread项目
    • 四、体验RT-Thread的交互式shell
    • 五、参考链接

本位将介绍如何在正点原子STM32探索者V3开发板上运行RT-Thread 5.0.0版本,并体验交互式shell命令行操作。本文介绍的方法,同样适用于体验rt-thread最新开发版本,即github主线(master)分支版本。对于想要体验RT-Thread最新版本,或者想要参与RT-Thread开源贡献的朋友,本文值得你的阅读。

一、准备RT-Thread Env工具

RT-Thread Env工具可以用于创建RT-Thread项目,并且支持生成Keil项目文件(也支持生成RT-Thread Studio项目)。本篇将继续使用Keil作为集成开发环境,继续使用JLink作为硬件调试器。

RT-Thread Env工具下载链接:https://www.rt-thread.org/download.html#download-rt-thread-studio

下载下来是一个压缩包,加压后,运行里面的 env.bat,会打开env命令行窗口。

RT-Thread官方提供了《Env 用户手册》:https://www.rt-thread.org/document/site/#/development-tools/env/env

详细使用细节可以查阅官方手册,本文后续仅介绍这次实验用到的功能。

二、创建RT-Thread项目

2.1 下载RT-Thread源码

首先,使用git命令下载rt-thread最新版本(国内推荐从gitee下载,速度更快):

image-20230513204818234

下载完成后,可以使用git tag --list查看所有TAG:

image-20230513210255532

使用git checkout v5.0.0,切换到5.0.0发布的tag点:

image-20230513210413402

到这里,我们已经成功下载最新代码,并将代码版本切换为RT-Thread 5.0.0发布版本了。

2.2 生成RT-Thread项目

在Env命令行窗口中,首先跳转到刚刚的rt-thread源码目录,在跳转到bsp/stm32/stm32f407-atk-explorer子目录:

image-20230513210809667

然后,使用命令如下即可创建基于Keil的RT-Thread项目:

scons --dist --target=mdk --project-name=rtt_sh --project-path=PATH_YOU_WANT

PS:这里的PATH_YOU_WANT可以替换成你需要的路径;

例如,我这里创建RT-Thread项目的路径是D:\Hardware\ST\ExplorerV3_STM32F407\Elecfans_02\rtt_sh

image-20230513202916865

这里创建出来的项目是根据rt-thread bsp目录下的项目模板生成的。

生成的目录内,顶层文件目录如下:

image-20230513211839285

其中,rtt_sh.uvprojx文件即为Keil项目文件。

三、编译和运行RT-Thread项目

直接双击打开rtt_sh.uvprojx文件,默认将会启动Keil,并打开该Keil项目,如下图所示:

image-20230513212028668

3.1 编译RT-Thread项目

由于我安装的是Keil 5.37,需要先切换默认便器才可以正常编译通过。

切换默认编译器,具体操作为:

  1. 鼠标右击Project视图中的rt-thread目录,选择“Options for Target - rt-thread”,弹出菜单,如下图所示:

    image-20230513212304758

  2. 在弹出的Options for Target - rt-thread界面中,下拉ARM Compiler,选择Use default compiler version 6,即使用默认的版本6编译器;

  3. 点击底部的OK,确认。

修改完默认编译器后,点击编译图标(或者按快捷键F7进行编译),将会开始编译:

image-20230513212505313

编译完成后,Build Output将会看到Program Size信息:

image-20230513212555451

3.2 下载程序到开发板

开始下载之前,我们需要检查开发板和PC之间的连接:

  • JTAG调试器,一端插在PC的USB口上,另一端插在开发板JTAG口上,用于下载程序和断点调试;
  • USB数据线,一端插在PC的USB口上,另一端插在开发板的USB-UART口上,用于串口输入输出;

由于我使用的是JLink调试器,因此还需要修改项目的调试器设置(Keil项目默认的调试器设置是ULINK)。

修改Keil项目的调试设置,具体操作如下(这里以JLink为例):

  1. 鼠标右击Project视图中的rt-thread目录,选择“Options for Target - rt-thread”,弹出菜单,如下图所示:

    image-20230513212906957

  2. 在弹出的Options for Target - rt-thread界面中,切换到Debug标签页面,如下图所示:

    image-20230513212855244

  3. Use右边的下拉,选择J-LINK/J-TRACE Cortex,然后点击右侧的Settings,弹出Cortex JLink/JTrace Target Driver Setup界面,如下图所示:

    image-20230513213022905

    这里,我修改了Port为SW,代表使用SWD接口(JTAG也可以),Max表示最大时钟信号频率,修改为50M下载速度更快。

    看到成功识别了 ARM CoreSight JTAG-DP,说明JLINK调试器已经成功识别到主控芯片了。

  4. 切换到Flash Download标签页,勾选Reset and Run,便于调试,如下图所示:

    image-20230507231213195

  5. 最后点击确定,回到Options for Target - Blinky界面,点击OK,保存设置;

完成上述修改后,就可以进行下载了。

点击Keil中的下载按钮,或者F8快捷键,将会开始下载,如下图:

image-20230513213418585

下载完成后,Build Output窗口中可以看到下载耗时信息:

image-20230513213502762

3.3 运行RT-Thread项目

由于我们为调试器设置了 Reset and run 选项,下载完成后会自动复位开发板 运行程序。

所以如果一切正常的话,下载完成后,将可以看到开发板上的红色LED灯闪烁。

因为默认的main.c程序代码为:

image-20230513213942215

main.c代码中,

  • 首先,使用rt_pin_mode设置PF9引脚为输出;
  • 然后,循环使用rt_pin_write改变PF9引脚高低电平,再并延时500毫秒;

四、体验RT-Thread的交互式shell

RT-Thread系统提供了交互式shell,实际开发过程中,非常方便进行多种功能的调试和测试(PS:可以将每个功能的测试实现为一个命令,这样就可以通过命令测试不同功能了)。

开始体验RT-Thread的交互式shell之前,需要再次先检查USB数据线是否连接正确:

  • 一端插在PC的USB口上,另一端插在开发板的USB-UART口上

然后,在设备管理器中找到串口设备编号:

image-20230513215309170

接着,使用串口助手 sscom 或者 MobaXterm 连接到COM12设备,波特率设置为115200:

image-20230513215530552

直接敲击回车,可以看到有提示符msh>输出:

image-20230513215818800

输入version命令并回车,可以看到输出的版号为5.0.0

image-20230513215900034

输入help命令并回车,可以看到支持哪些命令:

image-20230513220027203

输入ps命令并回车,可以看到当前正在运行的任务有哪些:

image-20230513220153485

另外,可以看到5.0版本的list命令用法和4.x版本不一样了:

image-20230513220245296

4.x版本是list_threadlist_timer之类的命令,5.0都改成了list的子命令。

list thread命令和ps等同:

image-20230513220438109

五、参考链接

  1. RT-Thread Env工具下载: https://www.rt-thread.org/download.html#download-rt-thread-studio
  2. RT-Thread Env 用户手册: https://www.rt-thread.org/document/site/#/development-tools/env/env
  3. RT-Thread 5.0.0 发布声明: https://mp.weixin.qq.com/s/x9Sb3hc_GxV5VYfagGKhcA

这篇关于【正点原子STM32探索者】体验RT-Thread最新5.x版本的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/928381

相关文章

Linux卸载自带jdk并安装新jdk版本的图文教程

《Linux卸载自带jdk并安装新jdk版本的图文教程》在Linux系统中,有时需要卸载预装的OpenJDK并安装特定版本的JDK,例如JDK1.8,所以本文给大家详细介绍了Linux卸载自带jdk并... 目录Ⅰ、卸载自带jdkⅡ、安装新版jdkⅠ、卸载自带jdk1、输入命令查看旧jdkrpm -qa

Tomcat版本与Java版本的关系及说明

《Tomcat版本与Java版本的关系及说明》:本文主要介绍Tomcat版本与Java版本的关系及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Tomcat版本与Java版本的关系Tomcat历史版本对应的Java版本Tomcat支持哪些版本的pythonJ

IDEA中Git版本回退的两种实现方案

《IDEA中Git版本回退的两种实现方案》作为开发者,代码版本回退是日常高频操作,IntelliJIDEA集成了强大的Git工具链,但面对reset和revert两种核心回退方案,许多开发者仍存在选择... 目录一、版本回退前置知识二、Reset方案:整体改写历史1、IDEA图形化操作(推荐)1.1、查看提

JDK多版本共存并自由切换的操作指南(本文为JDK8和JDK17)

《JDK多版本共存并自由切换的操作指南(本文为JDK8和JDK17)》本文介绍了如何在Windows系统上配置多版本JDK(以JDK8和JDK17为例),并通过图文结合的方式给大家讲解了详细步骤,具有... 目录第一步 下载安装JDK第二步 配置环境变量第三步 切换JDK版本并验证可能遇到的问题前提:公司常

查看Oracle数据库中UNDO表空间的使用情况(最新推荐)

《查看Oracle数据库中UNDO表空间的使用情况(最新推荐)》Oracle数据库中查看UNDO表空间使用情况的4种方法:DBA_TABLESPACES和DBA_DATA_FILES提供基本信息,V$... 目录1. 通过 DBjavascriptA_TABLESPACES 和 DBA_DATA_FILES

nvm如何切换与管理node版本

《nvm如何切换与管理node版本》:本文主要介绍nvm如何切换与管理node版本问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录nvm切换与管理node版本nvm安装nvm常用命令总结nvm切换与管理node版本nvm适用于多项目同时开发,然后项目适配no

最新Spring Security实战教程之Spring Security安全框架指南

《最新SpringSecurity实战教程之SpringSecurity安全框架指南》SpringSecurity是Spring生态系统中的核心组件,提供认证、授权和防护机制,以保护应用免受各种安... 目录前言什么是Spring Security?同类框架对比Spring Security典型应用场景传统

最新Spring Security实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)

《最新SpringSecurity实战教程之表单登录定制到处理逻辑的深度改造(最新推荐)》本章节介绍了如何通过SpringSecurity实现从配置自定义登录页面、表单登录处理逻辑的配置,并简单模拟... 目录前言改造准备开始登录页改造自定义用户名密码登陆成功失败跳转问题自定义登出前后端分离适配方案结语前言

OpenManus本地部署实战亲测有效完全免费(最新推荐)

《OpenManus本地部署实战亲测有效完全免费(最新推荐)》文章介绍了如何在本地部署OpenManus大语言模型,包括环境搭建、LLM编程接口配置和测试步骤,本文给大家讲解的非常详细,感兴趣的朋友一... 目录1.概况2.环境搭建2.1安装miniconda或者anaconda2.2 LLM编程接口配置2

Mybatis从3.4.0版本到3.5.7版本的迭代方法实现

《Mybatis从3.4.0版本到3.5.7版本的迭代方法实现》本文主要介绍了Mybatis从3.4.0版本到3.5.7版本的迭代方法实现,包括主要的功能增强、不兼容的更改和修复的错误,具有一定的参考... 目录一、3.4.01、主要的功能增强2、selectCursor example3、不兼容的更改二、