RT Thread + CLion环境搭建

2024-05-15 00:36
文章标签 搭建 环境 thread clion rt

本文主要是介绍RT Thread + CLion环境搭建,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

RT Thread + CLion环境搭建

  • 0.前言
  • 一、准备工具
    • 1. Env + RT Thread v5.1
    • 2.CLion安装
    • 3.编译及下载工具
  • 二、新建Env工程
  • 三、CLion配置
  • 四、运行测试


0.前言

  事情的起因是最近在使用RT Thread Studio时,发现默认的 rtt 内核版本及交叉编译链版本都过于陈旧,于是手动升级到了rtt 5.1和gcc-10,结果在studio内新建工程报了大量错误和警告,查找了一些帖子对这些错误进行了修改,虽然最后能够顺利编译,但是考虑到每次新建工程都需要如此繁琐的步骤,并且依然存在一些问题(比如基本的reboot命令都无法识别),所以决定换用Env工具。
  Env的缺点就是目前只能基于BSP来新建工程,如果没有适配对应的芯片,使用起来会比较麻烦,不过就目前来看,已适配的BSP应该足够DIY玩家使用了。在网上搜索了一下,目前大部分都是使用Env + Keil的开发方式,也有使用VScode的,不过使用VSCode + Studio插件的居多,且鉴于这些工具或是IDE风格太旧,或是插件配置比较繁琐,所以笔者参考之前STM32CubeIDE + CLion的帖子,摸索着搭建了RT Thread Env + CLion的开发环境,实际使用起来也确实很方便,感兴趣的读者也可以尝试使用此方式。

一、准备工具

1. Env + RT Thread v5.1

Env工具:https://github.com/RT-Thread/env
RT Thread:https://github.com/RT-Thread/rt-thread/tree/v5.1.0

此部分的安装笔者就不详细赘述了,由于笔者之前安装过python、git等工具,所以也不清楚哪些是必要依赖,可以自行站内搜索或参考RTT官网,能够使用鼠标右键打开ConEmu Here命令行就算成功。

2.CLion安装

此部分可以参考视频:https://www.bilibili.com/video/BV1Vd4y1t7aJ,2024.05测试仍有效。

3.编译及下载工具

CLion中需要添加以下工具链来进行编译和下载:
注:这些工具链只需要下载对应的Release压缩包即可,亲测不需要添加到windows系统环境变量,只用在CLion中指定工具路径即可。

1.cmake:https://cmake.org/download/ (下载Binary distributions版本的windows压缩包)
2.gcc-arm-none-eabi-gcc:https://developer.arm.com/downloads/-/gnu-rm
3.mingw64:https://github.com/niXman/mingw-builds-binaries/releases
注:此工具用于CLion的默认编译配置,编译一些x86平台的代码可以用,这里添加此工具,主要用来部署默认C\C++环境,提供代码提示及跳转等功能。i686-xxxx-release-win32-dwarf-rt-v10-rev3.7z为32位,x86_64-xxxx-release-win32-seh-rt_v10-rev3.7z为64位。
4.openocd:https://gnutoolchains.com/arm-eabi/openocd/ (用来调试程序)

下载完成后解压,将文件夹名称改的方便一点并存放到一个合适的路径:
在这里插入图片描述

二、新建Env工程

  在RT Thread内核目录下的bsp目录中,找到与自己使用的芯片相同的开发板,笔者使用的是STM32F103RCT6,就以stm32f103-yf-ufun这个开发板为例。右键此目录,并选择ConEmu Here打开Env命令行:
在这里插入图片描述
输入scons --dist命令,即可在本目录下生成一个模板工程,将此模板拷贝到合适的位置并保存,后续就可以基于此工程进行开发:
在这里插入图片描述
在这里插入图片描述

三、CLion配置

  这里笔者将project工程拷贝,并复制了一份作为第一个demo示例,右击此文件夹,选择ConEmu Here打开命令行,输入scons --target=cmake即可创建CMake工程:
在这里插入图片描述
在这里插入图片描述
再使用CLion打开此工程目录,首次打开时,可以先修改编译结果的保存目录,到项目更目录的build目录下,方便后续管理,如果有弹窗提示配置工具链,可以先直接关闭,稍后一起配置。
在这里插入图片描述
点击CLion左上角的文件 --> 设置,在工具链选项中,新建一个工具链配置,将下载的相关工具链路径填入:
在这里插入图片描述
点击项目右上角的编译配置,新建一个配置:
在这里插入图片描述
在这里插入图片描述
这个面板配置文件可以在openocd目录下的share\openocd\scripts\board找到一些芯片的配置,如果没有自己需要的话,可能需要自行搜索一下,这里笔者使用的STM32F103RCT6没有找到对应的配置文件,所以在st_nucleo_f103rb.cfg基础上进行了修改,该配置文内容如下:

# SPDX-License-Identifier: GPL-2.0-or-later# This is an ST NUCLEO F103RB board with a single STM32F103RBT6 chip.
# http://www.st.com/web/catalog/tools/FM116/SC959/SS1532/LN1847/PF259875source [find interface/stlink.cfg]transport select hla_swdsource [find target/stm32f1x.cfg]#reset_config srst_only

