0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示

CC1101工作原理 基于與STM32的CC1101接口移植

ss ? 作者:工程師譚軍 ? 2018-09-06 14:45 ? 次閱讀

本文主要是關于CC1101的相關介紹,并著重對CC1101工作原理進行了詳盡的敘述。

CC1101

CC1101 [1] 是一款低于1GHz設計旨在用于極低功耗RF應用。其主要針對工業(yè)、科研和醫(yī)療(ISM)以及短距離無線通信設備(SRD)。CC1101可提供對數(shù)據(jù)包處理、數(shù)據(jù)緩沖、突發(fā)傳輸、接收信號強度指示(RSSI)、空閑信道評估(CCA)、鏈路質(zhì)量指示以及無線喚醒(WOR)的廣泛硬件支持。CC1101在代碼、封裝和外引腳方面均與CC1100兼容,可用于全球最為常用的開放式低于1GHz頻率的RF設計?!?超低功耗無線收發(fā)器● 家庭和樓宇自動化● 高級抄表架構(gòu)(AMI)● 無線報警安全系統(tǒng)◆ 387.0MHz~464.0MHz工作頻段。(433MHz,0.6kbps,1%誤碼率時為-116dBm)。(接收模式,433MHz,1.2kbps時僅16.0mA)?!?最高可設置為+10dBm的發(fā)射功率。◆ 支持0.6kbps~500kbps的數(shù)據(jù)傳輸速率。◆ 支持多種調(diào)制模式(OOK、ASK、GFSK、2-FSK、4-FSK和MSK)?!?提供對同步字檢測、地址校驗、靈活的數(shù)據(jù)包長度以及自動CRC處理的支持?!?支持RSSI(接收信號強度指示)和LQI(鏈路質(zhì)量指示)?!?通過4線SPI接口MCU連接,同時提供2個可設定功能的通用數(shù)字輸出引腳?!?獨立的64字節(jié)RXFIFO和TX FIFO?!?工作電壓范圍:1.9V~3.6V,待機模式下電流僅為200nA。◆ 工作溫度范圍:-40℃~+85℃

CC1101工作原理 基于與STM32的CC1101接口移植

基于與STM32的CC1101接口移植

移植原來TI對于CC1101與MSP430接口庫到STM32平臺,參考原TI庫應用筆記“ MSP430 Interface to CC1100/2500 Code Library”,做到盡量保持所有函數(shù)名不改變,以方便以前基于MSP430的程序向STM32移植。

【要求】

1.編程要求:改寫原來基于MSP430的程序,使用于STM32,盡量保持所有函數(shù)名不改變,以方便以前基于MSP430的程序向STM32移植。

2.實現(xiàn)功能:STM32與CC1101通過SPI接口正常傳輸數(shù)據(jù),不同節(jié)點的CC1101可以正常傳輸數(shù)據(jù)。

3.實驗現(xiàn)象:STM32與CC1101連接后,可以與另一個節(jié)點通信,節(jié)點初始在隨機時間發(fā)送一個數(shù)據(jù),任一節(jié)點收到數(shù)據(jù)后LED閃一下,并把數(shù)據(jù)回傳,如此循環(huán),會看到LED不停閃爍。

【硬件電路】

測試時CC1101與STM32引腳連接表如表1所示。

CC1101工作原理 基于與STM32的CC1101接口移植

原理】

CC1101是TI公司一款高性價比的單片UHF收發(fā)器,為低功耗無線電應用而設計。它是CC1100器件的加強升級版,靈敏度更高,功耗更小,帶寬更大。CC1101可滿足多個領域中的低功耗無線應用要求,如警報與安全、自動抄表、工業(yè)監(jiān)控以及家庭和樓宇自動化等。CC1101理想適用于工業(yè)、科學及醫(yī)藥設備(ISM)以及316、433、868及916MHz短距裝置(SRD)頻帶。但是,該器件也可方便編程,以支持其它頻率,如300-348MHz、387-467MHz及779-928MHz等。出色的頻帶與調(diào)制格式支持使其能與目前的RF終端設備相兼容。

