Radio Configuration
This module includes the platform abstraction for radio configuration.
Summary
| Functions | |
|---|---|
| otPlatRadioGetBusLatency(otInstance *aInstance) | uint32_tGet the bus latency in microseconds between the host and the radio chip.  | 
| otPlatRadioGetBusSpeed(otInstance *aInstance) | uint32_tGet the bus speed in bits/second between the host and the radio chip.  | 
| otPlatRadioGetCaps(otInstance *aInstance) | Get the radio capabilities.  | 
| otPlatRadioGetCcaEnergyDetectThreshold(otInstance *aInstance, int8_t *aThreshold) | Get the radio's CCA ED threshold in dBm measured at antenna connector per IEEE 802.15.4 - 2015 section 10.1.4.  | 
| otPlatRadioGetFemLnaGain(otInstance *aInstance, int8_t *aGain) | Gets the external FEM's Rx LNA gain in dBm.  | 
| otPlatRadioGetIeeeEui64(otInstance *aInstance, uint8_t *aIeeeEui64) | voidGets the factory-assigned IEEE EUI-64 for this interface.  | 
| otPlatRadioGetNow(otInstance *aInstance) | uint64_tGet the current time in microseconds referenced to a continuous monotonic local radio clock (64 bits width).  | 
| otPlatRadioGetPromiscuous(otInstance *aInstance) | boolGet the status of promiscuous mode.  | 
| otPlatRadioGetReceiveSensitivity(otInstance *aInstance) | int8_tGet the radio receive sensitivity value.  | 
| otPlatRadioGetTransmitPower(otInstance *aInstance, int8_t *aPower) | Get the radio's transmit power in dBm.  | 
| otPlatRadioGetVersionString(otInstance *aInstance) | const char *Get the radio version string.  | 
| otPlatRadioSetAlternateShortAddress(otInstance *aInstance, otShortAddress aShortAddress) | voidSet the alternate short address.  | 
| otPlatRadioSetCcaEnergyDetectThreshold(otInstance *aInstance, int8_t aThreshold) | Set the radio's CCA ED threshold in dBm measured at antenna connector per IEEE 802.15.4 - 2015 section 10.1.4.  | 
| otPlatRadioSetExtendedAddress(otInstance *aInstance, const otExtAddress *aExtAddress) | voidSet the Extended Address for address filtering.  | 
| otPlatRadioSetFemLnaGain(otInstance *aInstance, int8_t aGain) | Sets the external FEM's Rx LNA gain in dBm.  | 
| otPlatRadioSetMacFrameCounter(otInstance *aInstance, uint32_t aMacFrameCounter) | voidSets the current MAC frame counter value.  | 
| otPlatRadioSetMacFrameCounterIfLarger(otInstance *aInstance, uint32_t aMacFrameCounter) | voidSets the current MAC frame counter value only if the new given value is larger than the current value.  | 
| otPlatRadioSetMacKey(otInstance *aInstance, uint8_t aKeyIdMode, uint8_t aKeyId, const otMacKeyMaterial *aPrevKey, const otMacKeyMaterial *aCurrKey, const otMacKeyMaterial *aNextKey, otRadioKeyType aKeyType) | voidUpdate MAC keys and key index.  | 
| otPlatRadioSetPanId(otInstance *aInstance, otPanId aPanId) | voidSet the PAN ID for address filtering.  | 
| otPlatRadioSetPromiscuous(otInstance *aInstance, bool aEnable) | voidEnable or disable promiscuous mode.  | 
| otPlatRadioSetRxOnWhenIdle(otInstance *aInstance, bool aEnable) | voidSets the rx-on-when-idle state to the radio platform.  | 
| otPlatRadioSetShortAddress(otInstance *aInstance, otShortAddress aShortAddress) | voidSet the Short Address for address filtering.  | 
| otPlatRadioSetTransmitPower(otInstance *aInstance, int8_t aPower) | Set the radio's transmit power in dBm for all channels.  | 
Functions
otPlatRadioGetBusLatency
uint32_t otPlatRadioGetBusLatency( otInstance *aInstance )
Get the bus latency in microseconds between the host and the radio chip.
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | The bus latency in microseconds between the host and the radio chip. Return 0 when the MAC and above layer and Radio layer resides on the same chip.  | 
otPlatRadioGetBusSpeed
uint32_t otPlatRadioGetBusSpeed( otInstance *aInstance )
Get the bus speed in bits/second between the host and the radio chip.
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | The bus speed in bits/second between the host and the radio chip. Return 0 when the MAC and above layer and Radio layer resides on the same chip.  | 
otPlatRadioGetCaps
otRadioCaps otPlatRadioGetCaps( otInstance *aInstance )
Get the radio capabilities.
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | The radio capability bit vector (see  OT_RADIO_CAP_*definitions). | 
otPlatRadioGetCcaEnergyDetectThreshold
otError otPlatRadioGetCcaEnergyDetectThreshold( otInstance *aInstance, int8_t *aThreshold )
Get the radio's CCA ED threshold in dBm measured at antenna connector per IEEE 802.15.4 - 2015 section 10.1.4.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | ||||||
| Return Values | 
 | 
