xref: /nrf52832-nimble/rt-thread/components/net/lwip-2.1.0/src/include/netif/ieee802154.h (revision 104654410c56c573564690304ae786df310c91fc)
1*10465441SEvalZero /**
2*10465441SEvalZero  * @file
3*10465441SEvalZero  * Definitions for IEEE 802.15.4 MAC frames
4*10465441SEvalZero  */
5*10465441SEvalZero 
6*10465441SEvalZero /*
7*10465441SEvalZero  * Copyright (c) 2018 Simon Goldschmidt.
8*10465441SEvalZero  * All rights reserved.
9*10465441SEvalZero  *
10*10465441SEvalZero  * Redistribution and use in source and binary forms, with or without modification,
11*10465441SEvalZero  * are permitted provided that the following conditions are met:
12*10465441SEvalZero  *
13*10465441SEvalZero  * 1. Redistributions of source code must retain the above copyright notice,
14*10465441SEvalZero  *    this list of conditions and the following disclaimer.
15*10465441SEvalZero  * 2. Redistributions in binary form must reproduce the above copyright notice,
16*10465441SEvalZero  *    this list of conditions and the following disclaimer in the documentation
17*10465441SEvalZero  *    and/or other materials provided with the distribution.
18*10465441SEvalZero  * 3. The name of the author may not be used to endorse or promote products
19*10465441SEvalZero  *    derived from this software without specific prior written permission.
20*10465441SEvalZero  *
21*10465441SEvalZero  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
22*10465441SEvalZero  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
23*10465441SEvalZero  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT
24*10465441SEvalZero  * SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25*10465441SEvalZero  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
26*10465441SEvalZero  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
27*10465441SEvalZero  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
28*10465441SEvalZero  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
29*10465441SEvalZero  * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY
30*10465441SEvalZero  * OF SUCH DAMAGE.
31*10465441SEvalZero  *
32*10465441SEvalZero  * This file is part of the lwIP TCP/IP stack.
33*10465441SEvalZero  *
34*10465441SEvalZero  * Author: Simon Goldschmidt <[email protected]>
35*10465441SEvalZero  *
36*10465441SEvalZero  */
37*10465441SEvalZero #ifndef LWIP_HDR_NETIF_IEEE802154_H
38*10465441SEvalZero #define LWIP_HDR_NETIF_IEEE802154_H
39*10465441SEvalZero 
40*10465441SEvalZero #include "lwip/opt.h"
41*10465441SEvalZero 
42*10465441SEvalZero #ifdef __cplusplus
43*10465441SEvalZero extern "C" {
44*10465441SEvalZero #endif
45*10465441SEvalZero 
46*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
47*10465441SEvalZero #  include "arch/bpstruct.h"
48*10465441SEvalZero #endif
49*10465441SEvalZero PACK_STRUCT_BEGIN
50*10465441SEvalZero /** General MAC frame format
51*10465441SEvalZero  * This shows the full featured header, mainly for documentation.
52*10465441SEvalZero  * Some fields are omitted or shortened to achieve frame compression.
53*10465441SEvalZero  */
54*10465441SEvalZero struct ieee_802154_hdr {
55*10465441SEvalZero   /** See IEEE_802154_FC_* defines */
56*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t frame_control);
57*10465441SEvalZero   /** Sequence number is omitted if IEEE_802154_FC_SEQNO_SUPPR is set in frame_control */
58*10465441SEvalZero   PACK_STRUCT_FLD_8(u8_t  sequence_number);
59*10465441SEvalZero   /** Destination PAN ID is omitted if Destination Addressing Mode is 0 */
60*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t destination_pan_id);
61*10465441SEvalZero   /** Destination Address is omitted if Destination Addressing Mode is 0 */
62*10465441SEvalZero   PACK_STRUCT_FLD_8(u8_t destination_address[8]);
63*10465441SEvalZero   /** Source PAN ID is omitted if Source Addressing Mode is 0
64*10465441SEvalZero       or if IEEE_802154_FC_PANID_COMPR is set in frame control*/
65*10465441SEvalZero   PACK_STRUCT_FIELD(u16_t source_pan_id);
66*10465441SEvalZero   /** Source Address is omitted if Source Addressing Mode is 0 */
67*10465441SEvalZero   PACK_STRUCT_FLD_8(u8_t source_address[8]);
68*10465441SEvalZero   /* The rest is variable */
69*10465441SEvalZero } PACK_STRUCT_STRUCT;
70*10465441SEvalZero PACK_STRUCT_END
71*10465441SEvalZero #ifdef PACK_STRUCT_USE_INCLUDES
72*10465441SEvalZero #  include "arch/epstruct.h"
73*10465441SEvalZero #endif
74*10465441SEvalZero 
75*10465441SEvalZero /* Addressing modes (2 bits) */
76*10465441SEvalZero #define IEEE_802154_ADDR_MODE_NO_ADDR   0x00 /* PAN ID and address fields are not present */
77*10465441SEvalZero #define IEEE_802154_ADDR_MODE_RESERVED  0x01 /* Reserved */
78*10465441SEvalZero #define IEEE_802154_ADDR_MODE_SHORT     0x02 /* Address field contains a short address (16 bit) */
79*10465441SEvalZero #define IEEE_802154_ADDR_MODE_EXT       0x03 /* Address field contains an extended address (64 bit) */
80*10465441SEvalZero 
81*10465441SEvalZero /* IEEE 802.15.4 Frame Control definitions (2 bytes; see IEEE 802.15.4-2015 ch. 7.2.1) */
82*10465441SEvalZero #define IEEE_802154_FC_FT_MASK             0x0007 /* bits 0..2: Frame Type */
83*10465441SEvalZero #define IEEE_802154_FC_FT_BEACON               0x00
84*10465441SEvalZero #define IEEE_802154_FC_FT_DATA                 0x01
85*10465441SEvalZero #define IEEE_802154_FC_FT_ACK                  0x02
86*10465441SEvalZero #define IEEE_802154_FC_FT_MAC_CMD              0x03
87*10465441SEvalZero #define IEEE_802154_FC_FT_RESERVED             0x04
88*10465441SEvalZero #define IEEE_802154_FC_FT_MULTIPURPOSE         0x05
89*10465441SEvalZero #define IEEE_802154_FC_FT_FRAG                 0x06
90*10465441SEvalZero #define IEEE_802154_FC_FT_EXT                  0x07
91*10465441SEvalZero #define IEEE_802154_FC_SEC_EN              0x0008 /* bit 3: Security Enabled */
92*10465441SEvalZero #define IEEE_802154_FC_FRAME_PEND          0x0010 /* bit 4: Frame Pending */
93*10465441SEvalZero #define IEEE_802154_FC_ACK_REQ             0x0020 /* bit 5: AR (ACK required) */
94*10465441SEvalZero #define IEEE_802154_FC_PANID_COMPR         0x0040 /* bit 6: PAN ID Compression (src and dst are equal, src PAN ID omitted) */
95*10465441SEvalZero #define IEEE_802154_FC_RESERVED            0x0080
96*10465441SEvalZero #define IEEE_802154_FC_SEQNO_SUPPR         0x0100 /* bit 8: Sequence Number Suppression */
97*10465441SEvalZero #define IEEE_802154_FC_IE_PRESENT          0x0200 /* bit 9: IE Present */
98*10465441SEvalZero #define IEEE_802154_FC_DST_ADDR_MODE_MASK  0x0c00 /* bits 10..11: Destination Addressing Mode */
99*10465441SEvalZero #define IEEE_802154_FC_DST_ADDR_MODE_NO_ADDR   (IEEE_802154_ADDR_MODE_NO_ADDR << 10)
100*10465441SEvalZero #define IEEE_802154_FC_DST_ADDR_MODE_SHORT     (IEEE_802154_ADDR_MODE_SHORT << 10)
101*10465441SEvalZero #define IEEE_802154_FC_DST_ADDR_MODE_EXT       (IEEE_802154_ADDR_MODE_EXT << 10)
102*10465441SEvalZero #define IEEE_802154_FC_FRAME_VERSION_MASK  0x3000 /* bits 12..13: Frame Version */
103*10465441SEvalZero #define IEEE_802154_FC_FRAME_VERSION_GET(x)    (((x) & IEEE_802154_FC_FRAME_VERSION_MASK) >> 12)
104*10465441SEvalZero #define IEEE_802154_FC_SRC_ADDR_MODE_MASK  0xc000 /* bits 14..15: Source Addressing Mode */
105*10465441SEvalZero #define IEEE_802154_FC_SRC_ADDR_MODE_SHORT     (IEEE_802154_ADDR_MODE_SHORT << 14)
106*10465441SEvalZero #define IEEE_802154_FC_SRC_ADDR_MODE_EXT       (IEEE_802154_ADDR_MODE_EXT << 14)
107*10465441SEvalZero 
108*10465441SEvalZero #ifdef __cplusplus
109*10465441SEvalZero }
110*10465441SEvalZero #endif
111*10465441SEvalZero 
112*10465441SEvalZero #endif /* LWIP_HDR_NETIF_IEEE802154_H */
113