CC1101工作原理 基于與STM32的CC1101接口移植

圖1 CC1101 的外引腳圖(俯視)

CC1100通過4線SPI兼容接口 (SI,SO,SCLK和 CSn)配置。這個接口同時用作寫和讀緩存數(shù)據(jù)。SPI 接口上所有的處理都同一個包含一個讀/寫位,一個突發(fā)訪問位和一個 6 位地址的頭字節(jié)一起作用。在地址和數(shù)據(jù)轉(zhuǎn)換期間, CSn 腳 (芯片選擇,低電平有效)必須保持為低電平。如果在過程中 CSn 變?yōu)楦唠娖?,則轉(zhuǎn)換取消。當 CSn 變低, 在開始轉(zhuǎn)換頭字節(jié)之前, MCU必須等待,直到 SO腳變低。這表明電壓調(diào)制器已經(jīng)穩(wěn)定,晶體正在運作中。除非芯片處在 SLEEP 或 XOFF 狀態(tài),SO 腳在 CSn變低之后總會立即變低。關于CC1101對配置寄存器寫和讀操作如圖2所示。

芯片狀態(tài)位

當頭字節(jié)在 SPI 接口上被寫入時,芯片狀態(tài)字節(jié)在 SO 腳上被 CC1100 寫入。狀態(tài)字節(jié)包含關鍵狀態(tài)信號,對MCU是有用的。第一位 s7,是CHIP_RDYn 信號。在 SCLK的在第一個正邊緣之前,這個信號必須變低。CHIP_RDYn 信號表明晶體正處于工作中,調(diào)節(jié)數(shù)字供給電壓是穩(wěn)定的。6,5 和4 位由狀態(tài)值組成。這個值反映了芯片的狀態(tài)。 當使 XOSC 空閑并使數(shù)字中心的能量開啟,所有其他模塊處于低功耗狀態(tài)時。只有芯片處于此狀態(tài)時,頻率和信道配置才能被更新。當芯片處于接收模式時, RX狀態(tài)是活動的。同樣地,當芯片處于發(fā)送模式時,TX狀態(tài)是活動的。狀態(tài)字節(jié)中的后四位( 3 :0)包含F(xiàn)IFO_BYTES_AVAILABLE。為了進行讀操作,這個區(qū)域包含可從 RX FIFO 讀取的字節(jié)數(shù)。為了進行寫操作,這個區(qū)域包含可寫入 TX FIFO 的 字節(jié)數(shù)。

寄存器訪問

CC1100配置寄存器位于SPI地址從0x00到0x2F之間。所有的配置寄存器均能讀和寫。當對寄存器寫時,每當一個待寫入的數(shù)據(jù)字節(jié)傳輸?shù)?SI腳時,狀態(tài)字節(jié)將被送至 SO腳。 通過在地址頭設置突發(fā)位,連續(xù)地址的寄存器能高效地被訪問。這個地址在內(nèi)部計數(shù)器內(nèi)設置起始地址。每增加一個新的字節(jié)計數(shù)器值增加 1。 突發(fā)訪問,不管是讀訪問還是寫訪問,必須通過設置CSn 為高來終止。對 0x30-0x3D間的地址來說, 突發(fā)位用以在狀態(tài)寄存器和命令濾波之間選擇。狀態(tài)寄存器只讀。突發(fā)讀取對狀態(tài)寄存器是不可取的,故它們每次只能被讀一個。

命令濾波

命令濾波可被視為 CC1100 的單字節(jié)指令。通過命令濾波寄存器的選址,內(nèi)部序列被啟動。這些命令用來關閉晶體振蕩器,開啟傳輸模式和電磁波激活等。命令濾波寄存器的訪問和一個寄存器的寫操作一樣,但沒有數(shù)據(jù)被傳輸。就是說,只