otPlatRadioGetFemLnaGain
otError otPlatRadioGetFemLnaGain( otInstance *aInstance, int8_t *aGain )
Gets the external FEM's Rx LNA gain in dBm.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | ||||||
| Return Values | 
 | 
otPlatRadioGetIeeeEui64
void otPlatRadioGetIeeeEui64( otInstance *aInstance, uint8_t *aIeeeEui64 )
Gets the factory-assigned IEEE EUI-64 for this interface.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioGetNow
uint64_t otPlatRadioGetNow( otInstance *aInstance )
Get the current time in microseconds referenced to a continuous monotonic local radio clock (64 bits width).
The radio clock SHALL NOT wrap during the device's uptime. Implementations SHALL therefore identify and compensate for internal counter overflows. The clock does not have a defined epoch and it SHALL NOT introduce any continuous or discontinuous adjustments (e.g. leap seconds). Implementations SHALL compensate for any sleep times of the device.
Implementations MAY choose to discipline the radio clock and compensate for sleep times by any means (e.g. by combining a high precision/low power RTC with a high resolution counter) as long as the exposed combined clock provides continuous monotonic microsecond resolution ticks within the accuracy limits announced by otPlatRadioGetCslAccuracy.
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | The current time in microseconds. UINT64_MAX when platform does not support or radio time is not ready.  | 
otPlatRadioGetPromiscuous
bool otPlatRadioGetPromiscuous( otInstance *aInstance )
Get the status of promiscuous mode.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | ||||
| Return Values | 
 | 
otPlatRadioGetReceiveSensitivity
int8_t otPlatRadioGetReceiveSensitivity( otInstance *aInstance )
Get the radio receive sensitivity value.
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | The radio receive sensitivity value in dBm.  | 
otPlatRadioGetTransmitPower
otError otPlatRadioGetTransmitPower( otInstance *aInstance, int8_t *aPower )
Get the radio's transmit power in dBm.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | ||||||
| Return Values | 
 | 
otPlatRadioGetVersionString
const char * otPlatRadioGetVersionString( otInstance *aInstance )
Get the radio version string.
This is an optional radio driver platform function. If not provided by platform radio driver, OpenThread uses the OpenThread version instead (
| Details | |||
|---|---|---|---|
| Parameters | 
 | ||
| Returns | A pointer to the OpenThread radio version.  | 
otGetVersionString()).
otPlatRadioSetAlternateShortAddress
void otPlatRadioSetAlternateShortAddress( otInstance *aInstance, otShortAddress aShortAddress )
Set the alternate short address.
This is an optional radio platform API. The radio platform MUST indicate support for this API by including the capability OT_RADIO_CAPS_ALT_SHORT_ADDR in otPlatRadioGetCaps().
When supported, the radio should accept received frames destined to the specified alternate short address in addition to the short address provided in otPlatRadioSetShortAddress().
The aShortAddress can be set to OT_RADIO_INVALID_SHORT_ADDR (0xfffe) to clear any previously set alternate short address.
This function is used by OpenThread stack during child-to-router role transitions, allowing the device to continue receiving frames addressed to its previous short address for a short period.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetCcaEnergyDetectThreshold
otError otPlatRadioSetCcaEnergyDetectThreshold( otInstance *aInstance, int8_t aThreshold )
Set the radio's CCA ED threshold in dBm measured at antenna connector per IEEE 802.15.4 - 2015 section 10.1.4.
| Details | |||||||
|---|---|---|---|---|---|---|---|
| Parameters | 
 | ||||||
| Return Values | 
 | 
