利用S3C44B0X的心電血壓監測儀USB接口設計
發布時間:2008/8/23 0:00:00 訪問次數:439
引言
家用心電血壓監測系統由采集記錄設備和上位機電子病歷管理系統組成,因此,需要解決數據傳輸方式問題。傳統的通信接口采用簡單的rs- 232串行uart ,這種方式速度慢且適用性差,而usb轉串口芯片的傳輸性能不能得到根本改善。usb總線接口則具有速度快、易于擴展、支持熱插拔、使用靈活方便等優勢, 尤其適用于家用設備與計算機的通信連接。
本文重點討論usb通信協議及其接口芯片的控制方法,針對臨床需求,設計實現了具有心電、血壓智能監測和usb高速數據傳輸功能的小型化設備,提供心電、血壓數據電子病歷查詢、打印和網絡傳輸等功能,對于提高家庭健康保健水平具有很重要的意義。
監測儀的usb接口電路設計
系統主控制芯片采用32位高性能嵌入式arm微處理器s3c44b0x,usb專用控制芯片選用usbn9603。usbn9603內置7個fifo端口,包括1個雙向的控制端口,3個發送端口和3個接收端口,各有64字節。
usb 控制器與s3c44b0x的接口電路如圖1所示。將usb控制器設計為bank2,即將ngcs2存儲體選擇線作為usbn9603的片選線,則該芯片的 片選地址為0x4000000。本文采用并行數據接口,兩個芯片的低8位數據線d0~d7相連接,并行傳輸通信數據。將mode0和mode1引腳都接 地,配置usbn9603為非復用方式,由于此工作模式需要地址線a0作為存取usbn9603片內寄存器data_in、data_out和addr寄 存器的選擇線,需連接32位地址總線中的a18到usb控制器的a0。對usbn9603進行讀寫操作時,分為兩個總線周期:首先,將地址線a0置高,即 設置總線地址為0x4040000,將待訪問寄存器的地址從數據線d[0:7]寫入,這樣,就在第一個總線周期將地址送到芯片;然后,在第二個周期,將 a0置低,即設置總線地址為0x4000000,讀寫d[0:7]即可實現對寄存器的讀寫操作。整個usb通信過程主要是處理包括接收、發送數據等各種中 斷事件,將usbn9603的int引腳連接到s3c44b0x的外部中斷eint0引腳,設置usb中斷為向量中斷請求模式。由于未使用dma方式,需 將dack置高,dma請求線drq懸空。usb電纜有4條導線,d+和d-是usb差分信號線,另外兩個分別是5v電源線和地線。usbn9603支持 低速和全速的usb通信,在d+信號線上連接1.5kω上拉電阻,使其工作在全速模式。
監測儀的usb接口固件實現
usb通信過程的操作是從主機開始的,按照約定的時序先發出一個令牌包,包含操作類型、方向、外設地址及端點號等信息,然后在令牌中指定數據發送者發出一個數據包或者指出沒有數據傳輸。而usb外設要以一個確認包作出響應,表示傳輸成功。
本文采用主從式usb通信結構,上位機通過發送各種事先約定好的協議命令,來實現對心電、血壓數據的采集及對系統設備的初始化設置,主要包括以下幾種數據: 心電數據以段為單位,每段包括32kb心電數據及6b的采集時間信息,每次傳輸若干段,數據量大,對傳輸可靠性要求也高;血壓數據包括舒張壓和收縮壓及其 采集時間,共10b,由于血壓監測比較頻繁,每次會傳輸一段時間內的血壓監測數據,數據量也比較大;下載升級版的固件等文件信息 。這3種數據的數據流量都比較大,而且可靠性要求都較高,3種數據均選用塊傳輸通道類型,另外,每個usb傳輸都必有控制傳輸通道。因此,需要使用3個通 道,即控制通道、bulkin通道和bulkout通道。
usb固件數據結構
本文涉及usb設備配置枚舉階段上位機在控制傳輸中要求設備傳輸的4類描述符,按照層次依次為:設備描述符、配置描述符、接口描述符和端點描述符,其中,較高階描述符會通知主機任何其它低階的描述符信息。
設備描述符是在設備連接時主機第一個讀取的描述符,每個設備只能有一個設備描述符,包含整個設備的信息以及設備支持的配置號碼,共18個字段。每個usb設 備有一個或多個配置描述符,包含設備的電源管理以及設備配置所支持的接口號碼,當設備收到獲取配置描述符的要求后,傳送該配置描述符及其所有接口、端點和 其它附屬描述符給主機,本文設置一個配置,其描述符共8個字段。接口包含一組端點,本文設置一個接口,其描述符有9個字段,為上位機提供了設備使用端點的 數目及其類型等信息。每個接口描述符有零個或多個端點描述符,包含主機與端點通信所需的信息,端點0作為控制端點來通信,端點1和端點2分別為塊傳輸模 式,其描述符包含了端點號、傳輸方向、端點傳輸類型、數據包最大傳輸字節等信息。
usb固件框架流程如圖2所示,在進入通信模塊后,固件首先調用初始化例程,配置usb接口設備,并使其進入操作狀態, 然后啟用中斷,usb通信的主要功能是在中斷服務中實現的,主程序只是在循環等待是否有退出的按鍵,當檢測到中斷信號時,就會進入中斷服務子程序,根據寄 存器maev的值,判斷中斷類型,并進入相應的處理過程。
設備的usb通信主要實現心電和血壓數據的bulk傳輸功能。在usb總線收發數據的通 信協議基礎上,監測儀還
引言
家用心電血壓監測系統由采集記錄設備和上位機電子病歷管理系統組成,因此,需要解決數據傳輸方式問題。傳統的通信接口采用簡單的rs- 232串行uart ,這種方式速度慢且適用性差,而usb轉串口芯片的傳輸性能不能得到根本改善。usb總線接口則具有速度快、易于擴展、支持熱插拔、使用靈活方便等優勢, 尤其適用于家用設備與計算機的通信連接。
本文重點討論usb通信協議及其接口芯片的控制方法,針對臨床需求,設計實現了具有心電、血壓智能監測和usb高速數據傳輸功能的小型化設備,提供心電、血壓數據電子病歷查詢、打印和網絡傳輸等功能,對于提高家庭健康保健水平具有很重要的意義。
監測儀的usb接口電路設計
系統主控制芯片采用32位高性能嵌入式arm微處理器s3c44b0x,usb專用控制芯片選用usbn9603。usbn9603內置7個fifo端口,包括1個雙向的控制端口,3個發送端口和3個接收端口,各有64字節。
usb 控制器與s3c44b0x的接口電路如圖1所示。將usb控制器設計為bank2,即將ngcs2存儲體選擇線作為usbn9603的片選線,則該芯片的 片選地址為0x4000000。本文采用并行數據接口,兩個芯片的低8位數據線d0~d7相連接,并行傳輸通信數據。將mode0和mode1引腳都接 地,配置usbn9603為非復用方式,由于此工作模式需要地址線a0作為存取usbn9603片內寄存器data_in、data_out和addr寄 存器的選擇線,需連接32位地址總線中的a18到usb控制器的a0。對usbn9603進行讀寫操作時,分為兩個總線周期:首先,將地址線a0置高,即 設置總線地址為0x4040000,將待訪問寄存器的地址從數據線d[0:7]寫入,這樣,就在第一個總線周期將地址送到芯片;然后,在第二個周期,將 a0置低,即設置總線地址為0x4000000,讀寫d[0:7]即可實現對寄存器的讀寫操作。整個usb通信過程主要是處理包括接收、發送數據等各種中 斷事件,將usbn9603的int引腳連接到s3c44b0x的外部中斷eint0引腳,設置usb中斷為向量中斷請求模式。由于未使用dma方式,需 將dack置高,dma請求線drq懸空。usb電纜有4條導線,d+和d-是usb差分信號線,另外兩個分別是5v電源線和地線。usbn9603支持 低速和全速的usb通信,在d+信號線上連接1.5kω上拉電阻,使其工作在全速模式。
監測儀的usb接口固件實現
usb通信過程的操作是從主機開始的,按照約定的時序先發出一個令牌包,包含操作類型、方向、外設地址及端點號等信息,然后在令牌中指定數據發送者發出一個數據包或者指出沒有數據傳輸。而usb外設要以一個確認包作出響應,表示傳輸成功。
本文采用主從式usb通信結構,上位機通過發送各種事先約定好的協議命令,來實現對心電、血壓數據的采集及對系統設備的初始化設置,主要包括以下幾種數據: 心電數據以段為單位,每段包括32kb心電數據及6b的采集時間信息,每次傳輸若干段,數據量大,對傳輸可靠性要求也高;血壓數據包括舒張壓和收縮壓及其 采集時間,共10b,由于血壓監測比較頻繁,每次會傳輸一段時間內的血壓監測數據,數據量也比較大;下載升級版的固件等文件信息 。這3種數據的數據流量都比較大,而且可靠性要求都較高,3種數據均選用塊傳輸通道類型,另外,每個usb傳輸都必有控制傳輸通道。因此,需要使用3個通 道,即控制通道、bulkin通道和bulkout通道。
usb固件數據結構
本文涉及usb設備配置枚舉階段上位機在控制傳輸中要求設備傳輸的4類描述符,按照層次依次為:設備描述符、配置描述符、接口描述符和端點描述符,其中,較高階描述符會通知主機任何其它低階的描述符信息。
設備描述符是在設備連接時主機第一個讀取的描述符,每個設備只能有一個設備描述符,包含整個設備的信息以及設備支持的配置號碼,共18個字段。每個usb設 備有一個或多個配置描述符,包含設備的電源管理以及設備配置所支持的接口號碼,當設備收到獲取配置描述符的要求后,傳送該配置描述符及其所有接口、端點和 其它附屬描述符給主機,本文設置一個配置,其描述符共8個字段。接口包含一組端點,本文設置一個接口,其描述符有9個字段,為上位機提供了設備使用端點的 數目及其類型等信息。每個接口描述符有零個或多個端點描述符,包含主機與端點通信所需的信息,端點0作為控制端點來通信,端點1和端點2分別為塊傳輸模 式,其描述符包含了端點號、傳輸方向、端點傳輸類型、數據包最大傳輸字節等信息。
usb固件框架流程如圖2所示,在進入通信模塊后,固件首先調用初始化例程,配置usb接口設備,并使其進入操作狀態, 然后啟用中斷,usb通信的主要功能是在中斷服務中實現的,主程序只是在循環等待是否有退出的按鍵,當檢測到中斷信號時,就會進入中斷服務子程序,根據寄 存器maev的值,判斷中斷類型,并進入相應的處理過程。
設備的usb通信主要實現心電和血壓數據的bulk傳輸功能。在usb總線收發數據的通 信協議基礎上,監測儀還
上一篇:基于多種技術的高效LCD驅動器
上一篇:USB接口研究與硬件電路設計