41 #if defined(DeviceFamily_CC23X0R5) || defined(DeviceFamily_CC23X0R2) || defined(DeviceFamily_CC27XX) || defined(DeviceFamily_CC23X0R22) || defined(DeviceFamily_CC2340R53) 42 # include <ti/devices/DeviceFamily.h> 43 # include DeviceFamily_constructPath(inc/hw_types.h) 44 # include DeviceFamily_constructPath(inc/hw_lrfdpbe.h) 48 #ifdef DeviceFamily_CC1308 49 # define BUFFER_SPLIT_SUPPORT 50 # include "ti/drivers/rcl/LRFCC1308.h" 53 #ifdef DeviceFamily_CC1404_CC1407 54 # define BUFFER_SPLIT_SUPPORT 55 # include "ti/drivers/rcl/LRFCC1407.h" 62 #define LRF_TxPower_Use_Min ((LRF_TxPowerTable_Index){.rawValue = -128}) 67 #define LRF_TxPower_Use_Max ((LRF_TxPowerTable_Index){.rawValue = 125}) 72 #define LRF_TxPower_Use_Raw ((LRF_TxPowerTable_Index){.rawValue = 126}) 78 #define LRF_TxPower_None ((LRF_TxPowerTable_Index){.rawValue = 127}) 84 #define LRF_SETTINGS_BUFFER_UNLIMITED 0x3FFF 90 #define LRF_RSSI_INVALID (127) 93 typedef enum LRF_RadioState_e {
102 typedef enum LRF_SetupResult_e {
121 uint32_t lengthMinus1 : 12;
123 uint32_t startAddress : 16;
136 uint32_t length : 14;
137 uint32_t invertedFeatureMask : 1;
138 uint32_t compoundSegment : 1;
139 uint32_t featureMask : 16;
175 #ifdef BUFFER_SPLIT_SUPPORT 179 uint32_t segmentLength;
184 uint32_t regionLength;
185 uint32_t regionStart;
189 #define LRF_PhyFeatures_Default 0 192 #define __ERROR_Address_is_in_an_invalid_range_for_LRF_setup 0x00040000 194 #define _ADDRESS_REGION_BIT(_address) \ 195 ((((((uintptr_t)(_address)) >= (LRF_BASE_ADDR)) && \ 196 ((uintptr_t)(_address)) < ((LRF_BASE_ADDR) + 0x10000)) ? 0 : \ 197 ((((uintptr_t)(_address)) >= (PBE_RAM_BASE_ADDR)) && \ 198 (((uintptr_t)(_address)) < ((PBE_RAM_BASE_ADDR) + 0x10000)) ? \ 200 (((((uintptr_t)(_address)) >= 0) && \ 201 (((uintptr_t)(_address)) < 0x10000)) ? \ 203 (__ERROR_Address_is_in_an_invalid_range_for_LRF_setup)))) << 14) 205 #define LRF_SETTINGS_CLEAR(_startAddress, _numWords) \ 206 ((((_numWords) - 1) & 0x0FFF) | \ 207 _ADDRESS_REGION_BIT(_startAddress) | \ 208 ((((uintptr_t)(_startAddress)) & 0xFFFF) << 16)) 210 #define LRF_SETTINGS_16BIT_BLOCK(_startAddress, _numWords) \ 211 ((((_numWords) - 1) & 0x0FFF) | \ 212 _ADDRESS_REGION_BIT(_startAddress) | (1 << 12) | \ 213 ((((uintptr_t)(_startAddress)) & 0xFFFF) << 16)) 215 #define LRF_SETTINGS_16BIT_DUAL_ENTRY(_value0, _value1) \ 216 (((_value0) & 0xFFFF) | (((_value1) & 0xFFFF) << 16)) 218 #define LRF_SETTINGS_32BIT_BLOCK(_startAddress, _numWords) \ 219 ((((_numWords) - 1) & 0x0FFF) | \ 220 _ADDRESS_REGION_BIT(_startAddress) | (2 << 12) | \ 221 ((((uintptr_t)(_startAddress)) & 0xFFFF) << 16)) 223 #define LRF_SETTINGS_16BIT_SPARSE_BLOCK(_startAddress, _numWords) \ 224 ((((_numWords) - 1) & 0x0FFF) | \ 225 _ADDRESS_REGION_BIT(_startAddress) | (3 << 12)) \ 227 #define LRF_SETTINGS_16BIT_SPARSE_ENTRY(_address, _value) \ 228 (((((uintptr_t)(_address)) & 0xFFFF) << 16) | ((_value) & 0xFFFF)) 230 #define LRF_SETTINGS_16BIT_MASKED_BLOCK(_startAddress, _numWords) \ 231 ((((_numWords) - 1) & 0x0FFF) | (11 << 12) | \ 232 ((((uintptr_t)(_startAddress)) & 0xFFFF) << 16)) 234 #define LRF_SETTINGS_16BIT_MASKED_ENTRY(_mask, _value) \ 235 ((((_mask) & 0xFFFF) << 16) | ((_value) & 0xFFFF)) 243 #ifdef BUFFER_SPLIT_SUPPORT 244 state->totalLength = 0;
252 uint16_t phyFeatures);
255 int32_t bufferAvailWords);
int8_t LRF_readRssi(void)
Definition: LRFCC23X0.c:1644
void LRF_rclEnableRadioClocks(void)
Definition: LRFCC23X0.c:1620
void LRF_setClockEnable(uint16_t mask, uint8_t entryNumber)
static void LRF_resetSettingsState(LRF_ApplySettingsState *state)
Definition: LRF.h:241
LRF_SetupResult LRF_loadImage(const LRF_TOPsmImage *image, uint32_t destinationAddress)
Definition: LRF.c:46
LRF_RadioState
Definition: LRF.h:93
LRF_SetupResult
Setup operation result.
Definition: LRF.h:102
void LRF_sendHardStop(void)
LRF_SetupResult LRF_setupRadio(const LRF_Config *lrfConfig, uint16_t phyFeatures, LRF_RadioState lrfState)
Single entry of the tx power table. Maps power in dBm to specific register settings.
Definition: LRFCC23X0.h:182
void LRF_sendGracefulStop(void)
void LRF_discardRxFifoWords(uint32_t wordLength)
Definition: LRFCC23X0.c:1010
void LRF_peekRxFifoWords(uint32_t *data32, uint32_t wordLength, uint32_t startRp)
Definition: LRFCC23X0.c:1119
uint32_t value32
Definition: LRF.h:125
uint32_t image[]
Definition: LRF.h:116
Tx power table, containing all characterized dBm to register settings mappings.
Definition: LRFCC23X0.h:201
void LRF_writeTxFifoWords(const uint32_t *data32, uint32_t wordLength)
Definition: LRFCC23X0.c:1051
LRF_SetupResult LRF_applySettings(LRF_ConfigWord *config, LRF_ApplySettingsState *state, int32_t bufferAvailWords)
Definition: LRF.c:158
void LRF_clearClockEnable(uint16_t mask, uint8_t entryNumber)
Index of the tx power table.
Definition: LRFCC23X0.h:169
Radio configuration structure.
Definition: LRFCC23X0.h:580
uint32_t LRF_enableSynthRefsys(void)
Definition: LRFCC23X0.c:1590
uint32_t LRF_prepareRxFifo(void)
Definition: LRFCC23X0.c:894
uint8_t * LRF_getTxFifoWrAddr(int32_t offset)
Definition: LRFCC23X0.c:949
static void LRF_clearHwInterrupt(uint32_t mask)
Definition: LRF.h:313
LRF_ApplySettingsBase
Definition: LRF.h:165
uint32_t imageLen
Definition: LRF.h:115
bool LRF_imagesNeedUpdate(const LRF_Config *lrfConfig)
Definition: LRFCC23X0.c:307
void hal_enable_command_radio_interrupt(uint32_t mask)
Definition: hal_cc23x0.c:356
uint32_t swParamList[]
Definition: LRFCC23X0.c:151
static void LRF_disableHwInterrupt(uint32_t mask)
Definition: LRF.h:308
void hal_clear_command_radio_interrupt(uint32_t mask)
Definition: hal_cc23x0.c:362
void LRF_setRxFifoEffSz(uint32_t maxSz)
Definition: LRFCC23X0.c:1076
void hal_disable_command_radio_interrupt(uint32_t mask)
Definition: hal_cc23x0.c:367
void LRF_disable(void)
Definition: LRFCC23X0.c:857
void LRF_rclDisableRadioClocks(void)
Definition: LRFCC23X0.c:1632
void LRF_programFrequency(uint32_t frequency, bool tx)
Definition: LRFCC23X0.c:1501
static void LRF_enableHwInterrupt(uint32_t mask)
Definition: LRF.h:303
uint32_t LRF_getUncommittedFifoStatus(uint32_t *currentRp)
Definition: LRFCC23X0.c:1135
void LRF_disableSynthRefsys(void)
Definition: LRFCC23X0.c:1615
LRF_TxPowerTable_Entry LRF_TxPowerTable_findValue(const LRF_TxPowerTable *table, LRF_TxPowerTable_Index powerLevel)
Search for settings corresponding to the highest tx power lower than specified value in the tx power ...
Definition: LRF.c:761
const size_t swParamListSz
Definition: LRFCC23X0.c:152
uint16_t phyFeatures
Definition: LRF.h:172
void LRF_initSettingsState(LRF_ApplySettingsState *state, LRF_ApplySettingsBase includeBase, uint16_t phyFeatures)
Definition: LRF.c:149
uint32_t LRF_prepareTxFifo(void)
Definition: LRFCC23X0.c:913
void LRF_waitForTopsmReady(void)
Definition: LRFCC23X0.c:885
void LRF_enable(void)
Definition: LRFCC23X0.c:832
uint32_t numEntries
Definition: LRF.h:144
void LRF_setRawTxPower(uint32_t value, uint32_t temperatureCoefficient)
Definition: LRFCC23X0.c:1659
uint32_t LRF_peekTxFifo(int32_t offset)
Definition: LRFCC23X0.c:938
LRF_ApplySettingsBase includeBase
Definition: LRF.h:173
void LRF_readRxFifoWords(uint32_t *data32, uint32_t wordLength)
Definition: LRFCC23X0.c:1024
LRF_RegionOperation
Definition: LRF.h:148
LRF_TxPowerTable_Entry LRF_getRawTxPower(void)
Definition: LRFCC23X0.c:1666
void LRF_skipTxFifoWords(uint32_t wordLength)
Definition: LRFCC23X0.c:999
uint32_t LRF_peekRxFifo(int32_t offset)
Definition: LRFCC23X0.c:926