otPlatRadioSetExtendedAddress
void otPlatRadioSetExtendedAddress( otInstance *aInstance, const otExtAddress *aExtAddress )
Set the Extended Address for address filtering.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetFemLnaGain
otError otPlatRadioSetFemLnaGain( otInstance *aInstance, int8_t aGain )
Sets the external FEM's Rx LNA gain in dBm.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | ||||
| Return Values | 
 | 
otPlatRadioSetMacFrameCounter
void otPlatRadioSetMacFrameCounter( otInstance *aInstance, uint32_t aMacFrameCounter )
Sets the current MAC frame counter value.
Is used when radio provides OT_RADIO_CAPS_TRANSMIT_SEC capability.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetMacFrameCounterIfLarger
void otPlatRadioSetMacFrameCounterIfLarger( otInstance *aInstance, uint32_t aMacFrameCounter )
Sets the current MAC frame counter value only if the new given value is larger than the current value.
Is used when radio provides OT_RADIO_CAPS_TRANSMIT_SEC capability.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetMacKey
void otPlatRadioSetMacKey( otInstance *aInstance, uint8_t aKeyIdMode, uint8_t aKeyId, const otMacKeyMaterial *aPrevKey, const otMacKeyMaterial *aCurrKey, const otMacKeyMaterial *aNextKey, otRadioKeyType aKeyType )
Update MAC keys and key index.
Is used when radio provides OT_RADIO_CAPS_TRANSMIT_SEC capability.
The radio platform should reset the current security MAC frame counter tracked by the radio on this call. While this is highly recommended, the OpenThread stack, as a safeguard, will also reset the frame counter using the otPlatRadioSetMacFrameCounter() before calling this API.
| Details | |||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetPanId
void otPlatRadioSetPanId( otInstance *aInstance, otPanId aPanId )
Set the PAN ID for address filtering.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetPromiscuous
void otPlatRadioSetPromiscuous( otInstance *aInstance, bool aEnable )
Enable or disable promiscuous mode.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetRxOnWhenIdle
void otPlatRadioSetRxOnWhenIdle( otInstance *aInstance, bool aEnable )
Sets the rx-on-when-idle state to the radio platform.
There are a few situations that the radio can enter sleep state if the device is in rx-off-when-idle state but it's hard and costly for the SubMac to identify these situations and instruct the radio to enter sleep:
- Finalization of a regular frame reception task, provided that:- The frame is received without errors and passes the filtering and it's not an spurious ACK.
- ACK is not requested or transmission of ACK is not possible due to internal conditions.
 
- Finalization of a frame transmission or transmission of an ACK frame, when ACK is not requested in the transmitted frame.
- Finalization of the reception operation of a requested ACK due to:- ACK timeout expiration.
- Reception of an invalid ACK or not an ACK frame.
- Reception of the proper ACK, unless the transmitted frame was a Data Request Command and the frame pending bit on the received ACK is set to true. In this case the radio platform implementation SHOULD keep the receiver on until a determined timeout which triggers an idle period start.OPENTHREAD_CONFIG_MAC_DATA_POLL_TIMEOUTcan be taken as a reference for this.
 
- Finalization of a stand alone CCA task.
- Finalization of a CCA operation with busy result during CSMA/CA procedure.
- Finalization of an Energy Detection task.
- Finalization of a radio reception window scheduled with otPlatRadioReceiveAt.
If a platform supports OT_RADIO_CAPS_RX_ON_WHEN_IDLE it must also support OT_RADIO_CAPS_CSMA_BACKOFF and handle idle periods after CCA as described above.
Upon the transition of the "RxOnWhenIdle" flag from TRUE to FALSE, the radio platform should enter sleep mode. If the radio is currently in receive mode, it should enter sleep mode immediately. Otherwise, it should enter sleep mode after the current operation is completed.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetShortAddress
void otPlatRadioSetShortAddress( otInstance *aInstance, otShortAddress aShortAddress )
Set the Short Address for address filtering.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | 
otPlatRadioSetTransmitPower
otError otPlatRadioSetTransmitPower( otInstance *aInstance, int8_t aPower )
Set the radio's transmit power in dBm for all channels.
| Details | |||||
|---|---|---|---|---|---|
| Parameters | 
 | ||||
| Return Values | 
 | 
Resources
OpenThread API Reference topics originate from the source code, available on GitHub. For more information, or to contribute to our documentation, refer to Resources.