當前位置:首頁 > 通信技術 > 通信技術
[導讀]從應用的角度出發(fā),闡述系統(tǒng)級RF收發(fā)芯片nRF24E1的RADIO口控制方法和工作過程;分析nRF24E1的收發(fā)方式。

    摘要:從應用的角度出發(fā),闡述系統(tǒng)級RF收發(fā)芯片nRF24E1的RADIO口控制方法和工作過程;分析nRF24E1的收發(fā)方式;詳細介紹ShockBUrst技術、DuoCeiver技術和應用中器件的配置方法并通過代碼說明實際應用中的編程方法。

    關鍵詞:nRF24E1 射頻 無線通信 配置

引言

nRF24E1收發(fā)器是Nordic VLSI推出的系統(tǒng)級射頻芯片,采用先進的0.18μm CMOS工藝、6mm×6mm的36引腳QFN封裝,以nRF240 RF芯片結構為基礎,將射頻率、8051MCU、9輸入10位ADC、125通道、UART、SPI、PWM、RTC、WDT全部集成到單芯片中,是目前世界首次推出的、全球2.4GHz通用的、完事的低成本射頻系統(tǒng)級芯片。

由于nRF24E1片內(nèi)集成了RADIO模塊,在使用中,只需要一片nRF24E1和少數(shù)的外圍元件就能完成射頻收發(fā)功能,因此,大大減少了系統(tǒng)的體積。使用nRF24E1時,必須進行相應的配置工作。下面,詳細講述nRF24E1的收發(fā)原理和編程方法,以供讀者設計時參考。有關nRF24E1的介紹請見2004年第6期。

1 RADIO口

nRF24E1收發(fā)器的收發(fā)任務由RADIO口控制。RADIO口使用標準8051中的P2口地址。由于射頻收發(fā)器是片內(nèi)置的,并不是雙向工作。為了滿足射頻收發(fā)子系統(tǒng)的需要,RADIO口的默認值與標準8051的P2默認值也不一樣。

收發(fā)器由特殊功能豁口中的RADIO(0A0H)和SPI_CTRL(0B3H)控制。SPI_CTRL=00B時,SPI沒用;SPI_CTRL=01B時,SPI連接到P1口;SPI_CTRL=10B時,SPI連到第一個nRF2401頻道;SPI_CTRL=11B時,SPI連接到第二個nRF2401頻道。RADIO豁口的各個位如圖1所示。在nRF24E1頭文件中,所定義的各個位的名字與圖1中一樣。

(1)用SPI口控制收發(fā)器

用芯片內(nèi)嵌的SPI口控制收發(fā)器的操作非常方便。如RF配置和ShockBurst RX(接收)或TX(發(fā)送)。

(2)復位時RADIO口的狀態(tài)

復位引腳為高電平時(無論是時鐘是否有效),控制nRF2401收發(fā)子系統(tǒng)的RADIO輸出位默認為RADIO.3(CS)=0,RADIO.6(CE)=0,RADIO.7(PWR_UP)=1。程序運行后,保持默認值,直到程序通過RADIO寄存器改變各位的值。

2 收發(fā)方式

通過PWR_UP、CE和CS三個控制引腳,可以設置nRF2401的工作方式。PWR_UP=1,CE=1,CS=0為收發(fā)方式;PWR_UP=1,CE=0,CS=1為配置方式;PWR_UP=1,CE=0,CS=0為空閑方式;PWPWR_UP=0時關機。

2.1 ShockBurst

nRF24E1的nRF2401收發(fā)子系統(tǒng)的收發(fā)方式只有ShockBurst。ShockBurst的功能由配置字決定。ShockBurst技術使用了片內(nèi)的FIFO(先入先出)堆棧。雖然數(shù)據(jù)低速進入,但能高速發(fā)送,使能耗減到最低限度。

(1)ShockBurst發(fā)送

CPU接口引腳為CE、CLK1、DATA,工作流程如下:

①CPU有數(shù)據(jù)要發(fā)送時,把CE置高,nRF2401開始工作。

②接收節(jié)點地址和有效數(shù)據(jù)按時序被送到nRF2401子系統(tǒng),可通過應用協(xié)議或CPU設置,使這個速度小于1Mbps(如10kbps)。

③CPU把CE置低,激活ShockBurst發(fā)送。

④ShockBurst。

*給RF前端供電;

*完成RF包處理(加前綴,CRC校驗);

*數(shù)據(jù)高速發(fā)送(250kbps或1Mbps,可由用戶配置決定);

