鉴源论坛·观擎丨浅谈操作系统的适航符合性(下)

news2024/11/27 13:45:14

作者 | 蔡喁 上海控安可信软件创新研究院副院长

版块 | 鉴源论坛 · 观擎

社群 | 添加微信号“TICPShanghai”加入“上海控安51fusa安全社区”

在浅谈操作系统的适航符合性(上)中,详细介绍了民用飞机操作系统的研制现状及其适航要求,重点分析了当前满足适航要求的嵌入式操作系统研发的主要难点。本篇将展开讨论降低民机机载操作系统适航风险的具体方法。

04

机载嵌入式操作系统的适航路径

由于上面的这些问题,在民用飞机机载软件中使用的嵌入式操作系统,既要考虑高效的表明适航符合性,也需要能够实现对底层硬件的有效封装,方便应用软件的开发,真正发挥使用操作系统的便捷。通常,民机机载操作系统往往采用以下几个方法降低适航风险。

4.1 严格控制接口数量和类型

民机机载操作系统作为民用飞机功能的提供者,与民用飞机整体设计理念一脉相承,其首要思路就是功能严格按照需求和依据应用场景要求开发。民用飞机上每一克重量每一处设计都突出坚决不包含无用功能的概念。机载软件以及其操作系统,往往也会严格控制无用的功能和组件。这不仅仅是减少重量和功耗成本,也是为了减少不必要的安全影响,降低适航取证以及维护等成本的必然选择。

某国外民机机载操作系统厂商曾如此向笔者描述其提供的API范围,其所在的公司为了提供完美的机载嵌入式操作系统,他们精简了原先高安全性操作系统(非民机版本)中约95%的函数以及相应的代码。可见,“精简”是民机机载操作系统厂商的普遍选择。

4.2 针对性适配硬件对象

近些年来,操作系统规模越来越大,除了固化大量常用的操作以外,对各种不同类型的硬件提供适配也是原因之一。为了快速方便的适配,势必需要准备或者囊括各种不同类型的底层库,包括硬件抽象、底层接口库等。根据民机适航符合性的原则,所有装机代码都是机载软件审查对象。操作系统提供方或者机载功能的开发单位势必需要按照DO-178B/C标准表明这些库的符合性。不论这些库是否作为操作系统一部分提供,往往都会带来安全分析的压力以及适航取证的成本。因此,国外典型的民机机载嵌入式操作系统往往严格限定所适配的硬件对象,减少不必要的投入以及鉴定系统交付文件的复杂性。也有部分民机操作系统将硬件适配活动交由应用开发单位自己完成,这也无形中增加了操作系统使用的难度和成本。

4.3 完整的生命周期过程和数据

实现机载操作系统的顺利取证,研制单位必须完整地掌握其中所有的软件组件的详细设计数据。具有从需求、设计到代码乃至编译方法在内的全套技术细节。能够对其开展满足适航要求的系统设计和完整验证工作。往往对于其中采用的第三方或历史系统组件,需要有能力完成逆向工程并以此为起点完善相应的生命周期过程和数据。

4.4 提供典型场景示例以及适航鉴定数据包

作为面向民机功能开发的底层模块,操作系统研制单位必须能理解应用单位的使用场景,并且提供尽可能多的符合性证据支持,帮助应用开发单位降低后续开发和取证成本。为此,除了通常的操作系统手册文件外,一般还需为后续应用单位取证活动准备相应的鉴定数据包。数据包除包含需求、设计、代码等生命周期数据以备适航评审以外,通常还包括针对典型应用场景的性能分析数据等。

05

飞蜻操作系统

华东师范大学软件工程学院与上海控安共同开发的飞蜻(FlyLite)操作系统,取轻快飞行之意,目标是尽量减少国内企业适航软件的开发成本和周期。是国内首个贯彻上述思路,面向民用飞机低成本研发而打造的轻量级操作系统。该系统按照RTCA DO-178C A级软件要求开发。

8411.png

图1 飞蜻FlyLite操作系统

研制团队完整地定义了操作系统的接口和服务需求,实现了详细设计和代码开发。通过基于需求的测试完成了对需求和结构的覆盖。为确保操作系统本身广泛的适用性以及后续对不同类型机载软件的快速适配,同时保证应用软件的可移植性,操作系统接口按照POSIX标准开发,对标准中某些细节进行了完善。通过自研的测试覆盖分析工具,以及在开源平台上搭建的需求和过程管理工具,项目团队实现了低成本的软件生命周期环境构架,确保研制过程具有完整的生命周期过程数据记录。

8412.png

图2 飞蜻目标架构

