分析CITECT驱动程序的实现方式.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
分析CITECT驱动程序的实现方式

分析CITECT驱动程序的实现方式 机电商情网编辑一部 供稿??? 添加时间:2007-5-21 16:03:35???添加到我的收藏 1 驱动程序的功能(The Function of a Driver) 驱动程序用于在某一设备内独立与控制器或监视设备通信。它允许CITECT运行系统直接与许多运 行同样应用程序的不同类型的设备进行通信。CITECT 产生请求访问I/O设备并把这些请求传送至驱动程序。 驱动程序通过与I/O设备通信来处理这些请求(使用其唯一的通信协议)。一旦通信建立起来,CITECT将 其数据格式转换成CITECT的通用形式。而后驱动程序把结果反馈给CITECT。 CITECT设备驱动程序的结构是极度灵活的。它容许一个单一驱动程序同时同几个通信板进行通信, 每块集成板上可以有多个硬件端口,每个端口可以连接几个I/O设备。 2 驱动程序控制模块(Driver Control Block) 驱动程序控制模块是一种在CITECT和设备驱动程序之间转换请求的数据结构。驱动程序将(1)请求排队, (2)(当硬件有效时)处理请求, (3)把结果返回给CITECT。 CITECT可同时将几个DCB(驱动程序控制块)传递给驱动程序,DCB(驱动程序控制块)的数量由驱动程序决定。驱动程序将传递来的驱动程序控制块排在队列的尾部,驱动程序不断从队首取出DCB(驱动程序控制块) 进行处理,使驱动程序一直处于忙碌状态,以达到最高的执行效率。有些驱动程序可以对请求进行优化,合并成一个请求,使数据可以缓存,仅在需要时才产生物理请求。 值得注意的是,许多命令的处理必须是异步的,这将允许CITECT在等待驱动程序响应时能够进行其它操作。 支持异步运算的各种命令在CITECT驱动程序开发手册中有详细的说明。 DCB(驱动程序控制块)按以下方式往返传递:CITECT将含有命令和其他相关信息的DCB(驱动程序控制模块)作为参数调用驱动程序,驱动程序便获得DCB(驱动程序控制块),驱动程序将DCB中的“InUseFlag”成员变量的置为“真”。在此种状态下, CITECT不能修改该DCB控制块。当驱动程序完成DCB中命令的操作后,它将DCB控制块的“InUseFlag”成员变量重新设置为“假”,同时调用回调函数如果已经定义。 CITECT既可以设置‘InUseFlag’成员变量, 也可以附上一个回调函数以决定驱动程序在何时完成命令。 同时,CITECT还具有watch dog 的功能, 由它负责检查DCB规定的命令执行是否的超时,超时时间一般为三十秒,由WatchTime选项指定。如果CITECT检测出驱动程序在规定的时间内没有反应,它将取消DCB并产生一个硬件报警。 数据点(Data Point):DATAPOINT数据结构定义了用于信息读、写的位置以及每次读、写过程中所需 要转换的字节数。数据结构中的数据由编译程序的定义数据库构成和具体的通讯协议构成。 通道(Channel):对于CITECT组态软件中的每个端口,每个通道数据结构都被分配了内存单元。通道 数据结构含有与通道相关的所有数据。通道数据结构的第一部分是固定的,由CITECT设定这部分的内容,其他情况下不能改变其内容。 一般情况下在驱动程序的指定部分增加需要与物理通道有关的数据,比较典型的数据包括timer(定时器)、 queue header(队列头)和communications buffer (通信缓冲区)。MaxUnit(最大单元)和UnitDataBase(单元数据库)是所有CITECT驱动程序中的一个标准部分。这样便可以将通道和通道所处的单元建立连接。 3 基于请求的驱动程序(Request based drivers) Request handling(请求操作)将驱动程序划分为两种基本形式:基于请求的驱动程序和front-end /back-end(前端、后端)驱动程序[2]。 在基于请求的驱动程序中,来自CITECT的CTDCB请求使驱动程序直接对物理设备提出请求。当该设备做出反应时,驱动程序会回复CITECT提出的请求。这是最常见的一种驱动程序形式,比前端/后端驱动程序简单些。 大部分驱动程序是这样工作的。其工作原理见图一 前端/后端驱动程序有两部分组成Front end和Back-end。与基于请求的驱动程序不同的是Back-end无须接 收来自CITECT的任何CTDCB请求就能与I/O设备建立通信。它通常使用CTDRV_CPU命令定期地轮询设备。Back end将来自I/O设备的数据放入存储缓冲器,作为I/O设备寄存器的存储影象。驱动程序的Front end将处理来自CITECT的命令。要完成一个请求,Front end从存储缓冲器中提取数据。该数据将不在

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档