*發(fā)送完成,nRF2401返回空閑信號。

(2)ShockBurst接收

CPU的接口引腳為CE、DR1、CLK1、DATA,工作流程如下:

①校驗接收到的RF包的地址和欲接收的RF包中有效數(shù)據(jù)的長度。

②把CE置高,激活RX。

③經(jīng)過200μs處理,nRF2401子系統(tǒng)監(jiān)視啟動并等待信號的到來。

④當收到一個有效的數(shù)據(jù)包(正確的地址和CRC),nRF2401子系統(tǒng)移去前綴、地址和CRC位。

⑤nRF2401子系統(tǒng)通過把DR1置高來通知CPU。

⑥CPU把CE置低,把RF前端設為低功耗方式。

⑦CPU將按時序以適當?shù)乃俣龋ㄈ?0kbps)把有效數(shù)據(jù)取出。

⑧當所有的有效數(shù)據(jù)都送完,nRF2401子系統(tǒng)再次把DR1置低。如果CE保持為高,準備接收下一個數(shù)據(jù)包;CE為低,重新開始新的接收。

2.2 DuoCeiver

ShockBurst收發(fā)方式使nRF24E1能夠方便地同時接收兩個不同頻率的頻道發(fā)送的數(shù)據(jù),并且能夠使接收速度達到最大值。這意味著:

*nRF24E1通過一個天線,能夠接收兩個頻率相差8MHz(8個頻率通道)的1Mbps發(fā)射器(如nRF24E1、nRF2401或nRF2402)發(fā)送的數(shù)據(jù)。

*這兩個不同數(shù)據(jù)頻道的數(shù)據(jù)被分別送到兩套不同的接口——數(shù)據(jù)頻道1為CLK1、DATA和DR1,數(shù)據(jù)頻道2為CLK2、DOUT2和DR2。

DuoCeiver技術提供了兩個獨立、專用于接收的數(shù)據(jù)頻道,而不是采用兩個相互獨立的接收器。使用第二個數(shù)據(jù)頻道必須滿足要求:第二數(shù)據(jù)頻道的工作頻率至少比第一個頻道的工作頻率高8MHz。使用ShockBurst技術,CPU先取出其中一個數(shù)據(jù)頻道中的數(shù)據(jù),另一數(shù)據(jù)頻道中的數(shù)據(jù)等待CPU處理完。這樣不至于丟失數(shù)據(jù);同時,也降低了對CPU性能的要求。

3 器件配置

在配置方式下,配置字最高可達18字節(jié)。nRF2401子系統(tǒng)的配置字通過一個簡單的三線接口(CS、CLK1和DATA)送給配置寄存器。

3.1 ShockBurst的配置

ShockBurst方式配置字的作用是使nRF2401子系統(tǒng)能夠處理RF協(xié)議。在實際操作中,一旦完成協(xié)議并裝入了nRF2401子系統(tǒng),只有1字節(jié)(bit[7:0])的配置字需要更新。用于ShockBurst的配置字分為如下四塊(詳見表2):

*有效數(shù)據(jù)寬度(DATA2_W和DATA1_W),指明RF包中有效數(shù)據(jù)的位數(shù),這使nRF2401子系統(tǒng)能夠區(qū)分接收到數(shù)據(jù)包中的有效數(shù)據(jù)和CRC字節(jié);

*地址寬度(ADDR2和ADDR1),設置RF數(shù)據(jù)包中地址字節(jié)所占用的位數(shù),最高為40位,這使nRF2401字節(jié)系統(tǒng)能夠區(qū)分地址和有效數(shù)據(jù);

*接收頻道地址(ADDR_W),即接收數(shù)據(jù)的目標地址;

*CRC配置(CRC_L和CRC_EN),CRC_L用于設置CRC為8位或16位校驗,CRC_L=0為8位,CRC_L=1為16位,CRC_EN使能片內(nèi)的CRC。

在發(fā)送方式,CPU必須產(chǎn)生與接收數(shù)據(jù)的nRF2401子系統(tǒng)配置相同的地址和有效數(shù)據(jù)塊。當使用nRF240子系統(tǒng)片內(nèi)的CRC特性時,注意CRC是否已經(jīng)使能,并且注意在發(fā)送器和接收器上使用相同的長度。

3.2 配置字描述

