nrfxlib API 2.8.99
Loading...
Searching...
No Matches
nrf_802154_const.h File Reference

Go to the source code of this file.

Macros

#define RAW_LENGTH_OFFSET   0
 Module that contains definitions of constant values used by the nRF 802.15.4 driver.
 
#define RAW_PAYLOAD_OFFSET   1
 Offset of the frame payload in a raw frame.
 
#define ACK_HEADER_WITH_PENDING   0x12
 The first byte of an ACK frame containing a pending bit.
 
#define ACK_HEADER_WITHOUT_PENDING   0x02
 The first byte of an ACK frame without a pending bit.
 
#define ACK_REQUEST_OFFSET   1
 Byte containing the ACK request bit (+1 for the frame length byte).
 
#define ACK_REQUEST_BIT   (1 << 5)
 ACK request bit.
 
#define ASN_IN_NONCE_BIT   0x40
 Bit containing the ASN in Nonce field.
 
#define DEST_ADDR_TYPE_OFFSET   2
 Byte containing the destination address type (+1 for the frame length byte).
 
#define DEST_ADDR_TYPE_MASK   0x0c
 Mask of bits containing the destination address type.
 
#define DEST_ADDR_TYPE_EXTENDED   0x0c
 Bits containing the extended destination address type.
 
#define DEST_ADDR_TYPE_NONE   0x00
 Bits containing a not-present destination address type.
 
#define DEST_ADDR_TYPE_SHORT   0x08
 Bits containing the short destination address type.
 
#define DEST_ADDR_OFFSET   6
 Offset of the destination address in the Data frame (+1 for the frame length byte).
 
#define DSN_OFFSET   3
 Byte containing the DSN value (+1 for the frame length byte).
 
#define DSN_SUPPRESS_OFFSET   2
 Byte containing the DSN suppression field.
 
#define DSN_SUPPRESS_BIT   0x01
 Bits containing the DSN suppression field.
 
#define FRAME_COUNTER_SUPPRESS_BIT   0x20
 Bit containing the Frame Counter Suppression field.
 
#define FRAME_PENDING_OFFSET   1
 Byte containing a pending bit (+1 for the frame length byte).
 
#define FRAME_PENDING_BIT   (1 << 4)
 Pending bit.
 
#define FRAME_TYPE_OFFSET   1
 Byte containing the frame type bits (+1 for the frame length byte).
 
#define FRAME_TYPE_MASK   0x07
 Mask of bits containing the frame type.
 
#define FRAME_TYPE_ACK   0x02
 Bits containing the ACK frame type.
 
#define FRAME_TYPE_BEACON   0x00
 Bits containing the Beacon frame type.
 
#define FRAME_TYPE_COMMAND   0x03
 Bits containing the Command frame type.
 
#define FRAME_TYPE_DATA   0x01
 Bits containing the Data frame type.
 
#define FRAME_TYPE_EXTENDED   0x07
 Bits containing the Extended frame type.
 
#define FRAME_TYPE_FRAGMENT   0x06
 Bits containing the Fragment or the Frak frame type.
 
#define FRAME_TYPE_MULTIPURPOSE   0x05
 Bits containing the Multipurpose frame type.
 
#define FRAME_VERSION_OFFSET   2
 Byte containing the frame version bits (+1 for the frame length byte).
 
#define FRAME_VERSION_MASK   0x30
 Mask of bits containing the frame version.
 
#define FRAME_VERSION_0   0x00
 Bits containing the frame version 0b00.
 
#define FRAME_VERSION_1   0x10
 Bits containing the frame version 0b01.
 
#define FRAME_VERSION_2   0x20
 Bits containing the frame version 0b10.
 
#define FRAME_VERSION_3   0x30
 Bits containing the frame version 0b11.
 
#define IE_HEADER_LENGTH_MASK   0x3f
 Mask of bits containing the length of an IE header content.
 
#define IE_PRESENT_OFFSET   2
 Byte containing the IE Present bit.
 
#define IE_PRESENT_BIT   0x02
 Bits containing the IE Present field.
 
#define KEY_ID_MODE_0   0
 Value of the 0x00 Key Identifier Mode.
 
#define KEY_ID_MODE_1   1
 Value of the 0x01 Key Identifier Mode.
 
#define KEY_ID_MODE_2   2
 Value of the 0x10 Key Identifier Mode.
 
#define KEY_ID_MODE_3   3
 Value of the 0x11 Key Identifier Mode.
 
