33 #ifndef ti_drivers_RCL_commands_ble_cs_h__include 34 #define ti_drivers_RCL_commands_ble_cs_h__include 40 #include <ti/drivers/utils/List.h> 87 #define RCL_CMDID_BLE_CS 0x1101U 88 #define RCL_CMDID_BLE_CS_PRECAL 0x1102U 91 #define RCL_BLE_CS_US_TO_MCE_TIMER(x) ((x)*48) 92 #define RCL_BLE_CS_US_TO_PBE_TIMER(x) ((x)*4) 93 #define RCL_BLE_CS_MCE_TIMER_TO_US(x) ((x)/48) 94 #define RCL_BLE_CS_PBE_TIMER_TO_US(x) ((x)/12) 95 #define RCL_BLE_CS_MCE_TIMER_TO_PBE_TIMER(x) ((x)/4) 96 #define RCL_BLE_CS_DELAY_PS_TO_LUT(x) (((x)+16)/32) 99 #define RCL_BLE_CS_MAX_NUM_ANT 4 100 #define RCL_BLE_CS_MAX_NUM_ANT_PATH 5 101 #define RCL_BLE_CS_MAX_PAYLOAD_SIZE 4 102 #define RCL_BLE_CS_NUM_CORR 3 103 #define RCL_BLE_CS_NUM_STIM 2 104 #define RCL_BLE_CS_MAX_S2R_LEN 1024 105 #define RCL_BLE_CS_NUM_RX_GAIN_LEVEL 2 106 #define RCL_BLE_CS_STEP_RX_GAIN_DB 3 107 #define RCL_BLE_CS_NUM_PRECAL_CHANNELS 8 130 uint16_t repeatSteps:1;
131 uint16_t chFilterEnable:1;
151 uint16_t tRxWideningR0;
163 uint8_t foffOverrideEnable:1;
179 #define RCL_CmdBleCs_Default() \ 181 .common = RCL_Command_Default(RCL_CMDID_BLE_CS, \ 182 RCL_Handler_BLE_CS), \ 184 #define RCL_CmdBleCs_DefaultRuntime() (RCL_CmdBleCs) RCL_CmdBleCs_Default() 243 RCL_CmdBleCs_IQSample
dc;
262 RCL_CmdBleCs_IQSample
iq;
517 uint8_t lowValid : 1;
518 uint8_t highValid : 1;
520 RCL_CmdBleCs_DCSample
low;
536 uint8_t numEntries : 7;
538 RCL_CmdBleCs_PrecalEntry entries[];
545 #define RCL_CmdBleCs_PrecalTable_Default() \ 547 .callback = RCL_Handler_BLE_CS_PrecalDefaultCallback, \ 549 .highThreshold = 50, \ 550 .lowThreshold = 10, \ 556 .entries = {{.channel = 5}, \ 577 #define RCL_CmdBleCs_Precal_Default(pTable) \ 579 .common = RCL_Command_Default(RCL_CMDID_BLE_CS_PRECAL, \ 580 RCL_Handler_BLE_CS_Precal), \ 583 #define RCL_CmdBleCs_Precal_DefaultRuntime(pTable) (RCL_CmdBleCs_Precal) RCL_CmdBleCs_Precal_Default(pTable) 606 uint8_t chSpacing : 7;
607 uint8_t enPhaseComp : 1;
608 uint8_t enMagnComp : 1;
609 uint8_t numEntries : 7;
610 RCL_CmdBleCs_PctCompEntry entries[];
616 #ifndef RCL_BLE_CS_PHASE_DELAY_PS 617 #ifdef DeviceFamily_CC27XX 619 #define RCL_BLE_CS_PHASE_DELAY_PS (1100UL) 622 #define RCL_BLE_CS_PHASE_DELAY_PS (1500UL) 627 #define RCL_CmdBleCs_PctCompTable_Default() \ 629 .firstChannelIdx = 0, \ 634 .entries = {{.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 635 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 636 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 637 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 638 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 639 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 640 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 641 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 642 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 643 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}, \ 644 {.phaseDelay = RCL_BLE_CS_DELAY_PS_TO_LUT(RCL_BLE_CS_PHASE_DELAY_PS)}}, \ 672 #define RCL_CMD_BLE_CS_FREQCOMP_NA 0xC000 673 #define RCL_CMD_BLE_CS_TOAD_NA 0x8000 674 #define RCL_CMD_BLE_CS_RSSI_NA 0x7F 677 #define RCL_CMD_BLE_CS_SUBEVENT_RESULTS_OPCODE 0x31 678 #define RCL_CMD_BLE_CS_SUBEVENT_RESULTS_CONTINUE_OPCODE 0x32 686 uint32_t channelIdx : 7;
688 uint32_t antennaPacket: 3;
689 uint32_t antennaPermIdx : 5;
690 uint32_t toneExtension : 2;
691 uint32_t payloadLen : 3;
692 uint32_t reserved : 10;
744 uint32_t quality : 8;
819 RCL_CmdBleCs_Tone tones[];
839 RCL_CmdBleCs_Tone tones[];
uint16_t toneExtension
Definition: ble_cs.h:234
uint16_t procedureCounter
Definition: ble_cs.h:709
PCT compensation table for antenna/front-end delay.
Definition: ble_cs.h:604
uint16_t magnMin
Definition: ble_cs.h:505
uint8_t packetAntenna
Definition: ble_cs.h:788
void RCL_Handler_BLE_CS_PrecalDefaultCallback(RCL_CmdBleCs_PrecalTable *table, uint8_t channel, RCL_CmdBleCs_IQSample *pHigh, RCL_CmdBleCs_IQSample *pLow)
Definition: ble_cs.c:2451
RCL_CMD_BLE_CS_Tpm_e
Enumerator of tPm duration options.
Definition: ble_cs.h:371
#define RCL_BLE_CS_NUM_RX_GAIN_LEVEL
Definition: ble_cs.h:105
int8_t pktRssi
Definition: ble_cs.h:240
uint16_t startAclConnectionEvent
Definition: ble_cs.h:708
RCL_CMD_BLE_CS_Payload_e
Enumerator of payload length.
Definition: ble_cs.h:429
uint8_t channel
Definition: ble_cs.h:829
uint8_t configID
Definition: ble_cs.h:728
int16_t measuredFreqOffset
Definition: ble_cs.h:773
uint16_t tStep
Definition: ble_cs.h:208
uint8_t mode
Definition: ble_cs.h:753
uint32_t payload0
Definition: ble_cs.h:275
RCL_CmdBleCs_PrecalTable * table
Definition: ble_cs.h:573
enum RCL_CMD_BLE_CS_ReportFormat_e RCL_CmdBleCs_ReportFormat
Definition: ble_cs.h:82
uint16_t mode
Definition: ble_cs.h:233
BLE Channel Sounding.
Definition: ble_cs.h:124
int16_t frequencyCompensation
Definition: ble_cs.h:710
RCL_CMD_BLE_CS_Tfcs_e
Enumerator of tFcs duration options.
Definition: ble_cs.h:358
enum RCL_CMD_BLE_CS_ToneQuality_e RCL_CmdBleCs_ToneQuality
Definition: ble_cs.h:79
uint16_t tAdjustA
Definition: ble_cs.h:197
Container format for mode-2 step results.
Definition: ble_cs.h:812
int16_t packetToF
Definition: ble_cs.h:835
uint8_t channel
Definition: ble_cs.h:754
BLE Channel Sounding QQ data.
Definition: ble_cs.h:219
uint8_t dataLength
Definition: ble_cs.h:830
uint8_t mode
Definition: ble_cs.h:782
RCL_CMD_BLE_CS_Tip_e
Enumerator of tIp duration.
Definition: ble_cs.h:383
uint16_t nStepsDone
Definition: ble_cs.h:292
uint8_t packetAntenna
Definition: ble_cs.h:771
Container format for mode-3 step results.
Definition: ble_cs.h:826
uint16_t nStepsWritten
Definition: ble_cs.h:290
uint32_t payload3
Definition: ble_cs.h:278
#define RCL_BLE_CS_MAX_PAYLOAD_SIZE
Definition: ble_cs.h:101
uint8_t numAntennaPath
Definition: ble_cs.h:715
enum RCL_CMD_BLE_CS_Phy_e RCL_CmdBleCs_Phy
Definition: ble_cs.h:68
uint8_t numAntennaPath
Definition: ble_cs.h:299
Container format for a single step in the subevent.
Definition: ble_cs.h:685
BLE Channel Sounding S2R IQ Data.
Definition: ble_cs.h:270
enum RCL_CMD_BLE_CS_PacketResult_e RCL_CmdBleCs_PacketResult
Definition: ble_cs.h:71
int8_t referencePowerLevel
Definition: ble_cs.h:711
uint8_t subeventDoneStatus
Definition: ble_cs.h:713
uint8_t rplScaler
Definition: ble_cs.h:300
Container format for common section of step results.
Definition: ble_cs.h:751
RCL_CMD_BLE_CS_StepMode_e
Enumerator of step types.
Definition: ble_cs.h:332
RCL_CMD_BLE_CS_Role_e
Enumerator of role types.
Definition: ble_cs.h:321
uint8_t chSpacing
Definition: ble_cs.h:535
uint16_t channelIdx
Definition: ble_cs.h:232
int8_t lastRssi
Definition: ble_cs.h:296
RCL_CMD_BLE_CS_ReportFormat_e
Enumerator of report format.
Definition: ble_cs.h:479
enum RCL_CMD_BLE_CS_Tfcs_e RCL_CmdBleCs_Tfcs
Definition: ble_cs.h:72
uint16_t foffErr
Definition: ble_cs.h:196
uint8_t antennaPacket
Definition: ble_cs.h:206
uint8_t packetAAQuality
Definition: ble_cs.h:801
enum RCL_CMD_BLE_CS_Role_e RCL_CmdBleCs_Role
Definition: ble_cs.h:69
uint16_t reserved0
Definition: ble_cs.h:199
int8_t packetRssi
Definition: ble_cs.h:787
uint8_t mode
Definition: ble_cs.h:828
uint8_t firstChannelIdx
Definition: ble_cs.h:605
uint8_t numAntennaPath
Definition: ble_cs.h:732
uint8_t nadm
Definition: ble_cs.h:833
RCL_CMD_BLE_CS_Tsw_e
Enumerator of antenna switch duration.
Definition: ble_cs.h:397
uint16_t connectionHandle
Definition: ble_cs.h:727
uint16_t nRxOk
Definition: ble_cs.h:293
uint8_t packetAntenna
Definition: ble_cs.h:805
enum RCL_CMD_BLE_CS_Tpm_e RCL_CmdBleCs_Tpm
Definition: ble_cs.h:73
uint8_t abortReason
Definition: ble_cs.h:714
uint8_t magnCoeff
Definition: ble_cs.h:596
uint16_t antennaSequence
Definition: ble_cs.h:207
RCL_CmdBleCs_PrecalTable * precalTable
Definition: ble_cs.h:167
uint16_t payloadLen
Definition: ble_cs.h:195
uint16_t nResultsRead
Definition: ble_cs.h:291
uint8_t phy
Definition: ble_cs.h:272
uint8_t antennaPermutationIndex
Definition: ble_cs.h:818
uint8_t dataLength
Definition: ble_cs.h:799
RCL_CMD_BLE_CS_RxGain_e
Enumerator of RX gain.
Definition: ble_cs.h:443
uint8_t nadm
Definition: ble_cs.h:802
RCL_CmdBleCs_PrecalCallback callback
Definition: ble_cs.h:529
#define RCL_BLE_CS_MAX_NUM_ANT_PATH
Definition: ble_cs.h:100
RCL_CmdBleCs_Stats * stats
Definition: ble_cs.h:169
Index of the tx power table.
Definition: LRFCC23X0.h:169
uint8_t packetAntenna
Definition: ble_cs.h:836
int16_t foffComp
Definition: ble_cs.h:298
uint8_t dataLength
Definition: ble_cs.h:784
#define RCL_BLE_CS_MAX_NUM_ANT
Definition: ble_cs.h:99
uint8_t numStepsReported
Definition: ble_cs.h:733
BLE Channel Sounding Step Result.
Definition: ble_cs.h:231
uint16_t magnAvg
Definition: ble_cs.h:507
uint16_t tAntennaA
Definition: ble_cs.h:209
RCL_CMD_BLE_CS_ToneExtensionSlot_e
Enumerator of tone extension slot.
Definition: ble_cs.h:467
uint16_t channelIdx
Definition: ble_cs.h:192
enum RCL_CMD_BLE_CS_PacketAntenna_e RCL_CmdBleCs_PacketAntenna
Definition: ble_cs.h:83
uint8_t configID
Definition: ble_cs.h:707
int8_t phaseStart
Definition: ble_cs.h:503
RCL_CMD_BLE_CS_PacketAntenna_e
Definition: ble_cs.h:653
int16_t lastFoff
Definition: ble_cs.h:297
int16_t magnMin
Definition: ble_cs.h:220
enum RCL_CMD_BLE_CS_Nadm_e RCL_CmdBleCs_Nadm
Definition: ble_cs.h:84
uint8_t data[]
Definition: ble_cs.h:555
BLE Channel Sounding IQ Sample.
Definition: ble_cs.h:114
uint16_t tAntennaB
Definition: ble_cs.h:210
int16_t q
Definition: ble_cs.h:116
int16_t i
Definition: ble_cs.h:115
uint8_t channel
Definition: ble_cs.h:798
uint16_t tAdjustB
Definition: ble_cs.h:198
uint8_t gain
Definition: ble_cs.h:239
uint8_t procedureDoneStatus
Definition: ble_cs.h:729
uint16_t connectionHandle
Definition: ble_cs.h:706
uint8_t mode
Definition: ble_cs.h:814
Container format for mode-0 step results.
Definition: ble_cs.h:780
enum RCL_CMD_BLE_CS_ToneExtensionSlot_e RCL_CmdBleCs_ToneExtensionSlot
Definition: ble_cs.h:80
BLE Channel Sounding S2R Sample type definition.
Definition: ble_cs.h:259
uint8_t nS2RDone
Definition: ble_cs.h:295
uint16_t magnMax
Definition: ble_cs.h:506
RCL_CMD_BLE_CS_ToneQuality_e
Enumerator of tone quality.
Definition: ble_cs.h:454
int16_t i
Definition: ble_cs.h:501
BLE Channel Sounding DC Sample.
Definition: ble_cs.h:500
uint32_t timestamp
Definition: ble_cs.h:530
#define RCL_BLE_CS_NUM_CORR
Definition: ble_cs.h:102
uint8_t dataLength
Definition: ble_cs.h:767
uint8_t channel
Definition: ble_cs.h:545
uint8_t dataLength
Definition: ble_cs.h:755
uint16_t reserved1
Definition: ble_cs.h:211
uint32_t aaRx
Definition: ble_cs.h:204
enum RCL_CMD_BLE_CS_Tsw_e RCL_CmdBleCs_Tsw
Definition: ble_cs.h:75
Container format for a batch of step results in the subevent (second+ segment)
Definition: ble_cs.h:725
uint8_t antennaPermIdx
Definition: ble_cs.h:249
uint8_t reportFormat
Definition: ble_cs.h:165
RCL_Command common
Definition: ble_cs.h:125
RCL_CMD_BLE_CS_AntennaConfig_e
Enumerator of antenna configuration.
Definition: ble_cs.h:412
DC precalibration command.
Definition: ble_cs.h:571
RCL_Command common
Definition: ble_cs.h:572
uint32_t aaTx
Definition: ble_cs.h:203
uint8_t antennaPacket
Definition: ble_cs.h:250
uint16_t rtt
Definition: ble_cs.h:241
uint8_t idx
Definition: ble_cs.h:271
uint8_t packetAAQuality
Definition: ble_cs.h:786
int16_t q
Definition: ble_cs.h:502
uint8_t procedureDoneStatus
Definition: ble_cs.h:712
uint8_t antennaPermutationIndex
Definition: ble_cs.h:838
RCL_CMD_BLE_CS_PacketResult_e
Enumerator of packet status options.
Definition: ble_cs.h:345
int8_t phaseStop
Definition: ble_cs.h:504
int16_t magnMax
Definition: ble_cs.h:221
RCL_CMD_BLE_CS_Nadm_e
Definition: ble_cs.h:660
int16_t foffOverride
Definition: ble_cs.h:162
uint8_t subeventCode
Definition: ble_cs.h:705
uint8_t channel
Definition: ble_cs.h:783
int16_t magnAvg
Definition: ble_cs.h:222
uint8_t lowThreshold
Definition: ble_cs.h:532
uint32_t payload1
Definition: ble_cs.h:276
uint8_t numStepsReported
Definition: ble_cs.h:716
int8_t packetRssi
Definition: ble_cs.h:770
Container format for a batch of step results in the subevent (first segment)
Definition: ble_cs.h:704
uint32_t aaTx
Definition: ble_cs.h:693
uint16_t mode
Definition: ble_cs.h:193
uint32_t aaRx
Definition: ble_cs.h:694
Container format for mode-1 step results.
Definition: ble_cs.h:795
int16_t packetToF
Definition: ble_cs.h:804
uint8_t channel
Definition: ble_cs.h:273
uint8_t abortReason
Definition: ble_cs.h:731
uint8_t dataLength
Definition: ble_cs.h:816
uint8_t payloadLen
Definition: ble_cs.h:274
uint8_t channel
Definition: ble_cs.h:815
BLE Channel Sounding Statistics.
Definition: ble_cs.h:289
uint8_t highThreshold
Definition: ble_cs.h:531
Container format for tones.
Definition: ble_cs.h:741
enum RCL_CMD_BLE_CS_Payload_e RCL_CmdBleCs_Payload
Definition: ble_cs.h:77
uint32_t word
Definition: ble_cs.h:260
List_List stepBuffers
Definition: ble_cs.h:170
Channel entry for PCT compensation for antenna/front-end delay.
Definition: ble_cs.h:594
uint16_t toneExtension
Definition: ble_cs.h:194
RCL_CMD_BLE_CS_Phy_e
Enumerator of phy types.
Definition: ble_cs.h:309
int8_t packetRssi
Definition: ble_cs.h:803
List_List resultBuffers
Definition: ble_cs.h:172
uint8_t subeventDoneStatus
Definition: ble_cs.h:730
Container format for mode-0 step results.
Definition: ble_cs.h:763
uint16_t nRxNok
Definition: ble_cs.h:294
enum RCL_CMD_BLE_CS_StepMode_e RCL_CmdBleCs_StepMode
Definition: ble_cs.h:70
uint8_t mode
Definition: ble_cs.h:544
RCL_CmdBleCs_IQSample iq
Definition: ble_cs.h:262
uint16_t payloadLen
Definition: ble_cs.h:235
uint8_t mode
Definition: ble_cs.h:797
uint16_t pktResult
Definition: ble_cs.h:238
enum RCL_CMD_BLE_CS_RxGain_e RCL_CmdBleCs_RxGain
Definition: ble_cs.h:78
const RCL_AntennaConfig_t antennaConfig[RCL_CmdBleCs_AntennaConfig_Length]
Definition: ble_cs.c:184
uint16_t reserved
Definition: ble_cs.h:236
List_List stepBuffersDone
Definition: ble_cs.h:171
List_List s2rBuffersDone
Definition: ble_cs.h:175
uint8_t phaseDelay
Definition: ble_cs.h:595
int16_t magnAvgdB
Definition: ble_cs.h:223
uint8_t rxGain
Definition: ble_cs.h:533
uint8_t mode
Definition: ble_cs.h:765
RCL_CmdBleCs_IQSample dc
Definition: ble_cs.h:243
enum RCL_CMD_BLE_CS_Tip_e RCL_CmdBleCs_Tip
Definition: ble_cs.h:74
uint8_t antennaPermIdx
Definition: ble_cs.h:205
DC precalibration entry.
Definition: ble_cs.h:515
uint8_t channel
Definition: ble_cs.h:516
RCL_CmdBleCs_DCSample high
Definition: ble_cs.h:519
void(* RCL_CmdBleCs_PrecalCallback)(RCL_CmdBleCs_PrecalTable *table, uint8_t channel, RCL_CmdBleCs_IQSample *pHigh, RCL_CmdBleCs_IQSample *pLow)
Callback function for DC precalibration feature.
Definition: ble_cs.h:493
List_List s2rBuffers
Definition: ble_cs.h:174
int8_t temperature
Definition: ble_cs.h:534
BLE Channel Sounding Step.
Definition: ble_cs.h:191
RCL_CmdBleCs_StepResult_Internal * results
Definition: ble_cs.h:168
uint8_t packetAAQuality
Definition: ble_cs.h:832
RCL_CmdBleCs_DCSample low
Definition: ble_cs.h:520
uint8_t packetAAQuality
Definition: ble_cs.h:769
int8_t packetRssi
Definition: ble_cs.h:834
List_List resultBuffersDone
Definition: ble_cs.h:173
DC precalibration table.
Definition: ble_cs.h:528
uint32_t payload2
Definition: ble_cs.h:277
uint16_t reserved1
Definition: ble_cs.h:251
uint8_t subeventCode
Definition: ble_cs.h:726
struct RCL_CMD_BLE_CS_STEP_RESULTS_TONE_t __attribute__
Definition: hal_cc23x0.c:510
uint16_t reserved
Definition: ble_cs.h:301
enum RCL_CMD_BLE_CS_AntennaConfig_e RCL_CmdBleCs_AntennaConfig
Definition: ble_cs.h:76
uint16_t reserved
Definition: ble_cs.h:280
uint16_t iqLength
Definition: ble_cs.h:279
uint8_t channel
Definition: ble_cs.h:766
int16_t foffMeasured
Definition: ble_cs.h:237