配置字的讀取在CLK1的正邊沿時,從MSB(最高位)開始。新的配置從CS的下降沿開始。假如nRF2401子系統(tǒng)需要配置為ShockBurst方式,兩個接收頻道,則在VDD(芯片電源)上電后,只需120位的配置字。在協(xié)議、工作方式和接收頻道都配置好后,只需要1位(RXEN)來切換是接收或發(fā)射。在配置字被讀取的過程中,MSB(最高位)最先被讀到寄存器中。默認配置字為:h8E08.1C20.2000.0000.00E7.0000.E721.0F04,共18字節(jié),可根據(jù)需要進行取舍。

ShockBurst數(shù)據(jù)包的總位數(shù)最多不能超過256位,可通過式(1)計算有效數(shù)據(jù)的最大位數(shù)。

DATAx_W(bits)=256-ADDR_W-CRC (1)

其中:ADDR_W為配置字中B[32:18]所設置的接收地址的長度,8位~40位;CRC為配置字B[17]所設置的校驗字,8位或16位。4位或8位前綴是自動加進去的,不占用數(shù)據(jù)包的位數(shù)。由式(1)可知,要想在每個數(shù)據(jù)包中得到更長的有效數(shù)據(jù),可減少地址和CRC校驗位。

3.3 收發(fā)常用的配置

在兩個接收頻道的方式下,nRF24E1同時接收來自兩個不同頻率頻道的數(shù)據(jù)。第一個頻道的頻率在配置字B[7-1]中設置,第二個頻道通常比第一個頻道的頻率高8MHz。RX2_EN(B[15])為第二個頻道的使能位:RX2_EN=0時,第二個頻道不工作;RX2_EN=1時,第二個頻道使能。RFDR_SB為收發(fā)速率設置位:RFDR_SB(B[13])=0時,收發(fā)速率為250kbps;RFDR_SB=1時,收發(fā)速率為1Mbps。16MHz晶振時,250kbps的收發(fā)靈敏度比1Mbps的高10dB。XO_F(B[12-10])為晶振選擇位。RF_PWR(B[9-8])設置nRF24E1射頻輸出功率。

RF_CH#(B[7-1])設置nRF24E1的工作頻率,可通過式(2)計算發(fā)射頻率和頻道1的接收頻率,通過式(3)計算頻道2的接收頻率。RXEN為收發(fā)切換位。

ChannelRF=2400MHz+RF_CH#×1.0MHz (2)

ChannelRF=2400MHz+RF_CH#×1.0MHz+8MHz (3)

4 數(shù)據(jù)包描述

完整的射頻數(shù)據(jù)包由四部分組成:前綴、地址、有效數(shù)據(jù)和CRC。前綴一般是8位,也要吧設置為4位,由地址的首位決定。如果地址的首位是0,前綴為01010101;如果地址的首位是1,前綴為10101010。ShockBurst方式,前綴、地址和CRC都是在接收器收到數(shù)據(jù)包后自動移去只留有效數(shù)據(jù)。

5 應用中的程序

下面所述的程序都是在Keil C51 V7.07下調(diào)試通過的。限于篇幅,只分析其中的主要函數(shù)代碼。

(1)系統(tǒng)初始化函數(shù)

void Init(void){

//配置I/O口

P0_ALT=0x06;//P0_ALT=00000110B,P0.1為RXD,P0.2為TXD

P0_DIR=0x09;//P0_DIR=00001001B,P0.0和P0.3設為輸入

P1_DIR=0x03;//P1_DIR=00000011B,P1.0和P1.1設為輸入

…………//其它I/O口配置

PWR_UP=1;//開Radio,讀時不用,寫時為電源

SPICLK=0;//SPI時鐘為XTAL/8

SPI_CTRL=0x02;//把SPI與第一收發(fā)通道(CH1)相連

…………//串口配置、A/D配置等,或自己系統(tǒng)相關的一些配置

}

(2)接收器配置函數(shù)

void Init_Receiver(void){

unsigned char b;

CS=1;//打開配置方式

for(b=0;b<rconf.n;b++){ //b<15

SpiReadWrite(rconf.buf[b]); //發(fā)送接收器配置字

}

CS=0; //關配置方式

CE=1; //使能收發(fā)功能

}

(3)接收函數(shù)

void Receiver(void){

unsigned char b;

CS=1; //打開配置方式

for(b=0;b<rconf.n;b++){

SpiReadWrite(rconf.buf[b]); //發(fā)送接收器配置字

}

CS=0; //關配置方式

for(;;){

b=ReceivePacket(); //接收數(shù)據(jù)包

…………//接收后的處理函數(shù)等,可自己擴展

}

}

(4)發(fā)送函數(shù)

