基于STM32F103的FreeRTOS系列(四)·FreeRTOS资料获取以及简介

目录

1.  FreeRTOS简介

1.1  FreeRTOS介绍

1.2  为何选择FreeRTOS

1.3  FreeRTOS资料获取

1.3.1  官网下载

1.3.2   Github下载

1.3.3  托管网站下载

1.4  FreeRTOS的编程风格

1.4.1  数据类型

1.4.2  变量名

1.4.3  函数名

1.4.4  宏


1.  FreeRTOS简介

1.1  FreeRTOS介绍

FreeRTOS是一个可裁剪的小型RTOS系统,其特点包括:

① FreeRTOS 的内核支持抢占式,合作式和时间片调度。

② SafeRTOS 衍生自 FreeRTOS,SafeRTOS 在代码完整性上相比 FreeRTOS更胜一筹。

③ 提供了一个用于低功耗的 Tickless 模式。

④ 系统的组件在创建时可以选择动态或者静态的 RAM,比如任务、消息队列、信号量、软件定时器等等。

⑤ 已经在超过 30 种架构的芯片上进行了移植。

⑥ FreeRTOS-MPU 支持 Corex-M 系列中的 MPU 单元,如 STM32F407.

⑦ FreeRTOS 系统简单、小巧、易用,通常情况下内核占用 4k-9k 字节的空间。

⑧ 高可移植性,代码主要 C 语言编写。

⑨ 支持实时任务和协程(co-routines 也有称为合作式、协同程序,我在这里使用的均成为协程)。

1.2  为何选择FreeRTOS

① 开源和免费:FreeRTOS是开源的实时操作系统,遵循MIT许可证,可以免费获取和使用。这使得它成为许多嵌入式开发者和企业的首选,特别是在成本和许可证限制方面较为敏感的项目中。

② 轻量级和高效:FreeRTOS设计精简,专注于提供基本的实时调度和任务管理功能,适合资源有限的嵌入式系统。它的内核非常小巧,具有低的内存占用和快速的上下文切换时间,能够在各种处理器架构上高效运行。

③ 广泛的架构支持:FreeRTOS支持多种处理器架构和开发板,包括ARM Cortex-M,ESP32,PIC,以及多个仿真器和开发板,这使得它在不同项目和硬件平台上都能得到广泛应用。

④ 丰富的特性和生态系统:尽管FreeRTOS本身非常轻量,但它提供了许多丰富的特性,如任务管理、消息队列、信号量、软件定时器等,可以满足大多数嵌入式系统的实时需求。同时,FreeRTOS拥有活跃的社区和丰富的生态系统,提供了许多额外的组件和驱动程序,可以加速开发过程并提供可靠的支持。

⑤ 成熟和可靠性:FreeRTOS经过多年的发展和使用,在工业和商业应用中已被广泛验证和采用,具有高度的成熟性和可靠性,适合要求高可靠性和稳定性的应用场景。

⑥ 易于学习和使用:FreeRTOS的API设计简洁清晰,易于理解和使用。它提供了详细的文档和示例,对于初学者和经验丰富的开发者都是友好的选择。

1.3  FreeRTOS资料获取

1.3.1  官网下载

官网下载链接:FreeRTOS - Market leading RTOS (Real Time Operating System) for embedded systems with Internet of Things extensionsFreeRTOS - Market leading RTOS (Real Time Operating System) for embedded systems with Internet of Things extensionsFreeRTOS - Market leading RTOS (Real Time Operating System) for embedded systems with Internet of Things extensions

手动输入链接:www.freertos.org 

1.3.2   Github下载

Github下载:GitHub - FreeRTOS/FreeRTOS: 'Classic' FreeRTOS distribution. Started as Git clone of FreeRTOS SourceForge SVN repo. Submodules the kernel.

 

1.3.3  托管网站下载

FreeRTOS - Market leading RTOS (Real Time Operating System) for embedded systems with Internet of Things extensions

        在该网站可以找到,以前发行的版本: 

        找到自己想要下载的版本,点击进入如下界面:

        其中两个文件均可下载。

注意:以上文件下载完后,我试了一下,进行解压的话,会提示文件过多,解压不了,我试了另一台电脑上面用的360解压的软件给解压出来了,然后我准备上传到百度网盘,发现由于文件过多,上传和下载速度也是非常感人。现在没有好的解决办法,后续发现好的解决办法会发到:FreeRTOS_时光の尘的博客-CSDN博客

