QNX操作系统及网络设备驱动模块

article/2025/1/16 2:02:44

QNX是业界公认的X86平台上最好的嵌入式实时操作系统之一。它具有独一无二的微内核实时平台,建立在微内核和完全地址空间保护基础之上,实时、稳定、可靠,已经完成到PowerPC、MIPS、ARM等内核的移植,成为在国内广泛应用的嵌入式实时操作系统。本文简单介绍QNX内核和网络结构的特点,针对目前热门的网络应用环境,讨论QNX网络设备驱动程序的结构和编写。

1 QNX内核简介

QNX的微内核结构是它区别于其它操作系统的显著特点。目前嵌入式系统中,操作系统和应用程序之间的关系大概可以归纳为图1~图3所示的三种情况。

平板式内存结构,如图1所示,所有的程序都使用同一个地址空间,不加保护;应用程序可以自由访问所有空间,效率较高,但是任何应用程序指针错误都可能会导致内核崩溃。

大内核内存结构,如图2所示,操作系统内核和各种驱动程序、网络协议在同一个地址空间,应用程序在单独空间;内核模块同处于一个保护空间,运行效率高,应用程序无法直接访问保护空间,系统稳定性大大提高。缺点是,由于内核模块(例如网络驱动)处于保护空间,因此调试困难,任何驱动程序的修改都要重新编译内核,无法做到驱动的动态加载和卸载。

QNX的微内核结构,如图3所示,内核独立自处于一个被保护的地址空间;驱动程序、网络协议和应用程序处地程序空间中。

微内核结构的优点:①驱动程序、网络协议、文件系统等操作系统模块和内核相互独立,任何模块的故障都不会导致内核的崩溃;②驱动程序、网络协议、文件系统和应用程序都处于程序空间,都调用相同的内核API,开发与调试和应用程序没有区别;③操作系统功能模块可以根据需要动态地加载或卸载,不需要编译内核。在高可靠性要求的情况下,可以编写监视模块,对可靠性要求高的模块进行监视,必要的时候重新启动或重新加载而无须重启系统。高可靠性的内核结构使QNX具备了高可靠性嵌入式操作系统的本质特征。

在具有高可靠性内核的基础上,QNX的创新设计使它同样具有很高的效率。QNX最为引人注目的地方是,它是UNIX的同胞异构体,保持了和UNIX的高度相似性,绝大多数UNIX或LINUX应用程序可以在QNX下直接编译生成。这意味着为数众多的稳定成熟的UNIX、LINUX应用可以直接移植到QNX这个更加稳定高效的实时嵌入式平台上来。

2 QNX网络结构

QNZ网络子系统由三个部分组成:网络管理模块(io-net)、网络协议模块(npm-qnet.so、npm-tcpip.so)、网络设备驱动模块(devn-ne2000.so)。

模块之间的层次关系如图4所示。

图4中的每个模块各自具有不同的功能,但是它们具有一些相同的属性。如:网络设备驱动、TCP/IP协议栈分别对上层io-net模块和应用程序产生数据,两者都可以被看作数据源;同时它们也接受上层发来的数据,又可以同时被看作数据的消费者。过滤模块对向上的数据进行筛选,分协议进行处理;对向下的数据则进行相应的转换,如进行网络地址转换NAT。转换模块负责不同协议帧结构的转换,在以太网的工作环境下,它就负责对IP数据报进行以太网帧的封装和解包。

和QNX其它服务进程一样,QNX的网络子系统也在内核外部空间运行。应用程序面对的是一个统一的网络接口,硬件相关的内容被完全包装在网络子系统内。

QNX网络子系统的三个子模块按层次分开,io-net模块处于中心,是QNX网络的核心和重点,其它模块都挂接在它上面。数据和信息的流动都必须经由io-net调度与转发,所有其它模块所面对的就是一个单一主体。这样的中心交换结构,屏蔽了各个模块间相互协调的复杂细节,在很大程序上方便了模块的编写工作;同时,io-net还是QNX的网络管理中心。任何网络协议和网络设备驱动程序都必须向io-net注册,由它来加载,并接受io-net的配置和管理,用户对网络状态的查询和管理也是通过io-net来实现的。

3 QNX网络设备驱动

QNX网络设备驱动模块处于网络硬件和io-net模块之间。驱动模块负责配置硬件使其正常工作,向io-net报告数据收发情况,接收和传递数据,接受io-net的调度和管理。QNX网络设备驱动程序依照以上功能,分为初始化、接收发送数据、网络设备信息统计几个功能块。要使网络设备工作正常,驱动程序就要对它进行一定的寄存器配置,同时,还要向QNX网络子系统注册自己,表明网络设备的存在和网络通信能力,才能为系统和应用程序所用。在初始化工作完成以后,网络设备就进入了工作状态,收发数据。设备信息的统计也是由设备驱动程序来完成的。