void Transmitter(void){

unsigned char b;

CS=1; //開配置方式

for(b=0;b<tconf.n;b++){

SpiReadWrite(tconf.buf[b]);//發(fā)送發(fā)送器配置字

}

CS=0; //關配置方式

b=KeyByte; //讀取數(shù)據(jù)

TransmitPacket(b); //發(fā)送數(shù)據(jù)

}

(5)其它

nRF24E1程序除了主要的初始化配置函數(shù)、接收器配置函數(shù)、接收函數(shù)和發(fā)送函數(shù)外,還有接收包處理函數(shù)、發(fā)送包處理函數(shù)、接收器配置字和發(fā)射器配置字等。Keil C51 V7.01及其以且的版本都支持nRF24E1,因此,編程非常方便。由于nRF24E1只有512字節(jié)的ROM,所以,在使用過程中,要擴展片外存儲器(Nordic公司推薦使用25320)。應用中,當VDD上電后,芯片通過SPI接口自動從片外存儲器讀取數(shù)據(jù)到片內(nèi)4KB和RAM中以便程序運行時使用。

本站聲明: 本文章由作者或相關機構授權發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

9月2日消息,不造車的華為或?qū)⒋呱龈蟮莫毥谦F公司,隨著阿維塔和賽力斯的入局,華為引望愈發(fā)顯得引人矚目。

關鍵字: 阿維塔 塞力斯 華為

加利福尼亞州圣克拉拉縣2024年8月30日 /美通社/ -- 數(shù)字化轉(zhuǎn)型技術解決方案公司Trianz今天宣布,該公司與Amazon Web Services (AWS)簽訂了...

關鍵字: AWS AN BSP 數(shù)字化

倫敦2024年8月29日 /美通社/ -- 英國汽車技術公司SODA.Auto推出其旗艦產(chǎn)品SODA V,這是全球首款涵蓋汽車工程師從創(chuàng)意到認證的所有需求的工具,可用于創(chuàng)建軟件定義汽車。 SODA V工具的開發(fā)耗時1.5...

關鍵字: 汽車 人工智能 智能驅(qū)動 BSP

北京2024年8月28日 /美通社/ -- 越來越多用戶希望企業(yè)業(yè)務能7×24不間斷運行,同時企業(yè)卻面臨越來越多業(yè)務中斷的風險,如企業(yè)系統(tǒng)復雜性的增加,頻繁的功能更新和發(fā)布等。如何確保業(yè)務連續(xù)性,提升韌性,成...

關鍵字: 亞馬遜 解密 控制平面 BSP

8月30日消息,據(jù)媒體報道,騰訊和網(wǎng)易近期正在縮減他們對日本游戲市場的投資。

關鍵字: 騰訊 編碼器 CPU

8月28日消息,今天上午,2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會開幕式在貴陽舉行,華為董事、質(zhì)量流程IT總裁陶景文發(fā)表了演講。

關鍵字: 華為 12nm EDA 半導體

8月28日消息,在2024中國國際大數(shù)據(jù)產(chǎn)業(yè)博覽會上,華為常務董事、華為云CEO張平安發(fā)表演講稱,數(shù)字世界的話語權最終是由生態(tài)的繁榮決定的。

關鍵字: 華為 12nm 手機 衛(wèi)星通信

要點: 有效應對環(huán)境變化,經(jīng)營業(yè)績穩(wěn)中有升 落實提質(zhì)增效舉措,毛利潤率延續(xù)升勢 戰(zhàn)略布局成效顯著,戰(zhàn)新業(yè)務引領增長 以科技創(chuàng)新為引領,提升企業(yè)核心競爭力 堅持高質(zhì)量發(fā)展策略,塑強核心競爭優(yōu)勢...

關鍵字: 通信 BSP 電信運營商 數(shù)字經(jīng)濟

北京2024年8月27日 /美通社/ -- 8月21日,由中央廣播電視總臺與中國電影電視技術學會聯(lián)合牽頭組建的NVI技術創(chuàng)新聯(lián)盟在BIRTV2024超高清全產(chǎn)業(yè)鏈發(fā)展研討會上宣布正式成立。 活動現(xiàn)場 NVI技術創(chuàng)新聯(lián)...

關鍵字: VI 傳輸協(xié)議 音頻 BSP

北京2024年8月27日 /美通社/ -- 在8月23日舉辦的2024年長三角生態(tài)綠色一體化發(fā)展示范區(qū)聯(lián)合招商會上,軟通動力信息技術(集團)股份有限公司(以下簡稱"軟通動力")與長三角投資(上海)有限...

關鍵字: BSP 信息技術
關閉
關閉