有 R/W 位(置為 0) ,突發(fā)訪問(置為 0)和六個地址位(0x30和0x3D之間)被寫。一個命令濾波可能在任何其他 SPI 訪問之后,而不需要將 CSn 拉至高電平。命令濾波立即被執(zhí)行,當 CSn 高時 SPWD和 SXOFF濾波是例外。

FIFO訪問

64 字節(jié) TX FIFO 和 64 字節(jié) RX FIFO 通過0x3F 被訪問。當讀/寫位為 0 時,TX FIFO被訪問,當讀/寫位為 1 時,RX FIFO 被訪問。 TX FIFO是只寫的,而 RX FIFO是只讀的。突發(fā)位用來決定 FIFO 訪問是單字節(jié)還是突發(fā)訪問。單字節(jié)訪問方式期望地址的突發(fā)位為 0 及1 數(shù)據(jù)字節(jié)。在數(shù)據(jù)字節(jié)之后等待一個新的地址,因此,CSn繼續(xù)保持低。突發(fā)訪問方式允許一地址字節(jié),然后是連續(xù)的數(shù)據(jù)字節(jié),直到通過設置 CSn 為高來關斷訪問。 當對 TX FIFO寫時,狀態(tài)字節(jié)對每個 SO腳上的新數(shù)據(jù)字節(jié)是輸出量,如圖 6 所示。這個狀態(tài)位能用來偵測對 TX FIFO 寫數(shù)據(jù)時的下溢。注意,狀態(tài)字節(jié)包含在寫入字節(jié)到 TX FIFO 的過程前空閑的字節(jié)數(shù)。當最后一個適合 TX FIFO的字節(jié)被傳送至 SI 腳后, 被 SO腳接收的狀態(tài)位會表明在 TX FIFO中只有一個字節(jié)是空閑的。

傳輸 FIFO 可能會通過發(fā)布一個 SFTX 命令濾波而被淹沒。相似地,一個 SFRX命令濾波會淹沒接收 FIFO。當進入休眠狀態(tài)時, 兩個 FIFO都被清空。PATABLE 訪問

0x3E 地址用來訪問 PATABLE。PATABLE用來選擇 PA 能量控制設置。在接收此地址之后,SPI 等待至少 8 個字節(jié)。通過控制PATABLE,能實現(xiàn)可控的 PA能量上升和下降,減少的帶寬的 ASK 調(diào)制整型也如此PATABLE 是一個 8 字節(jié)表, 定義了 PA控制 設置, 為 8 個 PA 功率值(由FRENDO.PA_POWER 的 3 個位的值所選擇)的每一個所使用。這個表從最低位到最高位可讀和寫,一此一位。一個索引計數(shù)器用來控制對這個表的訪問。每讀出或?qū)懭氡碇械囊粋€字節(jié),計數(shù)器就加 1。當 CSn 為高時,計數(shù)值置為最小值。當達到最大值時,計數(shù)器由零重新開始計數(shù)。

PATABLE 訪問

對 PATABLE 的訪問是單字節(jié)或者突發(fā)訪問,由突發(fā)位決定。當使用突發(fā)訪問時,索引計數(shù)器的值增加;達到7時重新從0開始。讀/寫位控制訪問是寫訪問(R/W=0)或者讀訪問(R/W=1)。 如果一字節(jié)被寫入 PATABLE,且這個值將要被讀出,那么,為了設置索引計數(shù)器的值重為 0,CSn必須在讀訪問之前置為高。 注意,當 PATABLE 進入休眠狀態(tài)時,所存儲的內(nèi)容會丟失,特別是第一個字節(jié)。

CC1101工作原理 基于與STM32的CC1101接口移植

圖2 配置寄存器寫和讀操作

STM32的串行外設接口(SPI)

STM32的串行外設接口(SPI)有如下特性:

