隨著醫學信息網絡化的需要,經常需要將各種醫學儀器(如腦電圖、心電圖等)與主機相連,以便于從這些醫學儀器獲得所需的各種醫學信息。同時,在需要的時侯還可以通過主機對這些醫學儀器的操作進行控制。
傳統的外設與主機的通訊接口一般是基于PCI總線、ISA總線或者是RS-232C串行總線。PCI總線雖具有高的傳輸速度(132Mbps),支持“即插即用”功能,但其缺點是插拔麻煩,且擴展槽有限(一般為5~6個)。ISA總線顯然存在著同樣的問題。RS-232C串行總線雖然連接簡單,但其缺點是傳輸速度慢(56kbps),且主機的串行口數目有限。
USB(Universal Serial Bus,通用串行總線)是由Intel、Microsoft、IBM及NEC等共同制定的微機總線接口規范1。由于USB具有較高的傳輸速度(USB協議1.1支持的最高傳輸速度為12Mbps,而USB協議2.0支持的最高傳輸速度更是高達480Mbps),支持即插即用和熱插拔功能,USB設備的連接電纜最長可達5 m,且可通過USB集線器進行層式星形拓撲連接(一臺主機最多可連接127個USB設備,且可實現最多5級的拓撲連接),因此其非常適合作為主機和醫學儀器之間的通信接口。
為便于臨床上采集病人的某些生理信號(如心電信號,腦電信號等)23,設計了基于USB總線的醫學數據采集設備,其最多支持32個通道的同步數據采集,最高采樣率為1kHz,采樣精度為16bit,主機的操作系統為Win98。主要完成了四個方面的工作:硬件設計、firmware(固件)設計、設備驅動程序設計以及應用軟件的設計。
1、硬件設計
USB數據采集設備的硬件構成見圖1。
從圖1可知,32路模擬輸入信號由多路模擬開關控制將其中的某一路信號接入串行A/D(選用B-B公司的ADS7809),A/D轉換的結果經光電隔離后串行輸出到移位寄存器,移位寄存器將此結果轉為并行數據并寫入FIFO存儲器,80C52系統將數據從FIFO存儲器中讀出并通過USB控制器送到主機。
當前可供選擇的USB控制器很多,如朗訊公司的USS820、國家半導體公司的USBN9602。另外,還有將微控制器和USB控制器集成在一起的芯片,如Intel公司的8x930Hx和8x930Ax,其中8x930Hx支持USB集線器功能。在實際開發中選擇了朗訊公司的USS820,其主要特點是完全遵循USB協議1.1,支持12Mbps的全速傳輸,支持四種傳輸方式,提供8個端點(Endpoint) 且每個端點的傳輸類型、傳輸方向均可自由配置。另外,它還為每個端點提供兩套FIFO數據緩沖區,總的數據緩沖區大小可達2240字節。
2、firmware設計
此處firmware(固件)是指被固化到89c52 E2PROM中的程序。firmware主要完成兩個方面的工作:控制A/D的采樣和通過USB控制器與主機通信。由于89C52系統控制A/D采樣的工作非常簡單,此處不做介紹。詳細介紹89C52系統通過USB控制器與主機通信的工作。
因為89C52系統對USB控制器的操作是嚴格按照USB協議1.1進行的,因此先對USB協議1.1做一簡單的介紹。按照USB協議1.1的規定,USB的傳輸方式分為4種:控制傳輸(Control transfer),塊傳輸(Bulk transactiONs),中斷傳輸(Interrupt transactions)和等時傳輸(Isochronous transactions)。控制傳輸主要用來完成主機對設備的各種控制操作(如獲取設備的設備描述符,設置設備的USB地址等,也可以通過控制傳輸來定義自己對設備的控制操作,如設置采樣參數、開始或停止采樣等);塊傳輸主要用來完成主機和設備之間的大批量數據傳輸,由于塊傳輸在硬件級上對傳輸數據進行錯誤檢測(若發生錯誤,它支持“重傳”功能),因此它能保證數據傳輸的可靠性,塊傳輸支持兩個方向的數據傳輸(即主機到設備和設備到主機);中斷傳輸用來完成設備到主機的少量數據傳輸,它只支持設備到主機方向的數據傳輸(中斷傳輸跟實際的“中斷”概念沒有任何聯系);等時傳輸主要用來完成主機和設備之間連續、實時數據的傳輸(如語音信號),同步傳輸不對傳輸數據進行錯誤檢測,它主要保證數據的連續傳輸。另外,需要注意的是所有的USB傳輸事務均由主機啟動,即USB總線采取主從式結構(master to slave)。
在實際開發中使用了兩種傳輸方式:控制傳輸和塊傳輸。控制傳輸用來實現位于主機上的USB總線驅動程序(USBD.SYS)以及編寫的功能驅動程序對設備的各種控制操作,而塊傳輸用來完成將采集數據從設備傳送到主機。
USB控制器的工作原理可以簡單地描述為:當USB控制器從USB總線檢測到主機啟動的某一傳輸請求時,USB控制器通過中斷方式將此請求通知89C52系統。89C52系統通過訪問USB控制器的狀態寄存器和數據寄存器獲得與此次傳輸有關的各種參數,并根據具體傳輸參數,對USB控制器的控制寄存器和數據寄存器進行相應的操作,以完成主機的傳輸請求。
3、設備驅動程序設計
USB設備驅動程序的設計是基于WDM(Windows Driver Model,Windows驅動程序模型)的4。WDM采用分層驅動程序模型,對于USB設備來說,可分為USB總線驅動程序和USB功能驅動程序(見圖2)。
USB總線驅動程序由操作系統提供,它位于USB功能驅動程序的下面,負責與實際的硬件打交道,實現煩瑣的低層通信。USB功能驅動程序由設備開發者編寫,位于USB總線驅動程序的上面,不與實際的硬件打交道,而是通過向USB總線驅動程序發送包含URB(USB Request Block,USB請求塊)的IRP(I/O Request Packet,I/O請求包),來實現對USB設備信息的發送或接收。采用這種分層驅動程序的設計方法有兩個優點:(1)多個USB設備可以通過USB總線驅動程序來協調它們的工作;(2)編寫分層驅動程序較之編寫單一驅動程序相對簡單,且可以節省內存和資源,不易出錯。 USB設備驅動程序的工作原理可以通過圖2簡單描述。
若應用程序想對設備進行I/O操作,它便使用Windows API 函數(如DeviceloControl 函數)對WIN32子系統進行WIN32調用。此調用由I/O系統服務接收并通知I/O管理器,I/O管理器將此請求構造成一個合適的I/O請求包(I/O Request Packet,IRP)并把它傳遞給USB功能驅動程序。USB功能驅動程序接收到這個IRP以后,根據IRP中包含的具體操作代碼,構造相應的USB請求塊并把此URB放到一個新的IRP中,然后把此IRP傳遞到USB總線驅動程序,USB總線驅動程序根據IRP中所含的URB執行相應的操作(如從USB設備讀取數據),并把操作結果通過IRP返還給USB功能驅動程序。USB功能驅動程序接收到此IRP后,將操作結果通過IRP返還給I/O管理器,最后I/O管理器將此IRP中操作結果返還給應用程序,至此應用程序對USB設備的一次I/O操作完成。
USB功能驅動程序除負責處理應用程序的I/O請求外,還要處理PnP管理器發送給它的PnP請求(如設備啟動請求IRP_MN_START_DEVICE,設備刪除請求IRP_MN_REMOVE_DEVICE等)。通過對這些PnP請求的處理,USB功能驅動程序可支持設備的熱插拔和即插即用功能。
驅動程序的入口函數是DriverEntry( ),所有對各種IRP的處理例程都在此入口函數中做出定義。
開發USB設備驅動程序的工具有Microsoft公司的Win98DDK,Compuware公司的Numega DriverStudio等。筆者在實際開發中使用了Win98DDK。
4、 應用軟件的設計
用戶態的軟件設計由兩個部分組成:動態鏈接庫和應用程序。動態連接庫負責與內核態的USB功能驅動程序通信并接受應用程序的各種操作請求,而應用程序負責對所采集的數據進行實時顯示、分析和存盤。
動態鏈接庫的工作原理如下:當它收到應用程序開始采樣的請求后,便創建兩個線程:采樣線程和顯示存盤線程。采樣線程負責將采集數據寫到應用程序提交的內存;而顯示存盤線程由多媒體定時器控制(每隔一段時間多媒體定時器就調用一次此線程),此線程負責給應用程序發送顯示和存盤消息。當應用程序接收到此消息后,便從它提交的內存中讀取數據并顯示和存盤。此處需要注意的是采樣線程和顯示存盤線程在讀寫應用程序提交的內存時要保持同步(如當采樣線程正在向內存進行寫操作時顯示存盤線程就不能對此段內存進行讀操作,否則就有可能導致讀寫錯誤)。保持線程同步的方法很多,如互斥量(Mutex)、信號量(Semiphore)和事件(Event)。此處使用了互斥量。
USB總線的特點使其非常適合于作為醫療儀器與主機之間的通訊接口,實現主機和醫學儀器之間的簡單、快速和可靠的連接。
基于USB總線的醫學數據采集設備,在實際應用中取得了良好的效果。同時,它也為數據采集提供了一種新穎的、方便的和可靠的解決方案
責任編輯:gt
-
usb
+關注
關注
60文章
7979瀏覽量
265578 -
數據采集
+關注
關注
39文章
6245瀏覽量
113915 -
總線
+關注
關注
10文章
2900瀏覽量
88288
發布評論請先 登錄
相關推薦
評論