#define KEY_ID_MODE_MASK   0x18
 Mask of bits containing Key Identifier Mode in the Security Control field.
 
#define KEY_ID_MODE_BIT_OFFSET   3
 Number of bits the Key Identifier Mode is offset in the Security Control field.
 
#define KEY_ID_MODE_0_MASK   0
 Bits containing the 0x00 Key Identifier Mode.
 
#define KEY_ID_MODE_1_MASK   0x08
 Bits containing the 0x01 Key Identifier Mode.
 
#define KEY_ID_MODE_2_MASK   0x10
 Bits containing the 0x10 Key Identifier Mode.
 
#define KEY_ID_MODE_3_MASK   0x18
 Bits containing the 0x11 Key Identifier Mode.
 
#define KEY_SRC_KEY_ID_MODE_0_SIZE   0
 Size of the Key Source field when Key Identifier Mode equals 0.
 
#define KEY_SRC_KEY_ID_MODE_1_SIZE   0
 Size of the Key Source field when Key Identifier Mode equals 1.
 
#define KEY_SRC_KEY_ID_MODE_2_SIZE   4
 Size of the Key Source field when Key Identifier Mode equals 2.
 
#define KEY_SRC_KEY_ID_MODE_3_SIZE   8
 Size of the Key Source field when Key Identifier Mode equals 3.
 
#define KEY_IDX_SIZE   1
 Size of the Key Index field.
 
#define MAC_CMD_COMMAND_ID_SIZE   1
 Size of the MAC Command ID field.
 
#define MAC_CMD_ASSOC_REQ   0x01
 Command frame identifier for MAC Association request.
 
#define MAC_CMD_ASSOC_RESP   0x02
 Command frame identifier for MAC Association response.
 
#define MAC_CMD_DISASSOC_NOTIFY   0x03
 Command frame identifier for MAC Disaccociation notification.
 
#define MAC_CMD_DATA_REQ   0x04
 Command frame identifier for MAC Data Requests.
 
#define MAC_CMD_PANID_CONFLICT   0x05
 Command frame identifier for MAC PAN ID conflict notification.
 
#define MAC_CMD_ORPHAN_NOTIFY   0x06
 Command frame identifier for MAC Orphan notification.
 
#define MAC_CMD_BEACON_REQ   0x07
 Command frame identifier for MAC Beacon.
 
#define MAC_CMD_COORD_REALIGN   0x08
 Command frame identifier for MAC Coordinator realignment.
 
#define MAC_CMD_GTS_REQUEST   0x09
 Command frame identifier for MAC GTS request.
 
#define PAN_ID_COMPR_OFFSET   1
 Byte containing the PAN ID compression bit (+1 for the frame length byte).
 
#define PAN_ID_COMPR_MASK   0x40
 PAN ID compression bit.
 
#define PAN_ID_OFFSET   4
 Offset of PAN ID in the Data frame (+1 for the frame length byte).
 
#define PHR_OFFSET   0
 Offset of the PHY header in a frame.
 
#define PHR_LENGTH_MASK   0x7f
 Mask of the PHR length field.
 
#define PSDU_OFFSET   1
 Offset of the PHY payload.
 
#define SECURITY_ENABLED_OFFSET   1
 Byte containing the Security Enabled bit.
 
#define SECURITY_ENABLED_BIT   0x08
 Bits containing the Security Enabled field.
 
#define SECURITY_LEVEL_MASK   0x07
 Mask of bits containing the Security level field.
 
#define SECURITY_LEVEL_NONE   0x00
 Bits indicating a frame with no security attributes (0b000).
 
#define SECURITY_LEVEL_MIC_32   0x01
 Bits containing the 32-bit Message Integrity Code (0b001).
 
#define SECURITY_LEVEL_MIC_64   0x02
 Bits containing the 64-bit Message Integrity Code (0b010).
 
#define SECURITY_LEVEL_MIC_128   0x03
 Bits containing the 128-bit Message Integrity Code (0b011).
 
#define SECURITY_LEVEL_ENC_MIC_32   0x05
 Bits containing the 32-bit Encrypted Message Integrity Code (0b101).
 
#define SECURITY_LEVEL_ENC_MIC_64   0x06
 Bits containing the 64-bit Encrypted Message Integrity Code (0b110).
 
#define SECURITY_LEVEL_ENC_MIC_128   0x07
 Bits containing the 128-bit Encrypted Message Integrity Code (0b111).
 
