1803_ChibiOS网络书籍阅读_嵌入式RTOS介绍

2023-10-05 20:39

本文主要是介绍1803_ChibiOS网络书籍阅读_嵌入式RTOS介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

         全部学习汇总: GreyZhang/g_ChibiOS: I found a new RTOS called ChibiOS and it seems interesting! (github.com)

1. RTOS指的是实时性操作系统,但是并不是只有嵌入式领域使用RTOS。然而,嵌入式是RTOS的主要使用领域。

2. 一般的RTOS有一组共同的特点:首先,都是采用了多线程单应用的模型;其次,具有确定的优先级调度模式;第三,API的处理包括了ISR。

3. 可以认为ISR也是一种线程,只是它的优先级是高于一般的线程的。

4. 一般来说,RTOS也都有一个idle task,它的任务优先级是最低的。

5. 从任务的优先级方面看,优先级有静态以及可变两种模式。

1. 中断可以触发ISR,而ISR可以唤醒任务。由此,这种处理逻辑与FreeRTOS中通过事件激活任务的方式类似。

2. 关于中断是可以分为两类的,一种是不可以用OS接口的,另一种是可以用OS接口的。这样的分类,也类似于AUTOSAR OS中的一类中断自己二类中断的分类方式。

3. 堆栈也可能有两种模式,一种是OS负责给ISR分配堆栈,另一种是ISR有专用的堆栈区。

1. Task可以认为是虚拟的CPU,有自己的寄存器组以及堆栈。之前关于这个概念了解的还不算是很透彻,自从看了一部分MIT 6.828的课程之后,对这个理念算是有了一个比较深入的理解了。

2. 作者倾向于把具有Create、Exit、Join等功能的任务叫做线程。也就是说,可能线程的概念比任务还要复杂一点。而这里的Join,看解释的信息应该就是fork以及wait的组合。

3. 这一页给出来了一个任务状态机,这个在不同的OS中都大同小异。从这个文件来看,其实作者也说了,可能这个状态机是一个标准的描述。

这里给出来了几种OS任务的分类:周期性的、非周期性的、连续的。

1. 结合上一页的末尾以及这一页的开头,通过伪代码的形式来介绍了可能的共享数据问题。

2. 比较好的设计应该从OS的角度来考虑一些行为的原子化操作而不是依赖于架构以及工具。

3. 采用关键代码保护区的方式处理共享数据问题,这通常是通过开关中断来实现的。但是这种处理方法不是很细致,应该考虑更加完善的方式。

1. 针对前面的比较简单粗暴的保护区的处理机制,进行一个改进:关中断的时候不要把全部中断都关掉,只关闭一部分。这样,可以减少因此带来的抖动。

2. 上面的方案看似不错了,但是其实有一个弊端,那就是对于多核是无效的。针对此问题,可以采用硬件信号的机制来处理。

3. 做这方面的处理的时候,需要考虑编译器代码优化所带来的影响。

4. 针对关键区域的设计,最好要兼顾几个方面:轻巧且快速、能够实现任务以及ISR的互斥。

5. 关键区的设计可能的缺点:抖动可能更大,而且不能够使用OS的API。

1. 常见的互斥信号有:计数信号量、二值信号量、互斥信号量等。

2. 优先级提升、消息、关键区等解决方案各有利弊。

3. 接下来引入了一个优先级翻转的案例,这个在其他的OS资料中也接触过了,不再仔细看了。

针对优先级翻转问题的解决方案:1. 避免互斥,但是可能不是一直可行; 2. 重排优先级,让任务可以用相邻优先级的资源,这种方式也可能效果有限;3. 互斥信号产生的时候,禁止抢占; 4. 采用优先级的天花板机制,让信号具有高于任务的优先级,获得信号的任务具有与其对等的优先级。

         1. OSEK OS等众多的OS采用了优先级天花板机制。

         2. 除了优先级天花板机制之外,其实还有一种解决方案:优先级继承机制。这样的机制,可以让使用互斥资源的任务中的资源请求任务临时获得所有资源使用任务中最高优先级的同等优先级。

         说起来,这种处理机制类似于中断保护中对中断处理的改进,只是让处理更加细腻了。

         ChibiOS采用的优先级继承的方法来实现任务优先级翻转问题的处理。

这篇关于1803_ChibiOS网络书籍阅读_嵌入式RTOS介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

JAVA智听未来一站式有声阅读平台听书系统小程序源码

智听未来,一站式有声阅读平台听书系统 🌟 开篇:遇见未来,从“智听”开始 在这个快节奏的时代,你是否渴望在忙碌的间隙,找到一片属于自己的宁静角落?是否梦想着能随时随地,沉浸在知识的海洋,或是故事的奇幻世界里?今天,就让我带你一起探索“智听未来”——这一站式有声阅读平台听书系统,它正悄悄改变着我们的阅读方式,让未来触手可及! 📚 第一站:海量资源,应有尽有 走进“智听

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了