● 3線全雙工同步傳輸

● 帶或不帶第三根雙向數(shù)據(jù)線的雙線單工同步傳輸

● 8或16位傳輸幀格式選擇

● 主或從操作

● 支持多主模式

● 8個主模式波特率預分頻系數(shù)(最大為fPCLK/2)

● 從模式頻率 (最大為fPCLK/2)

● 主模式和從模式的快速通信

● 主模式和從模式下均可以由軟件或硬件進行NSS管理:主/從操作模式的動態(tài)改變

● 可編程的時鐘極性和相位

● 可編程的數(shù)據(jù)順序,MSB在前或LSB在前

● 可觸發(fā)中斷的專用發(fā)送和接收標志

● SPI總線忙狀態(tài)標志

● 支持可靠通信的硬件CRC

─ 在發(fā)送模式下,CRC值可以被作為最后一個字節(jié)發(fā)送

─ 在全雙工模式中對接收到的最后一個字節(jié)自動進行CRC校驗

● 可觸發(fā)中斷的主模式故障、過載以及CRC錯誤標志

● 支持DMA功能的1字節(jié)發(fā)送和接收緩沖器:產(chǎn)生發(fā)送和接受請求

通常SPI通過4個引腳與外部器件相連: MISO:主設備輸入/從設備輸出引腳。該引腳在從模式下發(fā)送數(shù)據(jù),在主模式下接收數(shù)據(jù)。 MOSI:主設備輸出/從設備輸入引腳。該引腳在主模式下發(fā)送數(shù)據(jù),在從模式下接收數(shù)據(jù)。 SCK:串口時鐘,作為主設備的輸出,從設備的輸入 NSS:從設備選擇。這是一個可選的引腳,用來選擇主/從設備。它的功能是用來作為“片

選引腳”,本實驗中沒有使用。SPI的方框圖如圖3所示。

CC1101工作原理 基于與STM32的CC1101接口移植

圖3 SPI內(nèi)部框圖

CC1101工作原理 基于與STM32的CC1101接口移植

圖4 數(shù)據(jù)幀格式圖

表2 源文件用途分類說明

CC1101工作原理 基于與STM32的CC1101接口移植

結(jié)語

關于CC1101的相關介紹就到這了,如有不足之處歡迎指正。

相關閱讀推薦:一文看懂CC110L與CC1101的區(qū)別

相關閱讀推薦:無線芯片CC1100和CC1101的區(qū)別

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學習之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 芯片
    +關注

    關注

    450

    文章

    49636

    瀏覽量

    417151
  • CC1101
    +關注

    關注

    4

    文章

    35

    瀏覽量

    23017