#define SECURITY_LEVEL_MIC_LEVEL_MASK   0x03
 Mask of bits encoding the Message Integrity Code length.
 
#define SRC_ADDR_TYPE_EXTENDED   0xc0
 Bits containing the extended source address type.
 
#define SRC_ADDR_TYPE_NONE   0x00
 Bits containing a not-present source address type.
 
#define SRC_ADDR_TYPE_MASK   0xc0
 Mask of bits containing the source address type.
 
#define SRC_ADDR_TYPE_OFFSET   2
 Byte containing the source address type (+1 for the frame length byte).
 
#define SRC_ADDR_TYPE_SHORT   0x80
 Bits containing the short source address type.
 
#define SRC_ADDR_OFFSET_SHORT_DST   8
 Offset of the source address in the Data frame if the destination address is short.
 
#define SRC_ADDR_OFFSET_EXTENDED_DST   14
 Offset of the source address in the Data frame if the destination address is extended.
 
#define DSN_SIZE   1
 Size of the Sequence Number field.
 
#define FCF_SIZE   2
 Size of the FCF field.
 
#define FCS_SIZE   2
 Size of the FCS field.
 
#define FRAME_COUNTER_SIZE   4
 Size of the Frame Counter field.
 
#define IE_HEADER_SIZE   2
 Size of the obligatory IE Header field elements.
 
#define IMM_ACK_LENGTH   5
 Length of the ACK frame.
 
#define KEY_ID_MODE_1_SIZE   1
 Size of the 0x01 Key Identifier Mode field.
 
#define KEY_ID_MODE_2_SIZE   5
 Size of the 0x10 Key Identifier Mode field.
 
#define KEY_ID_MODE_3_SIZE   9
 Size of the 0x11 Key Identifier Mode field.
 
#define MAX_PACKET_SIZE   127
 Maximum size of the radio packet.
 
#define MIC_32_SIZE   4
 Size of MIC with the MIC-32 and ENC-MIC-32 security attributes.
 
#define MIC_64_SIZE   8
 Size of MIC with the MIC-64 and ENC-MIC-64 security attributes.
 
#define MIC_128_SIZE   16
 Size of MIC with the MIC-128 and ENC-MIC-128 security attributes.
 
#define PAN_ID_SIZE   2
 Size of the PAN ID.
 
#define PHR_SIZE   1
 Size of the PHR field.
 
#define SECURITY_CONTROL_SIZE   1
 Size of the Security Control field.
 
#define AES_CCM_KEY_SIZE   16
 Size of AES CCM Key.
 
#define EXTENDED_ADDRESS_SIZE   8
 Size of the Extended Mac Address.
 
#define SHORT_ADDRESS_SIZE   2
 Size of the Short Mac Address.
 
#define TURNAROUND_TIME   192UL
 RX-to-TX or TX-to-RX turnaround time (aTurnaroundTime), in microseconds (us).
 
#define CCA_TIME   128UL
 Time required to perform CCA detection (aCcaTime), in microseconds (us).
 
#define ACK_IFS   TURNAROUND_TIME
 Ack Inter Frame Spacing [us] - delay between last symbol of received frame and first symbol of transmitted Ack.
 
#define UNIT_BACKOFF_PERIOD   (TURNAROUND_TIME + CCA_TIME)
 Number of symbols in the basic time period used by CSMA-CA algorithm (aUnitBackoffPeriod), in (us).
 
#define PHY_US_PER_SYMBOL   16
 Duration of a single symbol in microseconds (us).
 
#define PHY_SYMBOLS_PER_OCTET   2
 Number of symbols in a single byte (octet).
 
#define PHY_SHR_SYMBOLS   10
 Number of symbols in the Synchronization Header (SHR).
 
#define PHY_MIN_RECEIVER_SENSITIVITY   -85
 Lowest receiver sensitivity level in dBm according to 802.15.4-2020 specification, chapter 12.3.4.
 
#define ED_RESULT_MAX   0xff
 Maximal ED result.
 
#define BROADCAST_ADDRESS   ((uint8_t[SHORT_ADDRESS_SIZE]) {0xff, 0xff})
 Broadcast short address.
 
#define MIN_SIFS_PERIOD_US   192
 Minimum Short IFS period default value in us.
 
#define MIN_LIFS_PERIOD_US   640
 Minimum Long IFS period default value in us.
 
#define MAX_SIFS_FRAME_SIZE   18
 Maximum frame length which can be followed by the Short Interframe Space.
 