(1)初始化

初始化包括两个方面,一方面是初始化网络设备,使其正常工作;另一个方面,是向io-net正确注册驱动模块,表明自己的属性,方便上层正确操作。网络设备的初始化工作和硬件紧密相关,这里就不一一描述。

驱动模块向io-net加载自己的时候,系统遵循如下工作流程:

①io-net搜索全局的符合io_net_dll_entry。它定义了驱动的初始化函数,io-net会直接调用这个函数。

②初始化函数向io-net注册驱动和相应的函数。

③初始化函数告诉io-net和它的模块自己的通信能力。

经过以上流程以后,io-net中就建立起有关此驱动程序的数据和函数调用列表。驱动程序必须正确编写初始化函数,并将该函数正确链接至io_net_dll_entry。

(2)从网络设备接收数据

当有包到达网络设备的时候,网络设备就会用某种方式通知驱动程序(例如中断),此时,驱动程序就要采取某种策略来处理到来的帧或数据。通常驱动程序这时候需要做以下工作:

①通过DMA将包取回来;

②做相应的必要处理,如通知网络设备释放当前帧的缓存,配置寄存器让网络设备等待下一帧到来等;

③通过调用io-net的tx_up_start()函数把包传递给上层模块。

当上层所有的模块都完成对这个包的处理以后,io-net调用我们驱动中的tx_done()函数,它来做最后的处理工作。

tx_up_start()函数是设备驱动中比较关键的函数,下面简要部分一下这个函数的入口参数。

npkt_t*(*tx_up_start)(int registrant_hdl,

nptk_t *npkt,

int off,

int framelen_sub,

uint16_t cell,

uint 16_t endpoint,

uint16_t iface,

void *done_hdl)

其中:int registrant_hdl--本驱动在io-net中的句柄,注册时由io-net生成;

nptk_t *npkt --需要处理的包的指针;

int off--底层协议包头长度,如以太网帧头部长度;

int framelen_sub--尾部填充的长度,对于以太网这个值为零;

uint16_t cell、uint16_t endpoint--endpoint和cell是io-net在注册的时候分配的用来区别不同的驱动;

uint16_t iface--接口号,可以让同一个驱动负现多个相同硬件;

void *done_hdl--该指针指向tx_done()函数需要的额外数据。

(3)向网络设备发送数据

当上层模块需要硬件传送包的时候,会调用io-net管理器的rx_down()函数。

int(*rx_down)(npkt_t*npkt,

void *func_hdl)

rx_down函数入口参数中,npkt是指向需要传送的数据的结构指针,func_hdl是相应驱动模块在io-net中的句柄。其中npt结构包含许多成员,其中的重要成员如表1所列。

表1

cell、endpoint、iface 需要处理该包的硬件标识
buffers 指向包的指针
tot_iov 包含数据包的所有I/O矢量
Framelen 所有数据的长度,以字节为单位

驱动模块在接收到io-net的调用后,就要配置网络设备,让它完成数据的发送工作。网络设备发送数据所需要的信息都会在相应的数据结构中,如net_buf_t结构中保存了等待传送的数据包的链接列表,配置DMA所需的物理地址在net_iov_t中等。驱动模块要等待硬件完成这些包的传送,并调用io-net的tx)done()函数通知上层模块驱动程序已经完成了数据的发送。

4 网络设备信息的统计

应用程序或者用户可以通过网络信息接口nicinfo工具来了解网络工作状态。信息的查询都是通过io-net来进行的。驱动程序必须维护相应的状态数据,方便io-net的查询。网络设备有一些共同的状态属性,如收到和发出的包的个数、发送错误的包的个数等,不同的网络设备还会具有不同的属性和状态,这些都可以在驱动程序中用数据结构详细列明。

需要维护的数据结构中,主要的是Nic_t,它包括四个子结构;

CustNicStats--网络信息入口;

EthernesStats_t--以太网状态;

GenStats_t--常用统计信息;

NetStats_t--网络信息(包含常用统计信息)。

以上是驱动程序需要维护的数据。当用户或应用程序要查询这些信息的时候,它们就通过Nicinfo工具对/dev/io-net/en0调用devctl()函数来取得网络信息。信息的取得是必须通过io-net来完成的,io-net对信息的查询则是通过调用io_net_register_funs_t结构中所指向的函数来取得信息的。例:

