Silicon Labs無線收發(fā)器SI446x的應(yīng)用技巧
Silicon Labs的無線Sub-G產(chǎn)品Si446x現(xiàn)在已經(jīng)越來越多的用于表計(jì)產(chǎn)品,如氣表、電表等。由于在表計(jì)類老產(chǎn)品中TI的CC1101系列應(yīng)用非常廣泛,所以客戶使用Si446x時(shí),就會(huì)遇到和CC1101兼容問題,本文檔將解決此問題。
本文引用地址:http://2s4d.com/article/201602/287406.htmSi446x具有硬件CRC、Whitening和軟件CRC、Whitening,因?yàn)椴皇褂肅RC、Whitening和Manchester 時(shí),Si446x和CC1101通信配置比較簡(jiǎn)單,可以參照Si446x works with CC1101_v1.11.pdf文檔,本文檔只討論CRC、Whitening和Manchester同時(shí)使能時(shí)配置方法。
Si446x提供軟件CRC、Whitening算法支持和CC1101兼容,需要將寄存器PKT_WHT_BIT_NUM 0x1205的SW_WHT_CTRL和SW_CRC_CTRL位置1,使能SW whitening和SW CRC。為了確保Si446x開啟SW whitening特性可以和CC1101通信,寄存器PKT_WHT_SEED_15_8 0x1203和PKT_WHT_SEED_7_0 0x1204需要都設(shè)置為0xFF。
Si446x最為發(fā)送端時(shí),包格式需配置如下:
由于已經(jīng)開啟SW CRC和SW Whitening,所以必須關(guān)閉硬件CRC和Whitening,以免重復(fù)計(jì)算CRC和Whitening,寄存器PKT_FIELD_1_CONFIG的PN_START和WHITEN位都清零,寄存器PKT_FIELD_1_CRC_CONFIG也配置為0x00。關(guān)閉了硬件CRC,為了發(fā)送由軟件CRC計(jì)算出的2個(gè)字節(jié)CRC的值,發(fā)送數(shù)據(jù)時(shí)需要多發(fā)送兩個(gè)字節(jié)給TX FIFO作為CRC字節(jié),并且配置Field1的長(zhǎng)度時(shí),也需要額外增加2個(gè)字節(jié)。比如發(fā)送數(shù)據(jù)為7個(gè)字節(jié),PKT_FIELD_1_LENGTH_12_8和PKT_FIELD_1_LENGTH_7_0則配置成0x00,0x09。下圖是數(shù)據(jù)長(zhǎng)度為7的示意圖,其中最后兩個(gè)字節(jié)可以是任意值。
Si446x最為接收端時(shí),包格式需配置如下:
由于已經(jīng)開啟SW CRC和SW Whitening,所以必須關(guān)閉硬件CRC和Whitening,以免重復(fù)計(jì)算CRC和Whitening,寄存器PKT_FIELD_1_CONFIG的PN_START和WHITEN位都清零,寄存器PKT_FIELD_1_CRC_CONFIG也配置為0x00。關(guān)閉了硬件CRC,為了發(fā)送由軟件CRC計(jì)算出的2個(gè)字節(jié)CRC的值,發(fā)送數(shù)據(jù)時(shí)需要多發(fā)送兩個(gè)字節(jié)給TX FIFO作為CRC字節(jié),并且配置Field1的長(zhǎng)度時(shí),也需要額外增加2個(gè)字節(jié)。比如發(fā)送數(shù)據(jù)為7個(gè)字節(jié),PKT_FIELD_1_LENGTH_12_8和PKT_FIELD_1_LENGTH_7_0則配置成0x00,0x09。下圖是數(shù)據(jù)長(zhǎng)度為7的示意圖,其中最后兩個(gè)字節(jié)可以是任意值。
Si446x最為接收端時(shí),包格式需配置如下:
同樣由于使能了SW CRC和SW Whitening,需要將寄存器PKT_FIELD_1_CONFIG的PN_START和WHITEN位都清零,寄存器PKT_FIELD_1_CRC_CONFIG也配置為0x00,關(guān)閉硬件CRC和Whitening。如果配置了寄存器PKT_CONFIG1 0x1206的PH_FIELD_SPLIT位,則TX和RX的寄存器分開配置,需要將寄存器PKT_RX_FIELD_X_CONFIG (X = 1, 2)的PN_START 和WHITEN位清零,寄存器PKT_RX_FIELD_X_CRC_CONFIG (X = 1, 2)設(shè)置為0x00。由于禁止了硬件CRC,接收數(shù)據(jù)時(shí)就不會(huì)自動(dòng)接收CRC字節(jié),并且接收的Field2的長(zhǎng)度只包含了Address和Data。為了能夠從空中接收CRC字節(jié),則需要告訴IC多接收2個(gè)字節(jié),這2個(gè)字節(jié)就是CRC字節(jié),所以需要調(diào)整接收端的包的長(zhǎng)度,分以下兩種情況配置。
1、接收端配置為固定包長(zhǎng)模式(寄存器PKT_LEN的ENDIAN位是0)
a、如果PH_FIELD_SPLIT位是0,則Feild1長(zhǎng)度配置成1,寄存器PKT_FIELD_1_LENGTH_12_8和PKT_FIELD_1_LENGTH_7_0配置成0x00,0x01.Feild2的長(zhǎng)度需要加2個(gè)字節(jié),比如上面發(fā)送7個(gè)字節(jié),則寄存器PKT_RX_FIELD_2_LENGTH_12_8和PKT_RX_FIELD_2_LENGTH_7_0配置成0x00,0x09。
b、PH_FIELD_SPLIT位是1,則上面的寄存器就是對(duì)應(yīng)的PKT_RX_FIELD_1_LENGTH和PKT_RX_FIELD_2_LENGTH。
2、接收端配置為可變包長(zhǎng)模式
則PKT_LEN需配置為0x21,PKT_LEN_FIELD_SOURCE配置為0x02,表示開啟可變包長(zhǎng)模式,F(xiàn)eild1是不可變的區(qū)域,F(xiàn)eild2是可變包長(zhǎng)區(qū)域。這種情況,可以配置PKT_LEN_ADJUST為0x02,接收端在接收數(shù)據(jù)時(shí)會(huì)自動(dòng)增加2個(gè)字節(jié)。PKT_LEN_ADJUST只針對(duì)可變包長(zhǎng)。如下圖為對(duì)應(yīng)發(fā)射的配置圖。
在上述基礎(chǔ)上增加Manchester,發(fā)送端需將PKT_FIELD_1_CONFIG的MANCH位置1;接收端需同時(shí)將PKT_FIELD_1_CONFIG和PKT_FIELD_2_CONFIG的MANCH位置1,或者是同時(shí)將PKT_RX_FIELD_1_CONFIG和PKT_RX_FIELD_2_CONFIG的MANCH位置1。
注意:
1、由于WDS中沒有留出勾選項(xiàng)來配置SW CRC和SW Whitening,所以需要在WDS配置基礎(chǔ)上生成工程,在工程中去修改相關(guān)寄存器。
2、在可變包長(zhǎng)模式中,如果使用PACKET_INFO來讀取接收到的包長(zhǎng),得到的是實(shí)際的包長(zhǎng),并且設(shè)備接收數(shù)據(jù)成功后的下一個(gè)狀態(tài)不可以設(shè)置為RX狀態(tài),讀到的數(shù)據(jù)長(zhǎng)度是最后一次收到數(shù)據(jù)的長(zhǎng)度。如果接收數(shù)據(jù)成功后就進(jìn)入下一個(gè)狀態(tài),那么使用PACKET_INFO命令得到數(shù)據(jù)會(huì)是0。這與讀取RSSI值是類似的。
評(píng)論