1.4  FreeRTOS的编程风格

1.4.1  数据类型

        FreeRTOS对C语言中的一些数据类型的命名,进行了重定义,以下是部分:

1.4.2  变量名

        比如char型变量的前缀是c, short型变量的前缀是s, long型变量的前缀是1, portBASE_TYPE类型变量的前缀是x。还有其他的数据类型,比如数据结构,任务句柄,队列句柄等定义的变量名的前缀也是 x。

        如果一个变量是无符号型的那么会有一个前缀 u,如果是一个指针变量则会有一个前缀 p。因此,当我们定义一个无符号的 char 型变量的时候会加一个 uc前缀,当定义一个char型的指针变量的时候会有一个pc前缀。

1.4.3  函数名

        如果是私有的函数则会加一个prv (private)的前缀。

①vTaskPrioritySet()函数的返回值为 void型,在task.c这个文件中定义。

②xQueueReceive()函数的返回值为 portBASE_TYPE 型,在 queue. c这个文件中定义。

③vSemaphoreCreateBinary()函数的返回值为 void型,在semphr.h 这个文件中定义。

1.4.4  宏

FreeRTOS_时光の尘的博客-CSDN博客

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

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

相关文章

11. Hibernate 持久化对象的各种状态

1. 前言 本节课和大家聊聊持久化对象的 3 种状态。通过本节课程,你将了解到: 持久化对象的 3 种状态;什么是对象持久化能力。 2. 持久化对象的状态 程序运行期间的数据都是存储在内存中。内存具有临时性。程序结束、计算机挂机…… 内存中…

前端开发大屏适配几种方案

方案一:vw(单位) 假设设计稿尺寸为 1920*1080,直接使用 vw 单位,屏幕的宽默认为 100vw,那么100vw 1920px, 1vw 19.2px 。 新建px2vw.scss / 使用 scss 的 math 函数 use "sass:math&q…

Web前端浅谈ArkTS组件开发

本文由JS老狗原创。 有幸参与本厂APP的鸿蒙化改造,学习了ArkTS以及IDE的相关知识,并有机会在ISSUE上与鸿蒙各路大佬交流,获益颇丰。 本篇文章将从一个Web前端的视角出发,浅谈ArkTS组件开发的基础问题,比如属性传递、插…

hamcrest 断言框架使用示例和优势分析

引言 在软件测试领域,断言是验证代码行为是否符合预期的关键环节。Hamcrest 断言框架,以其独特的匹配器(Matcher)概念和清晰的失败信息,赢得了广泛的赞誉。尽管 Python 标准库中没有内置的 Hamcrest 库,但…

【Linux】-----工具篇(编译器gcc/g++,调试器gdb)

目录 一、gcc/g 简单认识 程序的翻译过程认识gcc 预处理(宏替换) 编译 汇编 链接 宏观认识 如何理解(核心) 什么是链接? 链接的分类 二、gdb 基本的认识 基本操作及指令 安装gdb 启动gdb ​编辑 显示源代码(list) 运行程序…

RDF蕴涵插值的详细解释