#define NRF_802154_RESERVED_CSMACA_ID   (UINT32_MAX - 2)
 Delayed timeslot identifier reserved for CSMA/CA procedure.
 
#define NRF_802154_RESERVED_DTX_ID   (UINT32_MAX - 3)
 Delayed timeslot identifier reserved for delayed transmissions.
 
#define IE_VENDOR_ID   0x00
 Vendor-specific IE identifier.
 
#define IE_VENDOR_SIZE_MIN   3
 Vendor-specific IE minimum length.
 
#define IE_VENDOR_OUI_OFFSET   0
 Vendor-specific IE OUI offset.
 
#define IE_VENDOR_THREAD_SUBTYPE_OFFSET   3
 Thread Vendor-specific IE subtype offset.
 
#define IE_VENDOR_THREAD_DATA_OFFSET   4
 Thread Vendor-specific IE DATA offset.
 
#define IE_VENDOR_THREAD_OUI   0xeab89b
 Thread Vendor-specific IE OUI.
 
#define IE_VENDOR_THREAD_SIZE_MIN   4
 Thread Vendor-specific IE minimum length.
 
#define IE_VENDOR_THREAD_ACK_PROBING_ID   0x00
 Thread Vendor-specific ACK Probing IE subtype ID.
 
#define IE_VENDOR_THREAD_ACK_SIZE_MIN   5
 Thread Vendor-specific ACK Probing IE minimum size.
 
#define IE_VENDOR_THREAD_ACK_SIZE_MAX   6
 Thread Vendor-specific ACK Probing IE maximum size.
 
#define IE_VENDOR_THREAD_RSSI_TOKEN   0x01
 Thread Vendor-specific ACK Probing IE RSSI value placeholder.
 
#define IE_VENDOR_THREAD_MARGIN_TOKEN   0x02
 Thread Vendor-specific ACK Probing IE Link margin value placeholder.
 
#define IE_VENDOR_THREAD_LQI_TOKEN   0x03
 Thread Vendor-specific ACK Probing IE LQI value placeholder.
 
#define IE_VENDOR_THREAD_RSSI_FLOOR   -130
 Thread Vendor-specific ACK Probing RSSI floor value used for scaling.
 
#define IE_VENDOR_THREAD_MARGIN_FLOOR   0
 Thread Vendor-specific ACK Probing margin floor value used for scaling.
 
#define IE_VENDOR_THREAD_RSSI_CEIL   0
 Thread Vendor-specific ACK Probing RSSI ceil value used for scaling.
 
#define IE_VENDOR_THREAD_MARGIN_CEIL   130
 Thread Vendor-specific ACK Probing margin ceil value used for scaling.
 
#define IE_VENDOR_THREAD_CST_ID   0x02
 Thread Vendor-specific CST IE subtype ID.
 
#define IE_VENDOR_THREAD_CST_SIZE   8
 Thread Vendor-specific CST IE size.
 
#define IE_CSL_SYMBOLS_PER_UNIT   10
 Number of symbols per phase/period unit.
 
#define IE_CSL_PERIOD_MAX   0xffff
 Maximum CSL IE phase/period value.
 
#define IE_CSL_SIZE_MIN   4
 Minimal size of the CSL IE.
 
#define IE_CSL_ID   0x1a
 CSL IE identifier.
 
#define IE_HT1   0x7e
 Information Element Header Termination type 1.
 
#define IE_HT2   0x7f
 Information Element Header Termination type 2.
 
#define IE_LENGTH_MASK   0x7f
 Information element length mask.
 
#define IE_LENGTH_OFFSET   0x00
 Information element length offset.
 
#define IE_ID_OFFSET_0   0x00
 Offset of the octet containing the first part of the IE identifier.
 
#define IE_ID_OFFSET_1   0x01
 Offset of the octed containing the second part of the IE identifier.
 
#define IE_DATA_OFFSET   0x02
 Information element data offset.
 
#define IE_HEADER_ELEMENT_ID_OFFSET   0x07
 Bit offset of Element ID field in a Header IE header.
 

Enumerations

enum  req_originator_t {
  REQ_ORIG_HIGHER_LAYER , REQ_ORIG_CORE , REQ_ORIG_RSCH , REQ_ORIG_CSMA_CA ,
  REQ_ORIG_ACK_TIMEOUT , REQ_ORIG_DELAYED_TRX , REQ_ORIG_IFS
}