ieee802154.h 8.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232
  1. /*
  2. * IEEE802.15.4-2003 specification
  3. *
  4. * Copyright (C) 2007, 2008 Siemens AG
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2
  8. * as published by the Free Software Foundation.
  9. *
  10. * This program is distributed in the hope that it will be useful,
  11. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. * GNU General Public License for more details.
  14. *
  15. * Written by:
  16. * Pavel Smolenskiy <pavel.smolenskiy@gmail.com>
  17. * Maxim Gorbachyov <maxim.gorbachev@siemens.com>
  18. * Maxim Osipov <maxim.osipov@siemens.com>
  19. * Dmitry Eremin-Solenikov <dbaryshkov@gmail.com>
  20. * Alexander Smirnov <alex.bluesman.smirnov@gmail.com>
  21. */
  22. #ifndef LINUX_IEEE802154_H
  23. #define LINUX_IEEE802154_H
  24. #include <linux/types.h>
  25. #include <linux/random.h>
  26. #include <asm/byteorder.h>
  27. #define IEEE802154_MTU 127
  28. #define IEEE802154_MIN_PSDU_LEN 5
  29. #define IEEE802154_EXTENDED_ADDR_LEN 8
  30. #define IEEE802154_FC_TYPE_BEACON 0x0 /* Frame is beacon */
  31. #define IEEE802154_FC_TYPE_DATA 0x1 /* Frame is data */
  32. #define IEEE802154_FC_TYPE_ACK 0x2 /* Frame is acknowledgment */
  33. #define IEEE802154_FC_TYPE_MAC_CMD 0x3 /* Frame is MAC command */
  34. #define IEEE802154_FC_TYPE_SHIFT 0
  35. #define IEEE802154_FC_TYPE_MASK ((1 << 3) - 1)
  36. #define IEEE802154_FC_TYPE(x) ((x & IEEE802154_FC_TYPE_MASK) >> IEEE802154_FC_TYPE_SHIFT)
  37. #define IEEE802154_FC_SET_TYPE(v, x) do { \
  38. v = (((v) & ~IEEE802154_FC_TYPE_MASK) | \
  39. (((x) << IEEE802154_FC_TYPE_SHIFT) & IEEE802154_FC_TYPE_MASK)); \
  40. } while (0)
  41. #define IEEE802154_FC_SECEN_SHIFT 3
  42. #define IEEE802154_FC_SECEN (1 << IEEE802154_FC_SECEN_SHIFT)
  43. #define IEEE802154_FC_FRPEND_SHIFT 4
  44. #define IEEE802154_FC_FRPEND (1 << IEEE802154_FC_FRPEND_SHIFT)
  45. #define IEEE802154_FC_ACK_REQ_SHIFT 5
  46. #define IEEE802154_FC_ACK_REQ (1 << IEEE802154_FC_ACK_REQ_SHIFT)
  47. #define IEEE802154_FC_INTRA_PAN_SHIFT 6
  48. #define IEEE802154_FC_INTRA_PAN (1 << IEEE802154_FC_INTRA_PAN_SHIFT)
  49. #define IEEE802154_FC_SAMODE_SHIFT 14
  50. #define IEEE802154_FC_SAMODE_MASK (3 << IEEE802154_FC_SAMODE_SHIFT)
  51. #define IEEE802154_FC_DAMODE_SHIFT 10
  52. #define IEEE802154_FC_DAMODE_MASK (3 << IEEE802154_FC_DAMODE_SHIFT)
  53. #define IEEE802154_FC_VERSION_SHIFT 12
  54. #define IEEE802154_FC_VERSION_MASK (3 << IEEE802154_FC_VERSION_SHIFT)
  55. #define IEEE802154_FC_VERSION(x) ((x & IEEE802154_FC_VERSION_MASK) >> IEEE802154_FC_VERSION_SHIFT)
  56. #define IEEE802154_FC_SAMODE(x) \
  57. (((x) & IEEE802154_FC_SAMODE_MASK) >> IEEE802154_FC_SAMODE_SHIFT)
  58. #define IEEE802154_FC_DAMODE(x) \
  59. (((x) & IEEE802154_FC_DAMODE_MASK) >> IEEE802154_FC_DAMODE_SHIFT)
  60. #define IEEE802154_SCF_SECLEVEL_MASK 7
  61. #define IEEE802154_SCF_SECLEVEL_SHIFT 0
  62. #define IEEE802154_SCF_SECLEVEL(x) (x & IEEE802154_SCF_SECLEVEL_MASK)
  63. #define IEEE802154_SCF_KEY_ID_MODE_SHIFT 3
  64. #define IEEE802154_SCF_KEY_ID_MODE_MASK (3 << IEEE802154_SCF_KEY_ID_MODE_SHIFT)
  65. #define IEEE802154_SCF_KEY_ID_MODE(x) \
  66. ((x & IEEE802154_SCF_KEY_ID_MODE_MASK) >> IEEE802154_SCF_KEY_ID_MODE_SHIFT)
  67. #define IEEE802154_SCF_KEY_IMPLICIT 0
  68. #define IEEE802154_SCF_KEY_INDEX 1
  69. #define IEEE802154_SCF_KEY_SHORT_INDEX 2
  70. #define IEEE802154_SCF_KEY_HW_INDEX 3
  71. #define IEEE802154_SCF_SECLEVEL_NONE 0
  72. #define IEEE802154_SCF_SECLEVEL_MIC32 1
  73. #define IEEE802154_SCF_SECLEVEL_MIC64 2
  74. #define IEEE802154_SCF_SECLEVEL_MIC128 3
  75. #define IEEE802154_SCF_SECLEVEL_ENC 4
  76. #define IEEE802154_SCF_SECLEVEL_ENC_MIC32 5
  77. #define IEEE802154_SCF_SECLEVEL_ENC_MIC64 6
  78. #define IEEE802154_SCF_SECLEVEL_ENC_MIC128 7
  79. /* MAC footer size */
  80. #define IEEE802154_MFR_SIZE 2 /* 2 octets */
  81. /* MAC's Command Frames Identifiers */
  82. #define IEEE802154_CMD_ASSOCIATION_REQ 0x01
  83. #define IEEE802154_CMD_ASSOCIATION_RESP 0x02
  84. #define IEEE802154_CMD_DISASSOCIATION_NOTIFY 0x03
  85. #define IEEE802154_CMD_DATA_REQ 0x04
  86. #define IEEE802154_CMD_PANID_CONFLICT_NOTIFY 0x05
  87. #define IEEE802154_CMD_ORPHAN_NOTIFY 0x06
  88. #define IEEE802154_CMD_BEACON_REQ 0x07
  89. #define IEEE802154_CMD_COORD_REALIGN_NOTIFY 0x08
  90. #define IEEE802154_CMD_GTS_REQ 0x09
  91. /*
  92. * The return values of MAC operations
  93. */
  94. enum {
  95. /*
  96. * The requested operation was completed successfully.
  97. * For a transmission request, this value indicates
  98. * a successful transmission.
  99. */
  100. IEEE802154_SUCCESS = 0x0,
  101. /* The beacon was lost following a synchronization request. */
  102. IEEE802154_BEACON_LOSS = 0xe0,
  103. /*
  104. * A transmission could not take place due to activity on the
  105. * channel, i.e., the CSMA-CA mechanism has failed.
  106. */
  107. IEEE802154_CHNL_ACCESS_FAIL = 0xe1,
  108. /* The GTS request has been denied by the PAN coordinator. */
  109. IEEE802154_DENINED = 0xe2,
  110. /* The attempt to disable the transceiver has failed. */
  111. IEEE802154_DISABLE_TRX_FAIL = 0xe3,
  112. /*
  113. * The received frame induces a failed security check according to
  114. * the security suite.
  115. */
  116. IEEE802154_FAILED_SECURITY_CHECK = 0xe4,
  117. /*
  118. * The frame resulting from secure processing has a length that is
  119. * greater than aMACMaxFrameSize.
  120. */
  121. IEEE802154_FRAME_TOO_LONG = 0xe5,
  122. /*
  123. * The requested GTS transmission failed because the specified GTS
  124. * either did not have a transmit GTS direction or was not defined.
  125. */
  126. IEEE802154_INVALID_GTS = 0xe6,
  127. /*
  128. * A request to purge an MSDU from the transaction queue was made using
  129. * an MSDU handle that was not found in the transaction table.
  130. */
  131. IEEE802154_INVALID_HANDLE = 0xe7,
  132. /* A parameter in the primitive is out of the valid range.*/
  133. IEEE802154_INVALID_PARAMETER = 0xe8,
  134. /* No acknowledgment was received after aMaxFrameRetries. */
  135. IEEE802154_NO_ACK = 0xe9,
  136. /* A scan operation failed to find any network beacons.*/
  137. IEEE802154_NO_BEACON = 0xea,
  138. /* No response data were available following a request. */
  139. IEEE802154_NO_DATA = 0xeb,
  140. /* The operation failed because a short address was not allocated. */
  141. IEEE802154_NO_SHORT_ADDRESS = 0xec,
  142. /*
  143. * A receiver enable request was unsuccessful because it could not be
  144. * completed within the CAP.
  145. */
  146. IEEE802154_OUT_OF_CAP = 0xed,
  147. /*
  148. * A PAN identifier conflict has been detected and communicated to the
  149. * PAN coordinator.
  150. */
  151. IEEE802154_PANID_CONFLICT = 0xee,
  152. /* A coordinator realignment command has been received. */
  153. IEEE802154_REALIGMENT = 0xef,
  154. /* The transaction has expired and its information discarded. */
  155. IEEE802154_TRANSACTION_EXPIRED = 0xf0,
  156. /* There is no capacity to store the transaction. */
  157. IEEE802154_TRANSACTION_OVERFLOW = 0xf1,
  158. /*
  159. * The transceiver was in the transmitter enabled state when the
  160. * receiver was requested to be enabled.
  161. */
  162. IEEE802154_TX_ACTIVE = 0xf2,
  163. /* The appropriate key is not available in the ACL. */
  164. IEEE802154_UNAVAILABLE_KEY = 0xf3,
  165. /*
  166. * A SET/GET request was issued with the identifier of a PIB attribute
  167. * that is not supported.
  168. */
  169. IEEE802154_UNSUPPORTED_ATTR = 0xf4,
  170. /*
  171. * A request to perform a scan operation failed because the MLME was
  172. * in the process of performing a previously initiated scan operation.
  173. */
  174. IEEE802154_SCAN_IN_PROGRESS = 0xfc,
  175. };
  176. /**
  177. * ieee802154_is_valid_psdu_len - check if psdu len is valid
  178. * @len: psdu len with (MHR + payload + MFR)
  179. */
  180. static inline bool ieee802154_is_valid_psdu_len(const u8 len)
  181. {
  182. return (len >= IEEE802154_MIN_PSDU_LEN && len <= IEEE802154_MTU);
  183. }
  184. /**
  185. * ieee802154_is_valid_psdu_len - check if extended addr is valid
  186. * @addr: extended addr to check
  187. */
  188. static inline bool ieee802154_is_valid_extended_addr(const __le64 addr)
  189. {
  190. /* These EUI-64 addresses are reserved by IEEE. 0xffffffffffffffff
  191. * is used internally as extended to short address broadcast mapping.
  192. * This is currently a workaround because neighbor discovery can't
  193. * deal with short addresses types right now.
  194. */
  195. return ((addr != cpu_to_le64(0x0000000000000000ULL)) &&
  196. (addr != cpu_to_le64(0xffffffffffffffffULL)));
  197. }
  198. /**
  199. * ieee802154_random_extended_addr - generates a random extended address
  200. * @addr: extended addr pointer to place the random address
  201. */
  202. static inline void ieee802154_random_extended_addr(__le64 *addr)
  203. {
  204. get_random_bytes(addr, IEEE802154_EXTENDED_ADDR_LEN);
  205. /* toggle some bit if we hit an invalid extended addr */
  206. if (!ieee802154_is_valid_extended_addr(*addr))
  207. ((u8 *)addr)[IEEE802154_EXTENDED_ADDR_LEN - 1] ^= 0x01;
  208. }
  209. #endif /* LINUX_IEEE802154_H */