在逻辑和数学中,插值定理(Interpolation Theorem)是关于公式间蕴涵关系的一种性质。对于RDF蕴涵,插值的含义涉及在两个RDF图之间找到一个中间图,这个中间图与这两个图在语义上有某种特定的关系。 插值定理概述 在一阶逻辑中,插值定理通常表示如下: 如果一个公式 ( A …

SQL labs-SQL注入(三,sqlmap使用)

本文仅作为学习参考使用,本文作者对任何使用本文进行渗透攻击破坏不负任何责任。 引言: 盲注简述:是在没有回显得情况下采用的注入方式,分为布尔盲注和时间盲注。 布尔盲注:布尔仅有两种形式,ture&#…

带分页的el-table获取全选的勾选状态

有时候要自定义el-table的全选按钮的事件操作 用它本身全选点击事件,然后根据点击状态TRUE/FALSE来做自己的操作 select-all"handleSelectAll" handleSelectAll(){ // refpushMultipleTable 的el-table的全选点击TRUE/FALSE if(this.$refs[pushM…

学习笔记:MySQL数据库操作3

1. 创建数据库和表 创建数据库 mydb11_stu 并使用该数据库。创建 student 表,包含字段:学号(主键,唯一),姓名,性别,出生年份,系别,地址。创建 score 表&…

UE5 UE4 使用python进行编辑器操作

使用UE 4.25以上版本后,python代码改动相对较少。 如下类库在4.20/21/22等早起版本不适用,建议查询UE的python文档 unreal.EditorAssetLibrary 1.获取当前选中的资源(Content中) # 获取当前选中的资产selected_assets unreal.E…

C#、Net6、WebApi报表方案

目录 1 Pdf表单方案 1.1出现如下错误提示: 1.2 字体路径使用 2 Docx报表模板方案 2.1 pdf方案缺陷 2.2 解决方案 3 Spire.Doc报表方案 3.1 Docx方案缺陷 3.2 解决方案 4 插入复选框 5 WebApi文件流下载接口 6 软件获取方式 1 Pdf表单方案 使用【Adobe Acrobat P…

Avalonia中的附加属性

文章目录 附加属性的基本概念定义附加属性:使用附加属性:附加属性的创建定义附加属性类:实现附加属性的访问器:示例代码使用附加属性附加属性的应用场景布局和位置:数据绑定:事件处理:样式和主题:附加属性的优缺点优点:缺点:总结在Avalonia中,附加属性(Attached Pr…

python—pandas基础(2)

文章目录 列操作修改变量列筛选变量列使用.loc[](基于标签)使用.iloc[](基于整数位置)使用.filter()方法 删除变量列添加变量列 变量类型的转换Pandas 支持的数据类型在不同数据类型间转换 建立索引新建数据框时建立索引读入数据时建立索引指…

Vue---vue3+vite项目内使用devtools,快速开发!

背景 我们在前期开发时,一般使用chrome或者edge浏览器,会使用vue-devtools或react-devtools(此插件个人未使用,可百度下是否可内嵌入项目!)来审查vue项目;这个需要安转浏览器插件才可支持&…

qt 时间戳和日期时间相互转化

#include <QCoreApplication> #include <QDateTime> #include <QDebug>int main() {// 获取当前时间QDateTime currentDateTime QDateTime::currentDateTime();// 将当前时间转换为时间戳qint64 timestamp currentDateTime.toMSecsSinceEpoch();// 输出时间…

顺丰+美团测开面试经验

测开大厂面经大汇总 经验顺丰测开一面顺丰测开二面美团(一面面经)美团测开OC美团测开实习一面_see you again_排序挂美团测开 日常实习 一面美团测开面经美团测开面经 经验 面试官的有用的建议我写在下面&#xff1a; 1、多看牛客网的面经和面试题&#xff0c;把常见的面试题背…

PHP压缩打包,下载目录或者文件,解压zip文件

函数 /*** 压缩整个文件夹为zip文件* 本地需要绝对路径&#xff0c;服务器需要相对路径*/function makeZipFile($zip_path , $folder_path ) {$rootPath realpath($folder_path);$zip new ZipArchive(); // $zip->open($zip_path, ZipArchive::CREATE | ZipArchi…

使用PyTorch导出JIT模型:C++ API与libtorch实战

PyTorch导出JIT模型并用C API libtorch调用 本文将介绍如何将一个 PyTorch 模型导出为 JIT 模型并用 PyTorch 的 CAPI libtorch运行这个模型。 Step1&#xff1a;导出模型 首先我们进行第一步&#xff0c;用 Python API 来导出模型&#xff0c;由于本文的重点是在后面的部署…

【odoo17】后端py方法触发右上角提示组件

概要 在前面文章中&#xff0c;有介绍过前端触发的通知服务。 【odoo】右上角的提示&#xff08;通知服务&#xff09; 此文章则介绍后端触发方法。 内容 直接上代码&#xff1a;但是前提一定是按钮触发&#xff01;&#xff01;&#xff01;&#xff01;&#xff01; def bu…

【css】实现扫光特效

对于要重点突出的元素&#xff0c;我们经常可以看到它上面打了一个从左到右的斜向扫光&#xff0c;显得元素亮闪闪的&#xff01;类似于下图的亮光动效 关键步骤 伪元素设置position :absolute【也可以不用伪元素&#xff0c;直接创建一个absolute元素盖在上面】设置渐变line…