STM32标准库移植RT-Thread nano

STM32标准库移植RT-Thread Nano

哔哩哔哩教程链接:STM32F1标准库移植RT_Thread Nano

移植前的准备

  1. stm32标准库的裸机代码(最好带有点灯和串口)
  2. RT-Thread Nano Pack
  3. 自己的开发板

移植前的说明

本人是在读学生,正在学习阶段,移植过程中,会有疏漏与不足,请有缘看到的读者指出,且敬请谅解,我会积极更改错误之处

移植步骤

在这里插入图片描述

一、打开RT-Thread文档中心作为参考: RT-Thread文档中心

二、keil上安装RT-Thread Nano Pack

1.用Keil IDE内安装RT-Thread Nano Pack(在线安装)
(1)打开Keil,选择Pack Installer ,关闭提示窗口

在这里插入图片描述

(2)打开pack,选择安装(我这里已经安装所以显示Remove)

在这里插入图片描述

2.用离线安装包安装RT-Thread Nano Pack(离线安装)
(1)下载离线包:RT-Thread Nano Pack 离线安装包
(2)离线安装(双击下载好的安装包,进行安装)

在这里插入图片描述
在这里插入图片描述
表示安装完成

三、添加内核源码

在这里插入图片描述
通过以上三个步骤,完成勾选以后,点击OK,就可以完成内核的添加,在keil目录结构中,就能够看到如下所示的内容,表示内核添加成功
在这里插入图片描述

四、删除与逻辑冲突的中断相关的函数

1.打开stm32f10x_it.c 找到相关的中断的函数

在这里插入图片描述

2.对与逻辑冲突的中断的函数,进行注释或删除

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

3.添加systick的中断函数到board.c中
void SysTick_Handler()
{rt_interrupt_enter();rt_tick_increase();rt_interrupt_leave();
}

在这里插入图片描述

五、删除RT-Thread中的部分代码,添加系统的时钟配置

1.注释或删除以下一行代码:
 #error "TODO 1: OS Tick Configuration."

在这里插入图片描述

2.添加时钟配置
SysTick_Config(SystemCoreClock / RT_TICK_PER_SECOND);

在这里插入图片描述

3.board.c中添加需要的头文件
#include "stm32f10x.h" 
#include "gpio.h"
#include "usart.h"
#include "delay.h"

在这里插入图片描述
通过以上步骤,就完成了在STM32标准库上进行RT-Thread Nano版本的移植,编译一下,0警告0错误
在这里插入图片描述

六、创建任务进行验证

1.在工程的user文件夹下,新建RT-Thread相关的头文件和源文件,并添加到工程中

在这里插入图片描述

2.编写user下的RT-Thread的源文件(我的是RT_Thread_demo.c)
(1)包含头文件
#include "stm32f10x.h" 
#include "RT_Thread_demo.h"
#include <rtthread.h>
#include "delay.h"
#include "gpio.h"
#include "usart.h"

在这里插入图片描述

(2)编写需要用到的宏定义
#define TASK1_PRIO      1                        /* 任务优先级 */
#define TASK1_STK_SIZE  128                       /* 任务堆栈大小 */
static rt_thread_t      Task1_Handler = RT_NULL;  /* 任务句柄 */
void Task1(void *pvParameters);             /* 任务函数 */#define TASK2_PRIO      2                        /* 任务优先级 */
#define TASK2_STK_SIZE  128                       /* 任务堆栈大小 */
static rt_thread_t      Task2_Handler = RT_NULL;  /* 任务句柄 */
void Task2(void *pvParameters);             /* 任务函数 */#define TASK3_PRIO      3                        /* 任务优先级 */
#define TASK3_STK_SIZE  128                       /* 任务堆栈大小 */
static rt_thread_t      Task3_Handler = RT_NULL;  /* 任务句柄 */
void Task3(void *pvParameters);             /* 任务函数 */

在这里插入图片描述

(3) 通过函数创建任务,并在main.c中调用
void RT_Thread_demo(void)
{Task1_Handler = rt_thread_create("Task1_Handler",Task1,RT_NULL,TASK1_STK_SIZE,TASK1_PRIO,20);rt_thread_startup(Task1_Handler);Task2_Handler = rt_thread_create("Task2_Handler",Task2,RT_NULL,TASK2_STK_SIZE,TASK2_PRIO,20);rt_thread_startup(Task2_Handler);Task3_Handler = rt_thread_create("Task3_Handler",Task3,RT_NULL,TASK3_STK_SIZE,TASK3_PRIO,20);rt_thread_startup(Task3_Handler);
}

在这里插入图片描述