收藏 人收藏

    評論

    相關推薦

    CC1101組網(wǎng)與假死問題

    CC1101的異步串行工作模式?CC1101為什么無緣無故自動進入空閑模式?CC1101配置空閑信道評估CCA,導致發(fā)送死掉CC1101發(fā)射
    發(fā)表于 08-29 17:45

    TI CC1101學習筆記:工作原理簡單入門

    的重要地位,還不能被新的協(xié)議完全取代。在之前的文章中,小編也說過了部分的通信協(xié)議,在此不作一一細說了。言歸正傳,今天要說的主角是SUB-1G的TI品牌的CC1101工作原理。 產(chǎn)品概述:CC1101
    發(fā)表于 11-09 10:44

    TI CC1101學習筆記:工作原理簡單入門

    的重要地位,還不能被新的協(xié)議完全取代。在之前的文章中,小編也說過了部分的通信協(xié)議,在此不作一一細說了。言歸正傳,今天要說的主角是SUB-1G的TI品牌的CC1101工作原理。產(chǎn)品概述:CC1101
    發(fā)表于 11-12 10:35

    cc1101天線設計

    cc1101天線設計,又需要的朋友下來看看。
    發(fā)表于 02-15 15:10 ?102次下載

    cc1101數(shù)據(jù)手冊

    cc1101數(shù)據(jù)手冊,此數(shù)據(jù)手冊為ti最新版本。
    發(fā)表于 02-17 17:11 ?16次下載

    cc1101產(chǎn)品手冊(English)

    CC1101的Datasheet,德州儀器英文原版。
    發(fā)表于 04-28 11:51 ?5次下載

    cc1101中文數(shù)據(jù)手冊

    cc1101中文數(shù)據(jù)手冊
    發(fā)表于 09-22 11:05 ?79次下載
    <b class='flag-5'>cc1101</b>中文數(shù)據(jù)手冊

    CC1101無線模塊如何使用_cc1101無線模塊的程序及使用介紹

    CC1101無線模塊是采用TI公司的CC1101芯片制作的模塊,一般是工作在433M。長沙云寶電子科技有限公司的生產(chǎn)的CC1101無線模塊比較穩(wěn)定。
    發(fā)表于 04-12 15:29 ?1.7w次閱讀

    無線芯片CC1100和CC1101的區(qū)別 淺談CC1101芯片的特點

    CC1101 [1] 是一款低于1GHz設計旨在用于極低功耗RF應用。其主要針對工業(yè)、科研和醫(yī)療(ISM)以及短距離無線通信設備(SRD)。
    發(fā)表于 09-06 09:43 ?9916次閱讀

    淺談CC1101驅(qū)動在STM32F103的移植

    最后,TI驅(qū)動里提供的是輪詢的方式收發(fā)數(shù)據(jù),對于初期來說,首先需要實現(xiàn)CC1101工作,編譯調(diào)試移植STM32上的CC1101驅(qū)動代碼,
    的頭像 發(fā)表于 09-06 15:18 ?7586次閱讀
    淺談<b class='flag-5'>CC1101</b>驅(qū)動在<b class='flag-5'>STM32</b>F103的<b class='flag-5'>移植</b>

    CC1101與STC單片機通信

    很多CC1101的通信代碼進行移植都不能成功通信,很苦惱,只能自己細細研究,最后發(fā)現(xiàn)網(wǎng)上的CC1101與單片機通信的絕大多數(shù)代碼都是基于51單片機普通IO與CC1101進行通信,而我手
    發(fā)表于 11-15 16:51 ?18次下載
    <b class='flag-5'>CC1101</b>與STC單片機通信

    無線射頻芯片CC1101的特點和區(qū)別

    本文主要是關于無線芯片CC1100和CC1101的相關介紹,并著重對無線芯片CC1100和CC1101進行了詳盡的對比分析。 CC1101
    發(fā)表于 03-09 12:44 ?1212次閱讀

    無線射頻芯片CC1101的特點和區(qū)別

    本文主要是關于無線芯片CC1100和CC1101的相關介紹,并著重對無線芯片CC1100和CC1101進行了詳盡的對比分析。 CC1101CC110
    的頭像 發(fā)表于 03-09 18:28 ?2023次閱讀

    【芯選擇】CC1101芯片的模塊實例

    CC1101芯片CC1101是一款低于1GHz設計旨在用于極低功耗RF應用。其主要針對工業(yè)、科研和醫(yī)療(ISM)以及短距離無線通信設備(SRD)。CC1101可提供對數(shù)據(jù)包處理、數(shù)據(jù)緩沖、突發(fā)傳輸
    的頭像 發(fā)表于 12-02 09:51 ?1192次閱讀
    【芯選擇】<b class='flag-5'>CC1101</b>芯片的模塊實例

    CC2500和CC1101移植說明

    主要通過如何移植、移植注意、關于芯片配置、如何生成導出配置四大步驟來說明CC2500和CC1101移植
    的頭像 發(fā)表于 06-15 14:32 ?433次閱讀
    <b class='flag-5'>CC</b>2500和<b class='flag-5'>CC1101</b><b class='flag-5'>移植</b>說明