为避免过多硬件适配可能带来的问题,飞蜻操作系统针对STM32L496以及某国产处理器为硬件对象,实现了接口层以下全面的适航符合性证据数据包的规划。为了确保数据的完整性,项目团队重新筛选并开发了Libc和Libm库,避免了底层软件中的不透明问题。最大程度地减少了取证风险。此外,针对应用单位可能在后续集成和验证过程中可能的软件分析工作,飞蜻操作系统还在其研发过程中引入了形式化性能分析以及调度特性建模仿真技术,方便应用单位在后期引入针对关键性能指标的模型仿真。

8413.png

图3 调度特性建模仿真

作为一种低成本轻量级操作系统,飞蜻主要应用场景包括轻量级适航应用软件开发。此类软件功能相对简单,经常无需包含分区等复杂操作,然而对研制周期和研发成本较为敏感。飞蜻操作系统能够通过定义的用户开发限定场景指导和帮助研制单位减少底层适配和举证的时间和人力成本,快速搭建满足适航要求的机载应用。

8414.png

图4 轻量级适航应用开发

此外,针对部分包括无人机以及eVOTL等非传统民机应用,通过飞蜻操作系统满足A级软件要求且应用开发快速的优势,可方便快速地搭建高等级应用的备份/冗余通道,配合相关的安全性设计和架构设计,降低原先主控通道的研制级别,最终实现快速交付和取证。

8415.png

图5 快速构建高级别冗余通道

后续,项目团队将重点针对简单非分区机载高安全应用、复杂机载应用的备份通道等应用场景开展操作系统的适配,进一步服务国产民机设备产业,让国产机载系统轻快地飞行。

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

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

相关文章

【雕爷学编程】Arduino动手做(197)---零知 STM32F103RBT6 标准开发板2

37款传感器与模块的提法,在网络上广泛流传,其实Arduino能够兼容的传感器模块肯定是不止37种的。鉴于本人手头积累了一些传感器和执行器模块,依照实践出真知(一定要动手做)的理念,以学习和交流为目的&#x…

SAP ABAP元素域值描述通过函数(DD_DOMVALUE_TEXT_GET)获取

代码如下&#xff1a; PERFORM FRM_GET_DOMVALUE_TEXT USING ZMMD_ZFLZQ <GFS_DATA>-ZFLZQ CHANGING <GFS_DATA>-ZZQTEXT .IF <GFS_DATA>-ZXYLX IS NOT INITIAL .PERFORM FRM_GET_DOMVALUE_TEXT USING ZMMD_ZXYLX <GFS_DATA>-ZXYLX CHANGING <GFS_…

matlab使用教程(11)—创建随机数

MATLAB 使用算法来生成伪随机数和伪独立数。这些数在数学意义上并非严格随机和独立的&#xff0c;但它们能够通过各种随机和独立统计测试&#xff0c;并且其计算可以重复&#xff0c;方便用于测试或诊断目的。 rand 、 randi 、 randn 和 randperm 函数是创建随机数数组的主要…

C++核心编程:C++中的引用

C中的引用 引用的基本语法 作用&#xff1a;给变量起别名 语法&#xff1a;数据类型 & 别名 原名 //比如给一个int变量a命名一个别名 b int &b a;b 20; cout<< a << endl;//a 20引用的注意事项 引用必须初始化 int &b;//错误的引用在初始化后&…

美国超导:一家第四次工业革命中的小型成长型公司

来源&#xff1a;猛兽财经 作者&#xff1a;猛兽财经 总结: &#xff08;1&#xff09;在韩国研究人员宣布发现首个常压室温超导体LLK-99这个潜在的革命性化合物,并大肆宣传后&#xff0c;美国超导(AMSC)的股票暴涨了60%。 &#xff08;2&#xff09;美国超导是一家专门从事超…

13 Java 多线程见的通信 volatile synchronized,Java多线程等待通知机制, ThreadLocal的使用

volatile synchronized ThreadLocal 线程间的通信 volatile synchronizedvolatile和synchronized关键字线程等待/通知机制ThreadLocal的使用 线程间的通信 volatile synchronized 线程开始运行&#xff0c;拥有自己的栈空间&#xff0c;就如同一个脚本一样&#xff0c;按照既定…

揭秘无人机在水利行业中如何应用

无人机的应用已经成为现代科技的重要组成部分&#xff0c;在水利行业中&#xff0c;无人机的应用同样发挥了极其重要的作用。无人机在水利行业中的应用&#xff0c;不仅提高了工作效率&#xff0c;还极大地降低了人力和物力成本&#xff0c;为水利工作注入了新的活力。 一、无人…

git clone 报错Filename too long

1.使用git clone代码&#xff0c;爆出Filename too long错误 2.原因分析 因为我很少看git clone日志&#xff0c;所以从未想过是clone异常&#xff0c;而且也看到代码clone下来了&#xff0c;所以我就显然以为代码clone成功&#xff0c;但是使用idea打开代码后发现大量代码无法…

