摘要:BlueCore2-external是我國CSR公司生產(chǎn)的藍牙收發(fā)電路。具有功耗低、外國器件少等特點,廣泛應用在筆記本電腦、藍牙手機和個人數(shù)字助理(PDA)等產(chǎn)品中。文中著重介紹BlueCore2的特點及其在計算機中的應用并給出軟件流程。
關鍵詞:藍牙;主機控制接口;HCI傳輸驅動;藍牙模塊
1 引言
藍牙技術是一種短距離無線通信技術。遵循開放系統(tǒng)互聯(lián)參考模型(OSI/RM),采用分層的協(xié)議棧。主機控制接口(HCI)位于藍牙協(xié)議棧的L2CAP(邏輯鏈路控制與適配協(xié)議)層和LMP(鏈路管理協(xié)議)層之間,是藍牙協(xié)議棧中軟件與硬件的接口。它為上層軟件調(diào)用下層(基帶和鏈路管理層)狀態(tài)寄存器和控制寄存器等硬件提供了統(tǒng)一的指令接口。藍牙設備高層軟件和底層硬件模塊接口之間的消息和數(shù)據(jù)傳遞必須通過藍牙主機控制器接口的解釋才能進行。HCI以上的協(xié)議軟件實體運行在主機上,而HCI以下的功能由藍牙模塊來完成,二者之間通過傳輸層進行交互傳輸數(shù)據(jù)。
2 BlueCore2-external的特點及結構
BlueCore2-external[1]是英國CSR公司推出的基于藍牙技術的收發(fā)電路。工作在2.4GHz的ISM(工業(yè)、科學、醫(yī)學)頻段,主要應用于PC、無線手機、PDA、鼠標、鍵盤、數(shù)碼相機等。其主要特點如下:
●工作電壓為1.8V;
●完全和別的藍牙器件匹配;
●采用0.18μm CMOS工藝;
●支持8Mb的外圍FLASH;
●外圍元器件較少。
該電路集成了藍牙協(xié)議棧的射頻和基帶部分,具有SPI、UART、USB、PIO、PCM接口。其中,SPI、UART、USB接口主要用來傳輸數(shù)據(jù);PIO接口為可編程接口;PCM接口用來傳輸語音。在BlueCore2-External中UART接口的最大傳輸速率為1.5Mb/s,能夠達到藍牙標準中規(guī)定的723.2kb/s的數(shù)據(jù)傳輸速率。其內(nèi)部結構如圖1所示。
3 硬件電路設計
系統(tǒng)的硬件組成如圖2所示。串口收發(fā)器采用常用的MAX232ACPE,完成BlueCore2與9針串口之間的電平轉換。串口和主機相連,主機可以是PC、ARM或單片機。這里為PC上的串口。藍牙模塊為主機控制器。這樣,藍牙主機可以和藍牙主機控制器之間實現(xiàn)通信。
4 HCI接口分析
HCI通過分組的方式傳輸數(shù)據(jù)(Data)、命令(Command)和事件(Event)[2],所有主機和主機控制器之間的通信都以分組的形式進行。在HCI分組中。數(shù)據(jù)分組是雙向的,命令分組只能從主機發(fā)往主機控制器,事件分組只能從主機控制器發(fā)向主機。主機發(fā)出的大多數(shù)命令分組都會由主機控制器產(chǎn)生相應的事件分組作為響應。
藍牙標準定義了3種類型的HCI傳輸層[3]:USB、RS232及UART。筆者提出了存在于HCI和UART之間的層-HCI傳輸驅動層,它的上層為HCI層,下層為UART驅動層,實現(xiàn)HCI和UART之間的數(shù)據(jù)傳輸。
藍牙HCI接口、藍牙主機及藍牙主機控制器之間的協(xié)議棧層次[3]如圖3所示。藍牙主機控制器即BlueCore2模塊集成了藍牙協(xié)議棧的射頻、基帶和鏈路管理部分。藍牙模塊通過UART硬件連接到藍牙主機。在藍牙主機中運行藍牙UART驅動程序、HCI傳輸驅動程序、HCI的API函數(shù)及上層協(xié)議棧。
5 程序設計與實現(xiàn)[4]
在發(fā)送數(shù)據(jù)階段,HCI傳輸驅動層負責把由上層傳輸過來的HCI數(shù)據(jù)包傳給UART驅動層,然后通過UART驅動層把數(shù)據(jù)傳輸?shù)剿{牙主機控制器。在接收數(shù)據(jù)時,HCI傳輸驅動層的作用正好相反。
在驅動程序的設計中,把傳輸狀態(tài)分為空閑態(tài)、傳輸類型態(tài)、傳輸頭態(tài)和傳輸數(shù)據(jù)態(tài)。HCI數(shù)據(jù)發(fā)送時根據(jù)傳輸狀態(tài)來判斷在哪一狀態(tài)。發(fā)送的數(shù)據(jù)包由類型字段、頭字段和數(shù)據(jù)構成。在發(fā)送數(shù)據(jù)階段,數(shù)據(jù)傳輸?shù)念愋妥侄螛酥緜鬏數(shù)氖敲睢?/SPAN>ACL數(shù)據(jù)還是SCO數(shù)據(jù),然后根據(jù)發(fā)送的類型來確定發(fā)送頭字段的長度,最后再發(fā)送數(shù)據(jù)。在接收數(shù)據(jù)階段,數(shù)據(jù)傳輸?shù)念愋妥侄螛酥緜鬏數(shù)氖鞘录?/SPAN>ACL數(shù)據(jù)還是SCO數(shù)據(jù)。不同的是在接收數(shù)據(jù)階段需要緩沖來接收數(shù)據(jù)。HCI傳輸驅動程序的數(shù)據(jù)結構如下所示:
在發(fā)送流程中,先對發(fā)送的狀態(tài)、看門狗、UART等初始化。使其處在待發(fā)送數(shù)據(jù)狀態(tài)。具體的發(fā)送流程如圖4所示。
接收流程和發(fā)送流程類似,所不同的是需要緩沖來接收,在此不再贅述。