ADRV9009是一款高集成度射頻(RF)、捷變收發器,提供雙通道發射器和接收器、集成式頻率合成器以及數字信號處理功能。這款IC具備多樣化的高性能和低功耗組合,以滿足3G、4G和5G宏蜂窩時分雙工(TDD)基站應用要求。
應用
3G、4G和5G TDD宏蜂窩基站
TDD有源天線系統
大規模多路輸入、多路輸出(MIMO)
相控陣雷達
電子戰
軍事通信
便攜測試設備
下面介紹ADI提供的adrv9009_API功能描述。源代碼鏈接如下:https://github.com/analogdevicesinc/no-OS/blob/master/drivers/rf-transceiver/talise/api/talise_radioctrl.h
talise_radioctrl.h
1, uint32_t TALISE_loadStreamFromBinary(taliseDevice_t *device, uint8_t *binary);描述:將二進制數組加載到流處理器數據內存中。限制:此函數在設備初始化并驗證PLL鎖定狀態后調用。
2, uint32_t TALISE_setArmGpioPins(taliseDevice_t *device, taliseArmGpioConfig_t *armGpio);描述:指示用于TDD引腳控制的GPIO引腳,此功能應在radio關閉狀態下使用。限制:此函數可以在加載Talise ARM二進制文件后調用,但在初始化期間進入radioOn之前。
3, uint32_t TALISE_setRadioCtlPinMode(taliseDevice_t *device, uint8_t pinOptionsMask, taliseRadioCtlCfg2_t orxEnGpioPinSel);描述:設置引腳模式控制的Tx、Rx和ORx 控制位掩碼。此功能應在radio關閉狀態下使用。限制:此函數可在設備在運行時操作期間的任何時候完全初始化后調用,但要在配置了ARM和GPIO之后。
4, uint32_t TALISE_getRadioCtlPinMode(taliseDevice_t *device, uint8_t *pinOptionsMask, taliseRadioCtlCfg2_t *orxEnGpioPinSel);描述:讀取引腳模式控制的Tx、Rx和ORx 控制位掩碼。此功能應在radio關閉狀態下使用。限制:此函數可在設備在運行時操作期間的任何時候完全初始化后調用,但要在配置了ARM和GPIO之后。
5,uint32_t TALISE_setOrxLoCfg(taliseDevice_t *device, const taliseOrxLoCfg_t *orxLoCfg);描述:ORx LO(本機振蕩器)源(RFPLL或AuxPLL)設置。限制:這個函數應該在加載ARM之后,但在運行初始化校準之前調用。AuxLO頻率也必須在設置RFPLL頻率后,但在初始CAL之前設置。此函數可以在ARM READY(init cals之前)或Radio off狀態下調用。
6,uint32_t TALISE_getOrxLoCfg(taliseDevice_t *device, taliseOrxLoCfg_t *orxLoCfg);描述: 讀取ORx LO(本機振蕩器)源(RFPLL或AuxPLL)設置。此函數可用于讀回 TALISE_setOrxLoCfg()函數設置的 ORx LO 配置。限制:在調用TALISE_setOrxLoCfg()之后,可以隨時調用此函數。此函數可以在ARM READY(init cals(初始化校準)之前)或Radio off狀態下調用。
7,uint32_t TALISE_radioOn(taliseDevice_t *device);描述:指示ARM處理器將無線電狀態移到打開狀態。當ARM處于無線電打開狀態時,啟用的Rx和Tx信號鏈將通電,ARM跟蹤校準將開始。要將此狀態退出到低功耗脫機狀態,請調用TALISE_radioOff()函數。限制:此函數在設備初始化完成、所有PLL配置并鎖定、多芯片同步(MCS)完成、JESD204B鏈路配置并可運行之后調用。
8,uint32_t TALISE_radioOff(taliseDevice_t *device);描述:指示ARM處理器將無線電狀態移到關閉狀態。當ARM從Radio On狀態移動到Radio Off(Idle)時,ARM跟蹤校準停止,TxEnable/RxEnable等GPIO控制引腳將被忽略。這還將保持接收和發送鏈的電源關閉,直到再次調用TALISE_radioOn()函數。限制:這個函數可以在TALISE_radioOn被調用前的任何時間調用。
9,uint32_t TALISE_getRadioState(taliseDevice_t *device, uint32_t *radioStatus);描述:讀取當前ARM的無線電狀態。目前,radioStatus只返回低8位的數據,但定義為32位狀態字,以允許將來擴展位字段。限制:此函數可在設備完全初始化后隨時調用。
10,uint32_t TALISE_setRxTxEnable(taliseDevice_t *device, taliseRxORxChannels_t rxOrxChannel, taliseTxChannels_t txChannel);描述:此API將收發器中Rx/ORx/Tx信道設置啟用或禁用。限制:此函數可在進入radioOn后調用。在radioOff期間,所有發射和接收鏈都被強制關閉。
11,uint32_t TALISE_getRxTxEnable(taliseDevice_t *device, taliseRxORxChannels_t *rxOrxChannel, taliseTxChannels_t *txChannel);描述:這個API讀回收發器中通電的Rx/ORx/Tx信道。限制:此函數可在進入radioOn后調用。在radioOff期間,所有發射和接收鏈都被強制關閉。
12,uint32_t TALISE_setTxToOrxMapping(taliseDevice_t *device, uint8_t txCalEnable, taliseTxToOrxMapping_t oRx1Map, taliseTxToOrxMapping_t oRx2Map);描述:設置外部LOL初始化校準和跟蹤校準的Tx到ORx外部信號路由。限制:此函數可在ARM初始化和加載后調用。但是,在初始化校準運行之前,因為這同時用于外部LOL初始化和跟蹤校準。
13,uint32_t TALISE_setRfPllFrequency(taliseDevice_t *device, taliseRfPllName_t pllName, uint64_t rfPllLoFrequency_Hz);描述:設置RF PLL本機振蕩器(LO)頻率(RF載波頻率)。限制:此函數可以在ARM初始化后調用,并且設備必須處于radioOff狀態。
14,uint32_t TALISE_getRfPllFrequency(taliseDevice_t *device, taliseRfPllName_t pllName, uint64_t *rfPllLoFrequency_Hz);描述:獲取PLL本機振蕩器(LO)頻率(RF載波頻率)。此函數用于獲取鎖相環的當前頻率。為期望的PLL頻率傳遞一個taliserfllname_t枚舉類型,以讀取:RF_PLL、AUX_PLL或CLK_PLL。限制:此功能可在設備初始化和配置PLL后使用。對于AUX U PLL或RF U PLL,ARM固件也必須加載并運行以讀取PLL頻率。
15,uint32_t TALISE_getPllsLockStatus(taliseDevice_t *device, uint8_t *pllLockStatus);描述:檢查PLL是否鎖定。此函數通過pllLockStatus指針返回Talise PLLs的狀態。pllLockStatus下uint8 UT值的3個LSB代表CLK PLL、RF PLL和AUX PLL的鎖定狀態。限制:此函數可以在PLL配置和運行后的任何時候調用。
16,uint32_t TALISE_setRfPllLoopFilter(taliseDevice_t *device, uint16_t loopBandwidth_kHz, uint8_t stability);描述:設置射頻鎖相環濾波器的配置。此函數已棄用,應改用TALISE_setPllLoopFilter,因為它允許設置RF或Aux PLL環路濾波器設置。限制:他的函數可以在ARM初始化后調用,并且設備必須處于radioOff狀態。此功能后必須有TALISE_setRfPllFrequency函數,以便使用新配置設置RF PLL。
17,uint32_t TALISE_getRfPllLoopFilter(taliseDevice_t *device, uint16_t *loopBandwidth_kHz, uint8_t *stability);描述:獲取RF PLL環路濾波器的配置。此函數已棄用。應改用 TALISE_getPllLoopFilter,因為它允許讀取RF或Aux PLL環路濾波器設置。限制:此功能可在設備初始化和配置RF_PLL后使用。ARM固件也必須加載并運行。
18,uint32_t TALISE_setPllLoopFilter(taliseDevice_t *device, taliseRfPllName_t pllName, uint16_t loopBandwidth_kHz, uint8_t stability);描述:設置RFPLL或AuxPLL的環路濾波器帶寬限制:此函數可以在ARM初始化后調用,并且設備必須處于radioOff狀態。此功能之后必須為所選PLL設置TALISE_setRfPllFrequency函數,以使用新的環路濾波器設置設置PLL。
19, uint32_t TALISE_getPllLoopFilter(taliseDevice_t *device, taliseRfPllName_t pllName, uint16_t *loopBandwidth_kHz, uint8_t *stability);描述:獲取RFPLL或Aux PLL循環篩選器的循環篩選器設置。限制:該功能可在設備初始化并配置所需的鎖相環后使用。ARM固件也必須加載并運行。
20,uint32_t TALISE_setOrxLoSource(taliseDevice_t *device, taliseObsRxLoSource_t orxLoSource);描述:設置ORx LO(本機振蕩器)源(RF PLL或Aux PLL)。注:此功能將ORx的本振源設置為RF PLL或Aux PLL,但在ORx上升沿接通ORx信道之前,該設置才生效。如果在ORx通電時改變LO源,則LO源在ORx被禁用并重新啟用之前不會生效。這是有效的,當使用引腳設置本振源和控制時,也啟用了ORx。限制:此函數可在設備完全初始化且初始化校準已運行后使用。這只能在radio Off狀態下調用。
21,uint32_t TALISE_getOrxLoSource(taliseDevice_t *device, taliseObsRxLoSource_t *orx1LoSource, taliseObsRxLoSource_t *orx2LoSource);描述:獲取ORx LO(本機振蕩器)源(RF PLL或Aux PLL)限制:此函數可在設備完全初始化且初始化CAL已運行后使用。這可以在radio Off 或 On 狀態下調用。
22,uint32_t TALISE_setFhmConfig(taliseDevice_t *device, taliseFhmConfig_t *fhmConfig);描述:此功能配置跳頻觸發GPIO輸入到ARM和跳頻范圍。FHM觸發器GPIO引腳、跳頻最小頻率和跳頻最大頻率由該功能配置。FHM(frequency hopping mode ,調頻模式)。限制:此功能可在設備完全初始化和ARM處理器初始化后使用。此函數只能在radio Off狀態下調用。
23,uint32_t TALISE_getFhmConfig(taliseDevice_t *device, taliseFhmConfig_t *fhmConfig);描述:此函數用于檢索當前FHM設置。FHM(frequency hopping mode ,調頻模式)。此功能讀回跳頻觸發GPIO引腳、跳頻最小頻率和跳頻最大頻率。限制:無。
24,uint32_t TALISE_setFhmMode(taliseDevice_t *device, taliseFhmMode_t *fhmMode);描述:此功能設置跳頻模式。限制:此函數可在設備完全初始化、ARM處理器初始化并調用TALISE_setFhmConfig()之后使用。此函數只能在radio Off狀態下調用。
25,uint32_t TALISE_getFhmMode(taliseDevice_t *device, taliseFhmMode_t *fhmMode);描述:此函數用于檢索跳頻的當前FHM模式設置。此功能可用于讀取當前FHM配置(FHM啟用/禁用、MCS同步和退出模式設置的當前狀態)。限制:無。
26,uint32_t TALISE_setFhmHop(taliseDevice_t *device, uint64_t nextRfPllFrequency_Hz);描述:此函數設置下一個RF PLL低跳頻率,并在非gpio模式下向ARM發送跳到下一個頻率的命令。限制:此函數可在設備完全初始化、ARM處理器初始化、FHM配置通過TALISE_setFhmConfig()API設置、FHM模式通過TALISE_setFhmMode()API設置后調用。此API只能在Radio ON狀態下調用。
27,uint32_t TALISE_getFhmRfPllFrequency(taliseDevice_t *device, uint64_t *fhmRfPllFrequency_Hz);描述:此功能允許用戶在跳頻模式下讀回當前射頻鎖相環頻率。限制:無。
28,uint32_t TALISE_getFhmStatus(taliseDevice_t *device, taliseFhmStatus_t *fhmStatus);描述:此函數返回當前FHM狀態。此功能可用于讀取當前FHM狀態。狀態字段的詳細說明請參見taliseFhmStatus結構定義。限制:無。
29,uint32_t TALISE_setExtLoOutCfg(taliseDevice_t *device, uint8_t enableExtLoOutput, taliseExtLoDiv_t extLoOutDivide);描述:此功能啟用/禁用外部LO輸出并設置外部LO輸出分配器。限制:無。
30,uint32_t TALISE_getExtLoOutCfg(taliseDevice_t *device, uint8_t *enableExtLoOutput, taliseExtLoDiv_t *extLoOutDivide);描述:此功能讀回外部LO輸出和外部LO輸出分配器設置的啟用狀態。限制:無。
原文標題:ADRV9009_API功能描述
文章出處:【微信公眾號:FPGA之家】歡迎添加關注!文章轉載請注明出處。
-
收發器
+關注
關注
10文章
3437瀏覽量
106065 -
射頻
+關注
關注
104文章
5594瀏覽量
167911 -
數字信號
+關注
關注
2文章
972瀏覽量
47589 -
5G
+關注
關注
1355文章
48476瀏覽量
564760
原文標題:ADRV9009_API功能描述
文章出處:【微信號:zhuyandz,微信公眾號:FPGA之家】歡迎添加關注!文章轉載請注明出處。
發布評論請先 登錄
相關推薦
評論