(4) 编写任务函数
void Task1(void *parameter)
{while(1){LED1_Toggle;//printf("Task1\r\n");USART_SendString(USART1,(unsigned char*)"Task1\r\n");rt_thread_mdelay(300);}rt_thread_delay(10);
}void Task2(void *parameter)
{while(1){LED2_Toggle;//printf("Task2\r\n");USART_SendString(USART1,(unsigned char*)"Task2\r\n");rt_thread_mdelay(600);		}rt_thread_delay(10);
}void Task3(void *parameter)
{while(1){LED3_Toggle;//printf("Task3\r\n");USART_SendString(USART1,(unsigned char*)"Task3\r\n");rt_thread_mdelay(900);		}rt_thread_delay(10);
}

在这里插入图片描述

(5) 模块初始化

把用到的初始化函数都放在board.c的rt_hw_board_init 中
在这里插入图片描述
在这里插入图片描述

通过以上步骤,已经完成对RT_Thread的移植。接下来调试验证

七、移植rt_kprintf函数

1. 在rtconfig.h中修改部分代码
(1)定义 RT_USING_CONSOLE

在这里插入图片描述

(2)删除或注释 uart_init 中的部分代码并加入usart的初始化函数(board.c中)

在这里插入图片描述
在这里插入图片描述

(3)删除rt_hw_console_output部分代码并修改

在这里插入图片描述
函数修改为:

void rt_hw_console_output(const char *str)
{rt_enter_critical();while(*str != '\0')		{if(*str == '\n'){USART_SendData(RT_kprintf_USARTx,'\r');while(USART_GetFlagStatus(RT_kprintf_USARTx, USART_FLAG_TXE) == RESET);	//等待上一个字节发送完成}USART_SendData(RT_kprintf_USARTx, *str++);								//发送一个字节while(USART_GetFlagStatus(RT_kprintf_USARTx, USART_FLAG_TXE) == RESET);	//等待上一个字节发送完成}rt_exit_critical();
}

在这里插入图片描述

八、finsh组件的移植

1. 添加组件源码

在这里插入图片描述
keil的目录结构中,会出现如下文件
在这里插入图片描述

2. rtconfig.h 中打开 finsh 选项

在这里插入图片描述

3. 修改 finsh_port.c 文件
#include <rthw.h>
#include <rtconfig.h>
#include "stm32f10x.h"
#include "usart.h"#ifndef RT_USING_FINSH
#error Please uncomment the line <#include "finsh_config.h"> in the rtconfig.h 
#endif#ifdef RT_USING_FINSHRT_WEAK char rt_hw_console_getchar(void)
{int ch = -1;//查询方式实现,记得将Usart1初始化中的中断接收配置相关代码注释掉/*等待串口1输入数据*/if( USART_GetFlagStatus( RT_kprintf_USARTx, USART_FLAG_RXNE ) != RESET ){ch = ( int )USART_ReceiveData( RT_kprintf_USARTx );USART_ClearFlag( RT_kprintf_USARTx, USART_FLAG_RXNE );}else{if( USART_GetFlagStatus( RT_kprintf_USARTx, USART_FLAG_ORE ) != RESET ){USART_ClearFlag( RT_kprintf_USARTx, USART_FLAG_ORE );}rt_thread_mdelay( 10 );}return ch;
}#endif /* RT_USING_FINSH */
4. 修改串口的初始化函数
void uart1_init(uint32_t bound)
{GPIO_InitTypeDef GPIO_InitStructure;    //GPIOUSART_InitTypeDef USART_InitStructure;  //USARTNVIC_InitTypeDef NVIC_InitStructure;    //NVICRCC_APB2PeriphClockCmd(RCC_APB2Periph_USART1,ENABLE);	RCC_APB2PeriphClockCmd(RCC_APB2Periph_GPIOA,ENABLE);GPIO_InitStructure.GPIO_Pin = GPIO_Pin_9;    //USART1_TXGPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_AF_PP;	//复用推挽输出GPIO_Init(GPIOA, &GPIO_InitStructure);GPIO_InitStructure.GPIO_Pin = GPIO_Pin_10;	    //USART1_RXGPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IN_FLOATING; //浮空输入GPIO_Init(GPIOA, &GPIO_InitStructure);NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);NVIC_InitStructure.NVIC_IRQChannel = USART1_IRQn;NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority=0;//抢占优先级3NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0;		//子优先级3NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;			//IRQ通道使能NVIC_Init(&NVIC_InitStructure);USART_OverSampling8Cmd(USART1,ENABLE);USART_InitStructure.USART_BaudRate = bound;USART_InitStructure.USART_WordLength = USART_WordLength_8b;USART_InitStructure.USART_StopBits = USART_StopBits_1;USART_InitStructure.USART_Parity = USART_Parity_No;USART_InitStructure.USART_HardwareFlowControl = USART_HardwareFlowControl_None;USART_InitStructure.USART_Mode = USART_Mode_Rx | USART_Mode_Tx;	//收发模式USART_Init(USART1, &USART_InitStructure);         //初始化串口1USART_Cmd(USART1, ENABLE);                       //使能串口1
}

通过以上步骤,对RT-Thread Nano版本的移植到此结束,希望大家相互学习,相互鼓励!!!!

九、keil调试验证

详细调试步骤,请移步至哔哩哔哩视频教程:STM32F1标准库移植RT_Thread Nano

九、烧录到开发板验证

详细步骤,请移步至哔哩哔哩视频教程:STM32F1标准库移植RT_Thread Nano

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/9652.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Unity 粒子特效在UI中使用裁剪效果

1.使用Sprite Mask 首先建立一个粒子特效在UI中显示 新建一个在场景下新建一个空物体&#xff0c;添加Sprite Mask组件&#xff0c;将其的Layer设置为UI相机渲染的UI层&#xff0c; 并将其添加到Canvas子物体中&#xff0c;调整好大小&#xff0c;并选择合适的Sprite&#xff…

JVM栈溢出线上环境排查

#查看当前Linux系统进程ID、线程ID、CPU占用率&#xff08;-eo后面跟想要展示的列&#xff09; ps H -eo pid,tid,%cpups H -eo pid,tid,%cpu |grep tid #使用java jstack 查看进程id下所有线程id的情况 jstack pid 案例2 通过jstack 排查死锁问题 #启动java代码 jstack 进…

【Linux权限】—— 于虚拟殿堂,轻拨密钥启华章

欢迎来到ZyyOvO的博客✨&#xff0c;一个关于探索技术的角落&#xff0c;记录学习的点滴&#x1f4d6;&#xff0c;分享实用的技巧&#x1f6e0;️&#xff0c;偶尔还有一些奇思妙想&#x1f4a1; 本文由ZyyOvO原创✍️&#xff0c;感谢支持❤️&#xff01;请尊重原创&#x1…

(2)SpringBoot自动装配原理简介

SpringBoot自动装配 这里写目录标题 SpringBoot自动装配启动器主程序自定义扫描包SpringBootApplicationSpringBootConfigurationEnableAutoConfigurationAutoConfigurationPackageImport({AutoConfigurationImportSelector.class})选择器AutoConfigurationEntrygetCandidateCo…

计算机网络 (60)蜂窝移动通信网

一、定义与原理 蜂窝移动通信网是指将一个服务区分为若干蜂窝状相邻小区并采用频率空间复用技术的移动通信网。其原理在于&#xff0c;将移动通信服务区划分成许多以正六边形为基本几何图形的覆盖区域&#xff0c;称为蜂窝小区。每个小区设置一个基站&#xff0c;负责本小区内移…

17.Word:李楠-学术期刊❗【29】

目录 题目​ NO1.2.3.4.5 NO6.7.8 NO9.10.11 NO12.13.14.15 NO16 题目 NO1.2.3.4.5 另存为手动/F12Fn光标来到开头位置处→插入→封面→选择花丝→根据样例图片&#xff0c;对应位置填入对应文字 (手动调整即可&#xff09;复制样式&#xff1a;开始→样式对话框→管理…

Java面试题2025-并发编程基础(多线程、锁、阻塞队列)

并发编程 一、线程的基础概念 一、基础概念 1.1 进程与线程A 什么是进程&#xff1f; 进程是指运行中的程序。 比如我们使用钉钉&#xff0c;浏览器&#xff0c;需要启动这个程序&#xff0c;操作系统会给这个程序分配一定的资源&#xff08;占用内存资源&#xff09;。 …

Java创建项目准备工作

新建项目 新建空项目 每一个空项目创建好后都要检查jdk版本 检查SDK和语言级别——Apply——OK 检查当前项目的Maven路径&#xff0c;如果已经配置好全局&#xff0c;就是正确路径不用管 修改项目字符集编码&#xff0c;将所有编码都调整为UTF-8 创建Spingboot工程 创建Spring…

2007-2020年各省国内专利申请授权量数据

2007-2020年各省国内专利申请授权量数据 1、时间&#xff1a;2007-2020年 2、来源&#xff1a;国家统计局、统计年鉴 3、指标&#xff1a;行政区划代码、地区名称、年份、国内专利申请授权量(项) 4、范围&#xff1a;31省 5、指标解释&#xff1a;专利是专利权的简称&…

(一)QT的简介与环境配置WIN11

目录 一、QT的概述 二、QT的下载 三、简单编程 常用快捷键 一、QT的概述 简介 Qt&#xff08;发音&#xff1a;[kjuːt]&#xff0c;类似“cute”&#xff09;是一个跨平台的开发库&#xff0c;主要用于开发图形用户界面&#xff08;GUI&#xff09;应用程序&#xff0c;…

【C语言】main函数解析

一、前言 在学习编程的过程中&#xff0c;我们很早就接触到了main函数。在Linux系统中&#xff0c;当你运行一个可执行文件&#xff08;例如 ./a.out&#xff09;时&#xff0c;如果需要传入参数&#xff0c;就需要了解main函数的用法。本文将详细解析main函数的参数&#xff…

自创《艺术人生》浅析

艺术是生活的馈赠&#xff0c;艺术是苦痛的呻吟。 笔记模板由python脚本于2025-01-29 00:01:11创建&#xff0c;本篇笔记适合喜欢写诗读诗诵诗的coder翻阅。 【学习的细节是欢悦的历程】 博客的核心价值&#xff1a;在于输出思考与经验&#xff0c;而不仅仅是知识的简单复述。 …

二进制安卓清单 binary AndroidManifest - XCTF apk 逆向-2

XCTF 的 apk 逆向-2 题目 wp&#xff0c;这是一道反编译对抗题。 题目背景 AndroidManifest.xml 在开发时是文本 xml&#xff0c;在编译时会被 aapt 编译打包成为 binary xml。具体的格式可以参考稀土掘金 MindMac 做的类图&#xff08;2014&#xff09;&#xff0c;下面的博…

AboutDialog组件的功能和用法

文章目录 1 概念介绍2 使用方法3 示例代码 我们在上一章回中介绍了AlertDialog Widget相关的内容,本章回中将介绍AboutDialog Widget.闲话休提&#xff0c;让我们一起Talk Flutter吧。 1 概念介绍 我们在这里说的AboutDialog是一种弹出式窗口&#xff0c;和上一章回中介绍的Al…

计算机网络 IP 网络层 2 (重置版)

IP的简介&#xff1a; IP 地址是互联网协议地址&#xff08;Internet Protocol Address&#xff09;的简称&#xff0c;是分配给连接到互联网的设备的唯一标识符&#xff0c;用于在网络中定位和通信。 IP编制的历史阶段&#xff1a; 1&#xff0c;分类的IP地址&#xff1a; …

关于产品和技术架构的思索

技术架构或者设计应该和产品设计分离&#xff0c;但是又不应该和产品架构独立。 听起来非常的绕并且难以理解。 下面我们用一个例子来解读这两者的关系 产品&#xff08;族谱图&#xff09; 如果把人类当作产品&#xff0c;那设计师应该是按照上面设计的(当然是正常的伦理道德)…

第十四讲 JDBC数据库

1. 什么是JDBC JDBC&#xff08;Java Database Connectivity&#xff0c;Java数据库连接&#xff09;&#xff0c;它是一套用于执行SQL语句的Java API。应用程序可通过这套API连接到关系型数据库&#xff0c;并使用SQL语句来完成对数据库中数据的查询、新增、更新和删除等操作…

蓝牙技术在物联网中的应用有哪些

蓝牙技术凭借低功耗、低成本和易于部署的特性&#xff0c;在物联网领域广泛应用&#xff0c;推动了智能家居、工业、医疗、农业等多领域发展。 智能家居&#xff1a;在智能家居系统里&#xff0c;蓝牙技术连接各类设备&#xff0c;像智能门锁、智能灯泡、智能插座、智能窗帘等。…

Visual Studio Code修改terminal字体

个人博客地址&#xff1a;Visual Studio Code修改terminal字体 | 一张假钞的真实世界 默认打开中断后字体显示如下&#xff1a; 打开设置&#xff0c;搜索配置项terminal.integrated.fontFamily&#xff0c;修改配置为monospace。修改后效果如下&#xff1a;

开发环境搭建-4:WSL 配置 docker 运行环境

在 WSL 环境中构建&#xff1a;WSL2 (2.3.26.0) Oracle Linux 8.7 官方镜像 基本概念说明 容器技术 利用 Linux 系统的 文件系统&#xff08;UnionFS&#xff09;、命名空间&#xff08;namespace&#xff09;、权限管理&#xff08;cgroup&#xff09;&#xff0c;虚拟出一…