#include<sys/nic.h>

int generic_eth_devctl(void *hdl,int dcmd,void *data,size_t size,int *ret)

{

Nic_t *nic=(Nic_t *)hdl;

int status;

status=EOK;

switch(dcmd){

case DCMD_IO_NET_NICINFO;

memcpy(data,nic,min(size,sizeof(Nic_t)));

break;

default:

status=ENOTSUP;

break;

}

return(status);

}

结语

网络设备的驱动是网络系统的最低层和最基础的模块,是如今嵌入式开发中首先要解决的问题之一。由于QNX具有微内核的特点,其网络设备驱动程序的开发不需要内核调试,更适合初学者掌握。本文对QNX操作系统及网络设备驱动程序的介绍,可以帮助读者对相关内容作初步了解。


http://chatgpt.dhexx.cn/article/RBY5drGO.shtml

相关文章

Linux or QNX ?

Linux大家可能都比较熟悉了&#xff0c;我们先来看一下QNX的简介。 QNX简介 关于QNX名字的由来有一则趣事&#xff1a;Gordon Bell和Dan Dodge在1980年成立了Quantum Software Systems公司&#xff0c;他们根据大学时代的一些设想写出了一个能在IBM PC上运行的名叫QUNIX&…

[转]车载电子操作系统:QNX与Linux未来有望两家独大

email:174176320qq.com 如果你认为本系列文章对你有所帮助&#xff0c;请大家有钱的捧个钱场&#xff0c;点击此处赞助&#xff0c;赞助额0.1元起步&#xff0c;多少随意 声明&#xff1a;本文只用于个人学习交流&#xff0c;若不慎造成侵权&#xff0c;请及时联系我&#xf…

QNX操作系统及网络设备驱动模块-qnx设备驱动模块

锋影 e-mail&#xff1a;174176320qq.com QNX是业界公认的X86平台上最好的嵌入式实时操作系统之一。它具有独一无二的微内核实时平台&#xff0c;建立在微内核和完全地址空间保护基础之上&#xff0c;实时、稳定、可靠&#xff0c;已经完成到PowerPC、MIPS、ARM等内核的移植&am…

QNX操作系统优先级以及调度策略

一、优先级分别以及任务抢占 Neutrino 提供了一个基于优先级驱动的抢占式的设计理念。优先级驱动意味着,我们可以为每个线程分配一个优先级,它将可以根据优先级调度策略获取CPU资源。如果一个低优先级线程和一个高优先级线程同时像获取CPU使用权,那么高优先级线程将会运行。…

【历史上的今天】9 月 12 日:世界上第一块集成电路诞生;QNX 操作系统开源;苹果推出 iPhone X

整理 | 王启隆 透过「历史上的今天」&#xff0c;从过去看未来&#xff0c;从现在亦可以改变未来。 今天是 2022 年 9 月 12 日&#xff0c;科技历史的今天有着许多“第一次”&#xff1a;第一架无线电无人机、第一块集成电路、第一个人造登月物体、QNX 第一次开源自己的操作系…

​Linux和QNX两大操作系统在智驾系统上的提升策略

智能驾驶底层软件的核心是其运行的操作系统&#xff0c;该系统主要运行在智能驾驶域控制器上&#xff0c;支持自动驾驶所需的高性能计算和高带宽通信异构芯片。考虑到智驾系统本身对安全性&#xff0c;实时性和可靠性的要求较高&#xff0c;因此&#xff0c;这类需求也会同步加…

QNX实时操作系统简介

目录 什么是QNX&#xff1f;QNX的特点 什么是QNX&#xff1f; QNX是一种实时操作系统&#xff1b; QNX是微内核架构&#xff1b;其核心仅提供4种服务&#xff08;大部分功能都剥离了出去&#xff09;&#xff0c;分别为&#xff1a;进程调度、进程间通信、底层网络通信和中断处…

qnx 镜像文件_一种基于Hypervisor的QNX操作系统启动方法及装置与流程

本发明涉及计算机领域&#xff0c;尤其涉及一种基于Hypervisor的QNX操作系统启动方法及装置。 背景技术&#xff1a; 基于Hypervisor的QNX是一种商用的遵从POSIX规范&#xff0c;常用用在汽车及路由器上&#xff0c;QNX是一种嵌入式实时操作系统&#xff0c;一般对系统启动速度…

QNX操作系统和QNX Hypervisor简介

