摘要 集成外设的增多,软件应用复杂性进一步的增加,导致开发外设驱动程序所需的工作量大大增加。TI公司提出了类/微驱动模型的驱动程序结构。实践结果表明,采用类/微驱动模型进行驱动程序设计后,应用软件可以复用绝大部分相似设备的驱动程序,从而极大地提高了驱动程序的开发效率。
关键词DM642 I/O设备驱动 类/微驱动模型 DSP/BlOS实时操作系统
近年来,DSP运算能力的不断增强,使其在电子设备方面得到了广泛的应用。DSP/BIOS是TI公司推出的一个实时操作系统,与TI的CCS(Code Composer Studio)集成在一起。用DSP/BIOS可以大大简化DSP应用程序的开发和调试,其中与外围设备的I/O接口是DSP应用开发中不可缺少的重要部分。TI公司为C64x系列DSP的开发者提供了一种类/微驱动模型(class/mini drivermodel)。通过对外围设备设计驱动程序,为高层应用程序提供统一的接口来操作底层硬件。只要足遵循此驱动程序接口标准开发的高层应用程序,都可以在具有相同接口的不同硬件平台上运行,从而使DSP软件系统与硬件系统相分离,提高了软件的可重用性、可维护性和可移植性,缩短了总体驱动程序的开发周期。
1 DSP的外设驱动开发模型
TI公司为开发DSP的外设驱动程序定义了标准的设备驱动模型,并将设备驱动分为类驱动和微驱动,即依赖于硬件层和不依赖于硬件层。两层之间使用通用接口进行数据通信,并提供了一系列的API接口,用户应用程序通过调用API来访问相应的外部设备。外设驱动开发模型的建立,提高了外设驱动程序的可重用性和模块化程度,简化了驱动程序的开发。外设开发模型如图1所示。
①类驱动(class driver)。类驱动程序用来为应用程序提供接口。这部分程序与所使用的硬件设备无关,主要功能包括维护设备缓冲区,向上提供API接口供应用程序调用,向下提供适配层与微驱动层相连,实现API接口函数到微驱动层程序的映射。
②微驱动(mini driver)。微驱动程序与外部硬件设备相关,所以设计微驱动程序是外设驱动开发的重点。微驱动程序与类驱动程序的接口格式是固定的,但微驱动程序对底层硬件的操作则须根据硬件平台的不同需要做相应的改动。微驱动通过接收类驱动层发出的调用命令来决定对底层硬件进行什么样的操作。
类驱动通过标准的微驱动接口调用微驱动控制硬件设备。到日前为止,TI共定义了3类驱动:①流输入输出模块(SIO),为每个DSP/BIOS线程提供一个独立的I/O机制,执行点到点的数据传送,支持动态创建,通过DIO适配模块与IOM连接;②管道管理模块(PIP),提供管理异步I/O的数据管道,每个管道对象都有一块同样大小的缓存,PIP模块通过缓存进行数据传输,通过PIO适配模块与IOM通信;③通用输入输出模块(GIO),基于流输入/输出模式的同步I/O,适合大流量数据的传输,更适合文件系统。在用户应用程序中可直接调用GIO的API函数,GIO不需要额外的适配模块,可直接与IOM进行交互。GIO的这些优点使得通过GIO模块与外部设备进行数据流传输,操作简单、稳定,所以在视频采集的类驱动中采用了通用输入输出模块GIO。
GIO模块实现GIO的类驱动,用于提供一个模块化的读写应用程序接口到应用程序。通过封装这部分代码,应用程序可以通过GIO提供的应用程序接口问接调用各种IOM微驱动来减小整体的代码大小,如图2所示。
GIO模块提供下述功能:提供模块化的读写应用程序;用IOM接口与指定设备微驱动实现程序通信;支持多个设备驱动;支持双向通道;允许用户配置模块化功能;支持应用程序增加新的应用领域(如视频)。其中,最后一项功能很重要。GIO_submit函数对新增加的用户定制的应用程序接口(API)提供标准通道(如video)。这种用户定制的类型包括用于文件系统的读写应用程序接口模块,例如UART、DSP视频帧等的应用。
传统的文件系统用读写应用程序接口来完成应用程序与文件之间的数据传输,需要由GIO类驱动和IOM微驱动来完成所需的双向通道。对GIO接口模块的扩展可以更加友好和高效地实现视频抓取和视频显示。这种扩展特别满足了视频设备存储空间(例如指定的帧缓存)的分配,而且通过简单的应用程序调用来更新视频帧缓存,提供视频驱动与应用程序之间最新的视频数据的更新。GIO类驱动具有如下接口。在函数表中指定设备的操作模式:
微驱动IOM通常包括如下函数:通道绑定函数(md-BindDev),通道创建函数(mdCreateChan),通道删除函数(mdDeleteChan),I/O请求发送函数(mdSubitChan),通道解绑定函数(mdUnBindDev)和设备控制函数(mdControl-Chan)。类驱动通过调用这些底层函数完成相应外部设备与应用程序之间的数据传送通道的创建,以及外部设备和内存空间的分配,控制各个线程之间数据传送的同步等。这些规定好的底层函数将放入微驱动的函数接口表(IOM_Fxns)中的相应位置,供应用程序通过适配模块或直接由GIO类驱动调用。IOM接口表的结构如下:
在调用IOM微驱动之前,必须要先在DSP/BIOSConfig中注册。在Device Drivers中右击选择插入一个设备驱动,命名为VPlACAPTURE,并进行各个属性(如函数表指针、函数表类型和设备ID号等)的配置,指明IOM—Fxns函数表地址和设备参数地址,如图3所示。
2 DM642芯片视频驱动程序设计
视频驱动程序的设计主要包括微驱动、类驱动和中间接口3方面的设计。为了最大程度的提高视频驱动代码的复用性和通用性,在视频采集驱动程序实例中,在GIO类驱动程序基础上进一步封装成FVID类。将微驱动细分为视频端口类和指定的编解码芯片微驱动,二者之间通过外部设备控制接口(EDC)实现对外围芯片的打开、控制和关闭等操作。这样一来,即使所使用的板卡上集成了不同的视频编解码芯片,也只需改变特定编解码芯片的微驱动。视频采集驱动程序的类/微驱动模型如图4所示。
例如,对VPORT_PortParams接口的说明属于对VPORT端口类的说明,而对SAA712l接口的说明则属于对特定编码芯片的说明。如果把VPORT类用于不同的芯片,则只需对SAA712l进行修改。对EDC的接口说明如下(指定要对外围设备进行打开、关闭等的操作):
下面举例说明对FVID类驱动的视频应用程序接口(video API)的操作。就应用程序而言,对设备驱动程序的操作可分为3个阶段:创建、处理和删除。创建是在应用程序与外部设备之间建立一个数据输入/输出的逻辑通道,对应于FVID_create;处理是在应用程序与外部设备之间进行数据的传送,并对外设进行相应的控制,对应于FVID_control和FVID_alloc;外设使用完毕后,相应地删除原先所建立的通道,对应于FVID_delete。具体的调用函数如下:
结语
本文介绍了TI公司开发的类/微驱动模型和改进后DM64z的视频类/微驱动模型。实践表明,DM642的视频类/微驱动模型降低了系统中软硬件之间的耦合性,提高了驱动程序的可重用性和可移植性,简化了视频驱动程序的开发。
上一篇:使用AADL语言分析和设计嵌入式系统
下一篇:基于PR818S的便携式媒体存储盒系统设计
- 热门资源推荐
- 热门放大器推荐
- 米尔T527系列核心板,高性能车载视频监控、部标一体机方案
- Akamai 全新视频工作流程功能强化媒体平台控制能力
- 紫光同芯推出全球首颗开放式架构安全芯片E450R 已获国密二级认证
- 品英Pickering公司携多款模块化信号开关和仿真解决方案亮相国防电子展
- 派克汉尼汾推出适用于现场监测和诊断的测量设备 Service Master COMPACT
- 连接与距离: 安防摄像头新气象—— Wi-Fi HaLow 带来更远传输距离和更低功耗
- 思特威携多款重磅产品强势亮相2023 CPSE安博会
- 双轮驱动,云天励飞推出12TOPS边缘视觉SoC
- 丰田汽车因信息泄露案接受日本行政指导 涉及241万条用户数据
- Allegro MicroSystems 在 2024 年德国慕尼黑电子展上推出先进的磁性和电感式位置感测解决方案
- 左手车钥匙,右手活体检测雷达,UWB上车势在必行!
- 狂飙十年,国产CIS挤上牌桌
- 神盾短刀电池+雷神EM-i超级电混,吉利新能源甩出了两张“王炸”
- 浅谈功能安全之故障(fault),错误(error),失效(failure)
- 智能汽车2.0周期,这几大核心产业链迎来重大机会!
- 美日研发新型电池,宁德时代面临挑战?中国新能源电池产业如何应对?
- Rambus推出业界首款HBM 4控制器IP:背后有哪些技术细节?
- 村田推出高精度汽车用6轴惯性传感器
- 福特获得预充电报警专利 有助于节约成本和应对紧急情况
- [有奖转发]Vishay新能源、航天/军工解决方案
- 申请ufun学习板,入门&深度学习模拟,工程技能
- 艾睿电子线上研讨会:英特尔FPGA深度学习加速技术 7月30日上午10:00-11:30 期待您的莅临!
- 你评论,我送礼!《玩转TI MSP430 Launchpad》TI社区与EEWORLD联合首发!
- 【抢楼有礼】TI TMS320F28377S 入门经验大搜集!
- 解锁【W5500-EVB-Pico】,探秘以太网底层,得捷电子Follow me第4期来袭!
- 深入东芝参考设计库:夯实您的设计库,让您的设计更出彩
- “集齐五友”参与KW41Z创意征集活动,赢100元京东卡!
- 泰科电子物联网应用资料下载中心 限时免费开放!