Loading...
Searching...
No Matches
ieee802154.h
Go to the documentation of this file.
1/*
2 * Copyright (C) 2015-2019 Freie Universität Berlin
3 *
4 * This file is subject to the terms and conditions of the GNU Lesser
5 * General Public License v2.1. See the file LICENSE in the top level
6 * directory for more details.
7 */
8
21#ifndef NET_IEEE802154_H
22#define NET_IEEE802154_H
23
24#include <stdint.h>
25#include <stdlib.h>
26
27#include "byteorder.h"
28#include "modules.h"
29#include "net/eui64.h"
30#include "time_units.h"
31
32#ifdef __cplusplus
33extern "C" {
34#endif
35
39#define IEEE802154_SFD (0xa7)
40
45#define IEEE802154_SHORT_ADDRESS_LEN (2U)
46#define IEEE802154_LONG_ADDRESS_LEN (8U)
55#define IEEE802154_MAX_HDR_LEN (23U)
56#define IEEE802154_MIN_FRAME_LEN (IEEE802154_FCF_LEN + sizeof(uint8_t))
57
58#define IEEE802154_FCF_LEN (2U)
59#define IEEE802154_FCS_LEN (2U)
60
61#define IEEE802154_FCF_TYPE_MASK (0x07)
62#define IEEE802154_FCF_TYPE_BEACON (0x00)
63#define IEEE802154_FCF_TYPE_DATA (0x01)
64#define IEEE802154_FCF_TYPE_ACK (0x02)
65#define IEEE802154_FCF_TYPE_MACCMD (0x03)
66
67#define IEEE802154_FCF_SECURITY_EN (0x08)
68#define IEEE802154_FCF_FRAME_PEND (0x10)
69#define IEEE802154_FCF_ACK_REQ (0x20)
70#define IEEE802154_FCF_PAN_COMP (0x40)
72#define IEEE802154_FCF_DST_ADDR_MASK (0x0c)
73#define IEEE802154_FCF_DST_ADDR_VOID (0x00)
74#define IEEE802154_FCF_DST_ADDR_RESV (0x04)
75#define IEEE802154_FCF_DST_ADDR_SHORT (0x08)
76#define IEEE802154_FCF_DST_ADDR_LONG (0x0c)
78#define IEEE802154_FCF_VERS_MASK (0x30)
79#define IEEE802154_FCF_VERS_V0 (0x00)
80#define IEEE802154_FCF_VERS_V1 (0x10)
81
82#define IEEE802154_FCF_SRC_ADDR_MASK (0xc0)
83#define IEEE802154_FCF_SRC_ADDR_VOID (0x00)
84#define IEEE802154_FCF_SRC_ADDR_RESV (0x40)
85#define IEEE802154_FCF_SRC_ADDR_SHORT (0x80)
86#define IEEE802154_FCF_SRC_ADDR_LONG (0xc0)
93#define IEEE802154_CHANNEL_MIN_SUBGHZ (0U)
94#define IEEE802154_CHANNEL_MAX_SUBGHZ (10U)
95#define IEEE802154_CHANNEL_MIN (11U)
96#define IEEE802154_CHANNEL_MAX (26U)
99#define IEEE802154_FRAME_LEN_MAX (127U)
100#define IEEE802154G_FRAME_LEN_MAX (2047U)
101#define IEEE802154_ACK_FRAME_LEN (5U)
106#define IEEE802154_LIFS_SYMS (40U)
107
111#define IEEE802154_SIFS_SYMS (12U)
112
116#define IEEE802154_SIFS_MAX_FRAME_SIZE (18U)
117
121#define IEEE802154_ACK_TIMEOUT_SYMS (54)
122
126#define IEEE802154_MR_OFDM_SYMBOL_TIME_US (120)
127
133#define IEEE802154_MR_FSK_SYMBOL_TIME_US (20)
134
140#define IEEE802154_RADIO_RSSI_OFFSET (-174)
141
142#define IEEE802154_PHY_MR_FSK_PHR_LEN (2)
143#define IEEE802154_PHY_MR_FSK_2FSK_SFD_LEN (2)
153#define IEEE802154_PHY_MR_FSK_2FSK_CODED_SFD_0 (0x6F4E)
154#define IEEE802154_PHY_MR_FSK_2FSK_CODED_SFD_1 (0x632D)
155#define IEEE802154_PHY_MR_FSK_2FSK_UNCODED_SFD_0 (0x90E4)
156#define IEEE802154_PHY_MR_FSK_2FSK_UNCODED_SFD_1 (0x7A0E)
165#define IEEE802154G_ATURNAROUNDTIME_US (1 * US_PER_MS)
166
171#define IEEE802154_ATURNAROUNDTIME_IN_SYMBOLS (12)
172
180#define IEEE802154_CCA_DURATION_IN_SYMBOLS (8)
181
196
205
217
227
237{
238 switch (srate) {
240 return 2;
242 return 3;
246 return 8;
248 return 10;
249 }
250
251 return 0;
252}
253
261#define IEEE802154_ADDR_BCAST { 0xff, 0xff }
262
266#define IEEE802154_ADDR_BCAST_LEN (IEEE802154_SHORT_ADDRESS_LEN)
267
283#if IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_BPSK)
284#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_BPSK
285#elif IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_ASK)
286#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_ASK
287#elif IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_OQPSK)
288#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_OQPSK
289#elif IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_MR_OQPSK)
290#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_MR_OQPSK
291#elif IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_MR_OFDM)
292#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_MR_OFDM
293#elif IS_ACTIVE(CONFIG_IEEE802154_DEFAULT_PHY_MR_FSK)
294#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_MR_FSK
295#endif
296
297#ifndef CONFIG_IEEE802154_DEFAULT_PHY_MODE
298#define CONFIG_IEEE802154_DEFAULT_PHY_MODE IEEE802154_PHY_OQPSK
299#endif
304#ifndef CONFIG_IEEE802154_DEFAULT_SUBGHZ_CHANNEL
305#define CONFIG_IEEE802154_DEFAULT_SUBGHZ_CHANNEL (5U)
306#endif
307
311#ifndef CONFIG_IEEE802154_DEFAULT_CHANNEL
312#define CONFIG_IEEE802154_DEFAULT_CHANNEL (26U)
313#endif
314
318#ifndef CONFIG_IEEE802154_DEFAULT_SUBGHZ_PAGE
319#define CONFIG_IEEE802154_DEFAULT_SUBGHZ_PAGE (2U)
320#endif
321
325#ifndef CONFIG_IEEE802154_MR_OQPSK_DEFAULT_CHIPS
326#define CONFIG_IEEE802154_MR_OQPSK_DEFAULT_CHIPS IEEE802154_MR_OQPSK_CHIPS_1000
327#endif
328
332#ifndef CONFIG_IEEE802154_MR_OQPSK_DEFAULT_RATE
333#define CONFIG_IEEE802154_MR_OQPSK_DEFAULT_RATE (2U)
334#endif
335
339#ifndef CONFIG_IEEE802154_MR_OFDM_DEFAULT_OPTION
340#define CONFIG_IEEE802154_MR_OFDM_DEFAULT_OPTION (2U)
341#endif
342
346#ifndef CONFIG_IEEE802154_MR_OFDM_DEFAULT_SCHEME
347#define CONFIG_IEEE802154_MR_OFDM_DEFAULT_SCHEME (2U)
348#endif
349
353#ifndef CONFIG_IEEE802154_MR_FSK_DEFAULT_SRATE
354#define CONFIG_IEEE802154_MR_FSK_DEFAULT_SRATE IEEE802154_MR_FSK_SRATE_200K
355#endif
356
360#ifndef CONFIG_IEEE802154_MR_FSK_DEFAULT_MOD_IDX
361#define CONFIG_IEEE802154_MR_FSK_DEFAULT_MOD_IDX (64U)
362#endif
363
367#ifndef CONFIG_IEEE802154_MR_FSK_DEFAULT_MOD_ORD
368#define CONFIG_IEEE802154_MR_FSK_DEFAULT_MOD_ORD (2U)
369#endif
370
374#ifndef CONFIG_IEEE802154_MR_FSK_DEFAULT_FEC
375#define CONFIG_IEEE802154_MR_FSK_DEFAULT_FEC IEEE802154_FEC_NONE
376#endif
377
381#ifndef CONFIG_IEEE802154_DEFAULT_PANID
382#define CONFIG_IEEE802154_DEFAULT_PANID (0x0023U)
383#endif
384
388#ifndef IEEE802154_PANID_BCAST
389#define IEEE802154_PANID_BCAST { 0xff, 0xff }
390#endif
391
395#ifndef CONFIG_IEEE802154_DEFAULT_TXPOWER
396#define CONFIG_IEEE802154_DEFAULT_TXPOWER (0)
397#endif
403#ifndef CONFIG_IEEE802154_DEFAULT_CSMA_CA_MIN_BE
404#define CONFIG_IEEE802154_DEFAULT_CSMA_CA_MIN_BE (3U)
405#endif
406
410#ifndef CONFIG_IEEE802154_DEFAULT_CSMA_CA_RETRIES
411#define CONFIG_IEEE802154_DEFAULT_CSMA_CA_RETRIES (4U)
412#endif
413
417#ifndef CONFIG_IEEE802154_DEFAULT_CSMA_CA_MAX_BE
418#define CONFIG_IEEE802154_DEFAULT_CSMA_CA_MAX_BE (5U)
419#endif
420
424#ifndef CONFIG_IEEE802154_CCA_THRESH_DEFAULT
425#define CONFIG_IEEE802154_CCA_THRESH_DEFAULT (-70)
426#endif
427
431#ifndef CONFIG_IEEE802154_DEFAULT_MAX_FRAME_RETRANS
432#define CONFIG_IEEE802154_DEFAULT_MAX_FRAME_RETRANS (4U)
433#endif
434
438#ifdef DOXYGEN
439#define CONFIG_IEEE802154_AUTO_ACK_DISABLE 0
440#endif
441
445#ifndef CONFIG_IEEE802154_DEFAULT_ACK_REQ
446#define CONFIG_IEEE802154_DEFAULT_ACK_REQ 1
447#endif
448
454#ifndef CONFIG_IEEE802154_DSME_CAP_REDUCTION
455#define CONFIG_IEEE802154_DSME_CAP_REDUCTION 0
456#endif
457
467#ifndef CONFIG_IEEE802154_DSME_MAC_RESPONSE_WAIT_TIME
468#define CONFIG_IEEE802154_DSME_MAC_RESPONSE_WAIT_TIME (244U)
469#endif
470
479#ifndef CONFIG_IEEE802154_DSME_SCAN_DURATION
480#define CONFIG_IEEE802154_DSME_SCAN_DURATION (4U)
481#endif
482
494#ifndef CONFIG_IEEE802154_DSME_SUPERFRAME_ORDER
495#define CONFIG_IEEE802154_DSME_SUPERFRAME_ORDER (3U)
496#endif
497
507#ifndef CONFIG_IEEE802154_DSME_MULTISUPERFRAME_ORDER
508#define CONFIG_IEEE802154_DSME_MULTISUPERFRAME_ORDER (3U)
509#endif
510
520#ifndef CONFIG_IEEE802154_DSME_BEACON_ORDER
521#define CONFIG_IEEE802154_DSME_BEACON_ORDER (3U)
522#endif
523
534#ifdef DOXYGEN
535#define CONFIG_IEEE802154_DSME_STATIC_GTS 0
536#endif
537
546#ifndef CONFIG_IEEE802154_DSME_GTS_EXPIRATION
547#define CONFIG_IEEE802154_DSME_GTS_EXPIRATION (16U)
548#endif
549
555#ifndef CONFIG_IEEE802154_DSME_MIN_COORD_LQI
556#define CONFIG_IEEE802154_DSME_MIN_COORD_LQI (100U)
557#endif
558
602size_t ieee802154_set_frame_hdr(uint8_t *buf, const uint8_t *src, size_t src_len,
603 const uint8_t *dst, size_t dst_len,
604 le_uint16_t src_pan, le_uint16_t dst_pan,
605 uint8_t flags, uint8_t seq);
606
617size_t ieee802154_get_frame_hdr_len(const uint8_t *mhr);
618
631int ieee802154_get_src(const uint8_t *mhr, uint8_t *src, le_uint16_t *src_pan);
632
645int ieee802154_get_dst(const uint8_t *mhr, uint8_t *dst, le_uint16_t *dst_pan);
646
663int ieee802154_dst_filter(const uint8_t *mhr, uint16_t pan,
664 network_uint16_t short_addr, const eui64_t *ext_addr);
665
675static inline uint8_t ieee802154_get_seq(const uint8_t *mhr)
676{
677 return mhr[2];
678}
679
699static inline eui64_t *ieee802154_get_iid(eui64_t *eui64, const uint8_t *addr,
700 size_t addr_len)
701{
702 int i = 0;
703
704 eui64->uint8[0] = eui64->uint8[1] = 0;
705
706 switch (addr_len) {
707 case 8:
708 eui64->uint8[0] = addr[i++] ^ 0x02;
709 eui64->uint8[1] = addr[i++];
710 eui64->uint8[2] = addr[i++];
711 eui64->uint8[3] = addr[i++];
712 eui64->uint8[4] = addr[i++];
713 eui64->uint8[5] = addr[i++];
714 eui64->uint8[6] = addr[i++];
715 eui64->uint8[7] = addr[i++];
716 break;
717
718 case 4:
719 eui64->uint8[0] = addr[i++] ^ 0x02;
720 eui64->uint8[1] = addr[i++];
721
722 /* Falls through. */
723 case 2:
724 eui64->uint8[2] = 0;
725 eui64->uint8[3] = 0xff;
726 eui64->uint8[4] = 0xfe;
727 eui64->uint8[5] = 0;
728 eui64->uint8[6] = addr[i++];
729 eui64->uint8[7] = addr[i++];
730 break;
731
732 default:
733 return NULL;
734 }
735
736 return eui64;
737}
738
755static inline int16_t ieee802154_rssi_to_dbm(uint8_t rssi)
756{
757 return rssi + IEEE802154_RADIO_RSSI_OFFSET;
758}
759
773static inline uint8_t ieee802154_dbm_to_rssi(int16_t dbm)
774{
775 const int min = IEEE802154_RADIO_RSSI_OFFSET;
776 const int max = min + (UINT8_MAX - 1);
777
778 int val = dbm <= min ? min : (dbm >= max ? max : dbm);
779 return val - IEEE802154_RADIO_RSSI_OFFSET;
780}
781
782#ifdef __cplusplus
783}
784#endif
785
786#endif /* NET_IEEE802154_H */
Functions to work with different byte orders.
EUI-64 data type definition.
ieee802154_mr_oqpsk_chips_t
802.15.4 MR-OQPSK chip rates
Definition ieee802154.h:221
#define IEEE802154_ADDR_BCAST_LEN
Length in byte of IEEE802154_ADDR_BCAST.
Definition ieee802154.h:266
int ieee802154_get_src(const uint8_t *mhr, uint8_t *src, le_uint16_t *src_pan)
Gets source address from MAC header.
size_t ieee802154_get_frame_hdr_len(const uint8_t *mhr)
Get length of MAC header.
int ieee802154_get_dst(const uint8_t *mhr, uint8_t *dst, le_uint16_t *dst_pan)
Gets destination address from MAC header.
static uint8_t ieee802154_mr_fsk_plen(ieee802154_mr_fsk_srate_t srate)
Get the minimum preamble length for a given symbol rate.
Definition ieee802154.h:236
int ieee802154_dst_filter(const uint8_t *mhr, uint16_t pan, network_uint16_t short_addr, const eui64_t *ext_addr)
Check whether a frame pass the IEEE 802.15.4 frame filter.
ieee802154_mr_fsk_srate_t
802.15.4 MR-FSK symbol rates
Definition ieee802154.h:209
size_t ieee802154_set_frame_hdr(uint8_t *buf, const uint8_t *src, size_t src_len, const uint8_t *dst, size_t dst_len, le_uint16_t src_pan, le_uint16_t dst_pan, uint8_t flags, uint8_t seq)
Initializes an IEEE 802.15.4 MAC frame header in buf.
static uint8_t ieee802154_dbm_to_rssi(int16_t dbm)
Convert from dBm scale to RSSI.
Definition ieee802154.h:773
const uint8_t ieee802154_addr_bcast[IEEE802154_ADDR_BCAST_LEN]
Broadcast address.
static uint8_t ieee802154_get_seq(const uint8_t *mhr)
Gets sequence number from MAC header.
Definition ieee802154.h:675
static eui64_t * ieee802154_get_iid(eui64_t *eui64, const uint8_t *addr, size_t addr_len)
Generates an IPv6 interface identifier from an IEEE 802.15.4 address.
Definition ieee802154.h:699
ieee802154_phy_mode_t
802.15.4 PHY modes
Definition ieee802154.h:185
static int16_t ieee802154_rssi_to_dbm(uint8_t rssi)
Convert from RSSI scale to dBm.
Definition ieee802154.h:755
#define IEEE802154_RADIO_RSSI_OFFSET
value of measured power when RSSI is zero.
Definition ieee802154.h:140
ieee802154_mr_fsk_fec_t
802.15.4 forward error correction schemes
Definition ieee802154.h:200
@ IEEE802154_MR_OQPSK_CHIPS_100
100 kChip/s
Definition ieee802154.h:222
@ IEEE802154_MR_OQPSK_CHIPS_200
200 kChip/s
Definition ieee802154.h:223
@ IEEE802154_MR_OQPSK_CHIPS_2000
2000 kChip/s
Definition ieee802154.h:225
@ IEEE802154_MR_OQPSK_CHIPS_1000
1000 kChip/s
Definition ieee802154.h:224
@ IEEE802154_MR_FSK_SRATE_50K
50k Symbols/s
Definition ieee802154.h:210
@ IEEE802154_MR_FSK_SRATE_100K
100k Symbols/s
Definition ieee802154.h:211
@ IEEE802154_MR_FSK_SRATE_400K
400k Symbols/s
Definition ieee802154.h:215
@ IEEE802154_MR_FSK_SRATE_150K
150k Symbols/s
Definition ieee802154.h:212
@ IEEE802154_MR_FSK_SRATE_200K
200k Symbols/s
Definition ieee802154.h:213
@ IEEE802154_MR_FSK_SRATE_300K
300k Symbols/s
Definition ieee802154.h:214
@ IEEE802154_PHY_BPSK
Binary Phase Shift Keying.
Definition ieee802154.h:187
@ IEEE802154_PHY_MR_OFDM
Multi-Rate Orthogonal Frequency-Division Multiplexing.
Definition ieee802154.h:191
@ IEEE802154_PHY_OQPSK
Offset Quadrature Phase-Shift Keying.
Definition ieee802154.h:189
@ IEEE802154_PHY_ASK
Amplitude-Shift Keying.
Definition ieee802154.h:188
@ IEEE802154_PHY_MR_FSK
Multi-Rate Frequency Shift Keying.
Definition ieee802154.h:192
@ IEEE802154_PHY_DISABLED
PHY disabled, no mode selected.
Definition ieee802154.h:186
@ IEEE802154_PHY_MR_OQPSK
Multi-Rate Offset Quadrature Phase-Shift Keying.
Definition ieee802154.h:190
@ IEEE802154_PHY_NO_OP
don't change PHY configuration
Definition ieee802154.h:194
@ IEEE802154_FEC_RSC
recursive and systematic code
Definition ieee802154.h:203
@ IEEE802154_FEC_NRNSC
non-recursive and non-systematic code
Definition ieee802154.h:202
@ IEEE802154_FEC_NONE
no forward error correction
Definition ieee802154.h:201
Common macros and compiler attributes/pragmas configuration.
Utility header providing time unit defines.
A 16 bit integer in big endian aka network byte order.
Definition byteorder.h:74
Data type to represent an EUI-64.
Definition eui64.h:55
uint8_t uint8[8]
split into 8 8-bit words.
Definition eui64.h:57
A 16 bit integer in little endian.
Definition byteorder.h:38