可以看到该配置是通过st-link烧录,使用的最终配置文件是stm32f1x.cfg(猜测同系列用的应该差不多),最后一行应该是和烧录后重启相关的配置,笔者查了一些帖子说是要注释掉比较好(注释后能正常运行,所以没有和不注释作对比),配置完这些后就可以通过CLion进行编译、烧录和debug:
在这里插入图片描述
注:由于Env生成的项目,默认生成的是rtthread.elf和rtthread.bin文件,所以如果想生成hex文件,需要手动修改CMakeLists.txt中的规则,在项目顶层的CMakeLists.txt中添加如下命令:

ADD_CUSTOM_COMMAND(TARGET ${CMAKE_PROJECT_NAME}.elf POST_BUILD
COMMAND ${CMAKE_OBJCOPY} -O ihex ${CMAKE_PROJECT_NAME}.elf ${CMAKE_PROJECT_NAME}.hex COMMAND ${CMAKE_SIZE} ${CMAKE_PROJECT_NAME}.hex)

在这里插入图片描述
此规则会在每次重新项目时被覆盖,所以每次需要手动添加,如果有更好的方法欢迎读者指正。生成的二进制文件就在项目目录下的build文件夹中。

四、运行测试

烧录:
在这里插入图片描述
调试:
在这里插入图片描述
唯一的不足,烧录和调试时的打印信息是红色的,总给人一种下载失败的错觉。不过瑕不掩瑜,写起代码确实很舒服,还能使用一些ai代码插件,还是挺不错的,感兴趣的读者可以试试。

这篇关于RT Thread + CLion环境搭建的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

阿里开源语音识别SenseVoiceWindows环境部署

SenseVoice介绍 SenseVoice 专注于高精度多语言语音识别、情感辨识和音频事件检测多语言识别: 采用超过 40 万小时数据训练,支持超过 50 种语言,识别效果上优于 Whisper 模型。富文本识别:具备优秀的情感识别,能够在测试数据上达到和超过目前最佳情感识别模型的效果。支持声音事件检测能力,支持音乐、掌声、笑声、哭声、咳嗽、喷嚏等多种常见人机交互事件进行检测。高效推

搭建Kafka+zookeeper集群调度

前言 硬件环境 172.18.0.5        kafkazk1        Kafka+zookeeper                Kafka Broker集群 172.18.0.6        kafkazk2        Kafka+zookeeper                Kafka Broker集群 172.18.0.7        kafkazk3

安装nodejs环境

本文介绍了如何通过nvm(NodeVersionManager)安装和管理Node.js及npm的不同版本,包括下载安装脚本、检查版本并安装特定版本的方法。 1、安装nvm curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.0/install.sh | bash 2、查看nvm版本 nvm --version 3、安装

【IPV6从入门到起飞】5-1 IPV6+Home Assistant(搭建基本环境)

【IPV6从入门到起飞】5-1 IPV6+Home Assistant #搭建基本环境 1 背景2 docker下载 hass3 创建容器4 浏览器访问 hass5 手机APP远程访问hass6 更多玩法 1 背景 既然电脑可以IPV6入站,手机流量可以访问IPV6网络的服务,为什么不在电脑搭建Home Assistant(hass),来控制你的设备呢?@智能家居 @万物互联

高并发环境中保持幂等性

在高并发环境中保持幂等性是一项重要的挑战。幂等性指的是无论操作执行多少次,其效果都是相同的。确保操作的幂等性可以避免重复执行带来的副作用。以下是一些保持幂等性的常用方法: 唯一标识符: 请求唯一标识:在每次请求中引入唯一标识符(如 UUID 或者生成的唯一 ID),在处理请求时,系统可以检查这个标识符是否已经处理过,如果是,则忽略重复请求。幂等键(Idempotency Key):客户端在每次

pico2 开发环境搭建-基于ubuntu

pico2 开发环境搭建-基于ubuntu 安装编译工具链下载sdk 和example编译example 安装编译工具链 sudo apt install cmake gcc-arm-none-eabi libnewlib-arm-none-eabi libstdc++-arm-none-eabi-newlib 注意cmake的版本,需要在3.17 以上 下载sdk 和ex

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

跨系统环境下LabVIEW程序稳定运行

在LabVIEW开发中,不同电脑的配置和操作系统(如Win11与Win7)可能对程序的稳定运行产生影响。为了确保程序在不同平台上都能正常且稳定运行,需要从兼容性、驱动、以及性能优化等多个方面入手。本文将详细介绍如何在不同系统环境下,使LabVIEW开发的程序保持稳定运行的有效策略。 LabVIEW版本兼容性 LabVIEW各版本对不同操作系统的支持存在差异。因此,在开发程序时,尽量使用

Go Playground 在线编程环境

For all examples in this and the next chapter, we will use Go Playground. Go Playground represents a web service that can run programs written in Go. It can be opened in a web browser using the follow

Thread如何划分为Warp?

1 .Thread如何划分为Warp? https://jielahou.com/code/cuda/thread-to-warp.html  Thread Index和Thread ID之间有什么关系呢?(线程架构参考这里:CUDA C++ Programming Guide (nvidia.com)open in new window) 1维的Thread Index,其Thread