概述 QNX操作系统和QNX Hypervisor是由QNX Software Systems开发的两个重要的嵌入式技术。它们在嵌入式系统领域具有广泛的应用和卓越的表现。 QNX OS是一个实时操作系统&#xff0c;主要用于嵌入式系统和实时应用程序。它具有可靠性、安全性和高性能的特点。QNX OS支持多处理…

如何查找中文-英文文献 ?

查找外文文献 1、DPLP 计算机类的文献可以在德国的DPLP网站上根据需要直接获得所需文章的相关信息。 http://dblp.org/ 进入DPLP的主页后,在搜索框键入所要搜索的内容。 例如查找文章"A self-Organizing approach to background subtraction for visual surveillan…

如何寻找计算机领域的英文文献?

大家一定或多或少都有文献检索的经验吧&#xff0c;中文文献还好&#xff0c;我们总归是对自己的的母语比较熟悉&#xff0c;通过关键词或其他检索条件&#xff0c;总能得心应手地找到自己需要的文献。相较于中文文献&#xff0c;对外文文献的检索就显得难度增加了不少&#xf…

在哪里可以搜索英文文献?

15天读了100篇英文文献&#xff0c;秘诀在此&#xff01; 如何段时间内阅读大量英文文献&#xff0c;相信很多人阅读英文文献最头疼的就是翻译问题了&#xff0c;没有好用的翻译工具&#xff0c;连检索英文文献都要费好大的劲&#xff0c;现在不用发愁啦&#xff0c;科研人经过…

检索下载中/英文论文的方法

目录 一、中文文献下载 1.本校的图书馆 2、百度学术百度学术https://xueshu.baidu.com/ 3.掌桥科研 二、英文文献下载方法 1.首推SCI-HUB 2、百度学术 3、semanticscholarsemanticscholarhttps://www.semanticscholar.org/ 4.必应搜索 5、其他搜索引擎 三、后记 一、中…

英文文献检索与下载

存档仅自用 谷歌学术镜像网站&#xff1a;谷歌学术镜像_Google镜像站主要提供谷歌学术搜索Google Scholar镜像和谷歌网页搜索镜像的导航站,实时更新最新镜像网站http://scholar.scqylaw.com/ 复制文献DOI号到此sci-hub文献检索sci-hub文献检索:提供sci-hub链接生成及论文搜索…

怎么查找和自己专业有关的英文文献?

参考文献是论文重要的组成部分&#xff0c;如何找到一篇适合自己论文参考文献更是重中之重&#xff0c;中文参考文献还好说&#xff0c;一眼过去可以了解大致内容&#xff0c;从而判断是否合适。而英文就不同了&#xff0c;相较于中文文献来说&#xff0c;英文文献找起来就比较…

移植tslib库 [五一勋章]

​​​​​​ 移植tslib库 tslib 为触摸屏驱动和应用层之间的适配层&#xff0c;它把应用程序中读取触摸屏 struct input_event 类型数据&#xff08;这是输入设备上报给应用层的原始数据&#xff09;并进行解析的操作过程进行了封装&#xff0c;向使用者提供了封装好的 API …

buildroot配置QT5和tslib

buildroot 移植参考文章 buildroot配置安装qt5 在buildroot下面&#xff0c;打开配置界面 make menuconfig 选择target packages项 找到QT5 勾选 进入QT5选项&#xff0c;勾选gui module 和 widgets module。 buildroot编译安装tslib 执行make menuconfig Target pack…

tslib的安装

tslib是嵌入式开发中使用qt开发之前需要搭建的一个必须的环境&#xff0c;通过tslib&#xff0c;你编写的qt程序才能通过触摸屏进行操作&#xff0c;而tslib进行进行你的qt程序和硬件之间的接口&#xff0c;因此&#xff0c; 学会如何搭建tslib是进行嵌入式开发的一个重要的环…

Linux·触摸板库tslib的编译和配置

作为基本输入设备&#xff0c;触摸板几乎是交互式嵌入式系统的标配。当我们知道了可以通过设备节点读取触摸板数据后&#xff0c;我们需要进一步优化这些直接获取的原生数据&#xff0c;比如去抖、消噪、校准等。 优化触摸板的 raw &#xff08;原生&#xff09;数据是一项十分…

嵌入式开发之tslib-1.4移植

目录 前言 一、下载tslib 二、编译和安装 1.编写编译脚本 2.编译时遇到的问题 三、移植到目标机 1.tslib文件移植 2.修改ts.conf内容 3.配置环境变量 4.测试 总结 前言 tslib是一个开源的程序&#xff0c;能够为触摸屏驱动获得的采样提供诸如滤波、去抖、校准等功能…