字符函数、字符串函数、内存函数

目录 求字符串长度&#xff1a; size_t strlen ( const char * str ); 无长度限制的字符串函数 字符串拷贝&#xff1a; char * strcpy ( char * destination, const char * source ); 字符串追加&#xff1a; char * strcat ( char * destination, const char * source ); 字…

COSV Schema 1.0正式对外发布,棱镜七彩参与制定工作

近期&#xff0c;CCF版开源漏洞信息描述规范COSV Schema 1.0正式制定并对外发布&#xff0c;棱镜七彩参与制定工作。 图 COSV Schema 1.0制定过程贡献单位及专家名单 作为开源软件治理与软件供应链安全领域的先行者&#xff0c;棱镜七彩一直致力于提升开源效能、防范开源漏洞。…

源码分析——LinkedList源码分析

文章目录 1.LinkedList简介2.内部结构分析3.LinkedList源码分析3.1构造方法3.2add方法3.3根据位置取数据的方法3.4根据对象得到索引的方法3.5检查链表是否包含某对象的方法&#xff1a; 1.LinkedList简介 LinkedList是一个实现了List接口和Deque接口的双端链表。 LinkedList底…

2024考研408-计算机网络 第五章-传输层学习笔记

文章目录 前言一、传输层提供的服务1.1、传输层的功能1.2、传输层的两个协议&#xff08;TCP、UDP&#xff09;1.3、传输层的寻址与端口&#xff08;常见端口介绍&#xff09; 二、UDP协议2.1、认识UDP功能和特点2.2、UDP首部格式2.3、UDP伪首部字段分析2.4、伪首部校验UDP用户…

Unity 基础函数

Mathf&#xff1a; //1.π-PI print(Mathf.PI); //2.取绝对值-Abs print(Mathf.Abs(-10)); print(Mathf.Abs(-20)); print(Mathf.Abs(1)); //3.向上取整-Ce il To In t float f 1.3f; int i (int)f; …

无人机光伏巡检系统的全新作用解析,提升效率保障安全

随着光伏发电行业的快速发展&#xff0c;光伏电站的规模越来越大&#xff0c;光伏维护和巡检成为一个巨大的挑战。为解决传统巡检方法的低效率和安全风险问题&#xff0c;无人机光伏巡检系统应运而生&#xff0c;并成为提升光伏巡检效率和保障安全的利器。 首先&#xff0c;无人…

我的Python教程:使用Pyecharts画关系节点图

示例源码1 from pyecharts import options as opts from pyecharts.charts import Graphnodes [{"name": "结点1", "symbolSize": 10},{"name": "结点2", "symbolSize": 20},{"name": "结点3&qu…

【泊松过程数学公式推导】

latex常见用法如下&#xff1a;https://blog.csdn.net/ViatorSun/article/details/82826664 高等教育出版社 **浙江大学《概率论与数理统计》**一 书关于泊松过程的推导如下&#xff1a; 理解了上面的思路才能更好的理解泊松过程的数学模型和本质。 上面的思路是&#xff1a; …

【LeetCode 75】第二十二题(1657)确定两个字符串是否接近

目录 题目: 示例: 分析: 代码运行结果: 题目: 示例: 分析: 给我们两种操作,问我们可不可以通过两种操作将word1转变成word2. 第一种操作是交换两个现有字符的位置. 那么这就意味着,只要word1和word2有相同的字符并且相同字符的数量一致,那么word1就能通过交换位置来转变…

Shiro是什么?为什么要用Shiro?

前言 本文小新为大家带来 Shiro入门概述 相关知识&#xff0c;具体内容包括Shiro是什么&#xff0c;为什么要用 Shiro&#xff0c;Shiro与Spring Security 的对比&#xff0c;Shiro的基本功能&#xff08;包括&#xff1a;基本功能框架&#xff0c;功能简介&#xff09;&#x…

org.springframework.beans.factory.UnsatisfiedDependencyException:

今天碰到了一个数据库表中有2个主键&#xff0c;结果利用mp生成的po类&#xff0c;出现了一系列问题&#xff0c;报了这个错误&#xff0c;一看是这个实体类自带了2个filedId注解&#xff0c;运行springboot能不报错吗&#xff1f;报错信息挺有意思的&#xff0c;所以写了这篇博…

服务器时钟同步

服务器时钟同步 文章目录 服务器时钟同步背景windows时钟同步Linux机器上的时钟同步Centos时钟同步Ubuntu系统时钟同步 查看是否同步的命令 背景 运维&#xff0c;XXX服务器慢了2秒&#xff0c;导致XXX业务没有正常执行&#xff0c;请立即排查为啥会有时钟不同步的问题。 首先…