RT-Thread与STM32CubeMX联合开发

本文介绍RT-Thread与STM32CubeMX联合开发,包括前置的软件环境,如RT-Thread Studio和STM32CubeMX。详细说明了CubeMX配置步骤,如系统配置、时钟配置、串口配置等,还提及代码生成和同步问题,最后编译烧录代码,串口正常显示则联合开发成功。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

RT-Thread与STM32CubeMX联合开发

一:前置条件

1.1软件环境

RT-Thread Studio
STM32CubeMX

上一节我们已经讲过如何安装RT-Thread Studio,
STM32CubeMX的安装参照: STM32CubeMX安装教程

二:CubeMX配置

首先我们在上一节创建好的工程下找到 CubeMX Setting,双击打开后进入配置界面
在这里插入图片描述
打开①System Core进入系统配置,②进入RCC界面使用外部时钟
在这里插入图片描述
进入Clock Configuration界面配置时钟数,我这里使用的是F407系列,时钟最高频率为168MHz,时钟频率根据你的单片机时钟频率而定
在这里插入图片描述
接着开始配置串口,由于我们在上一节使用的USART1作为rtthread日志输出,因而在CubeMX我们也打开USART1串口**(必须配置否则会最后编译会报错),波特率设置为默认的115200
在这里插入图片描述
修改代码生成方式,单独生成.c和.h文件
在这里插入图片描述
下面是重点!!!!!
由于RT-Thread系统会接管STM32相关的系统中断,也就是重定义
HardFault_Handler、PendSV_Handler、SysTick_Handler这三个中断函数,因此此过程中不需要在CubeMX的NVIC下生成相关代码,具体配置如下
在这里插入图片描述
取消勾选上述三个中断函数,然后可以点击
GENERATE CODE**生成代码
注意!!!!第一次生成代码后需要关闭CubeMX软件,否则生成的代码不会同步到RT-Thread Studio里(不知道是BUG还是什么)。
生成完毕后工程文件里会多出一个cubemx文件目录,下面我们做进一步配置
在这里插入图片描述
打开SConscript找到如下代码段

Src/main.c

在此代码段后添加

Src/gpio.c
Src/usart.c
Src/stm32f4xx_it.c

原因:CubeMX再勾选分别生成.C和.H文件后不会将main.c以外的源文件生成到工作空间内,需要我们手都配置,你配置了哪些外设就添加哪些,我们刚刚配置了GPIO,串口和中断,因此我们需要把这三个写进SConscript文件。
配置完毕后右击SConscript选择同步scons配置进项目,然后编译看看有没有报错。没有报错后我们打开cubemx/Src/main.c文件
在这里插入图片描述

// An highlighted block
__WEAK int main(void)
{
  /* USER CODE BEGIN 1 */

  /* USER CODE END 1 */

  /* MCU Configuration--------------------------------------------------------*/

  /* Reset of all peripherals, Initializes the Flash interface and the Systick. */
  HAL_Init();

  /* USER CODE BEGIN Init */

  /* USER CODE END Init */

  /* Configure the system clock */
  SystemClock_Config();

  /* USER CODE BEGIN SysInit */

  /* USER CODE END SysInit */

  /* Initialize all configured peripherals */
  MX_GPIO_Init();
  MX_USART1_UART_Init();
  /* USER CODE BEGIN 2 */

  /* USER CODE END 2 */

  /* Infinite loop */
  /* USER CODE BEGIN WHILE */
  while (1)
  {
    /* USER CODE END WHILE */

    /* USER CODE BEGIN 3 */
  }
  /* USER CODE END 3 */
}

进入main.c文件后将这段代码中的复制到application/main.c的while(1)之前

  //--------------------
  HAL_Init();
  MX_GPIO_Init();
  MX_USART1_UART_Init();

接着添加头文件

  //添加头文件
  #include "main.h"
  #include "usart.h"
  #include "gpio.h"

这里说明为什么cubemx生成的main.c文件会有一个**__WEAK** 标志,这是因为同一个工作空间下出现了两个相同的main函数,我们只需要直线applications目录下的main函数,因此需要使用__WEAK弱化掉cubemx里的main函数。
至此CubeMX移植完全结束,下面进行编译烧录代码

三:现象

串口正常显示如下则说明我们联合开发成功
在这里插入图片描述

### RT-Thread 操作系统 STM32CubeMX 工具联合开发教程 #### 项目初始化 为了启动一个新的基于RT-ThreadSTM32项目,在RT-Thread Studio环境中,需执行新建项目的流程。这涉及到选择文件菜单下的新建选项,随后指定创建的是一个基于特定微控制器型号的新工程,并完成必要的参数设定,比如命名工程项目以及挑选目标MCU种类等[^4]。 #### 配置环境准备 确保安装有适当版本的RT-Thread Studio和STM32CubeMX软件对于顺利开展工作至关重要。例如,已知兼容的一组版本组合为RTThread studio 2.2.6版配搭stm32CubeMx 6.9.0版[^3]。 #### 硬件资源分配设置 利用STM32CubeMX图形界面来规划外设功能是一项便捷的做法。可以针对具体应用场景调整GPIO引脚用途、启用定时器或是UART通信等功能模块。以简单的LED闪烁实验为例,只需简单勾选相应的GPIO端口作为输出即可满足需求。 #### 中间件集成 当考虑更复杂的外围设备接入时,如SPI闪存芯片W25Q32,则可能需要用到额外的支持库或框架。此时可以通过引入SFUD(Simple Flash Universal Driver)简化Flash存储器件的操作过程,再借助FAL(File Abstraction Layer)进一步封装成易于使用的API接口供上层调用[^5]。 ```c // 示例代码片段展示如何在应用层面访问外部Flash #include "fal.h" void write_data_to_flash(uint8_t *data, uint32_t addr, size_t len){ fal_blk_dev_write(&flash_device, addr, data, len); } uint8_t read_data_from_flash(uint8_t *buffer, uint32_t addr, size_t len){ return fal_blk_dev_read(&flash_device, addr, buffer, len); } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值