13ae75e02SAlexander Aring #ifndef __NL802154_H 23ae75e02SAlexander Aring #define __NL802154_H 33ae75e02SAlexander Aring /* 43ae75e02SAlexander Aring * 802.15.4 netlink interface public header 53ae75e02SAlexander Aring * 63ae75e02SAlexander Aring * Copyright 2014 Alexander Aring <aar@pengutronix.de> 73ae75e02SAlexander Aring * 83ae75e02SAlexander Aring * Permission to use, copy, modify, and/or distribute this software for any 93ae75e02SAlexander Aring * purpose with or without fee is hereby granted, provided that the above 103ae75e02SAlexander Aring * copyright notice and this permission notice appear in all copies. 113ae75e02SAlexander Aring * 123ae75e02SAlexander Aring * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES 133ae75e02SAlexander Aring * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF 143ae75e02SAlexander Aring * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR 153ae75e02SAlexander Aring * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES 163ae75e02SAlexander Aring * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN 173ae75e02SAlexander Aring * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF 183ae75e02SAlexander Aring * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. 193ae75e02SAlexander Aring * 203ae75e02SAlexander Aring */ 213ae75e02SAlexander Aring 223ae75e02SAlexander Aring #define NL802154_GENL_NAME "nl802154" 233ae75e02SAlexander Aring 243ae75e02SAlexander Aring enum nl802154_commands { 253ae75e02SAlexander Aring /* don't change the order or add anything between, this is ABI! */ 263ae75e02SAlexander Aring /* currently we don't shipping this file via uapi, ignore the above one */ 273ae75e02SAlexander Aring NL802154_CMD_UNSPEC, 283ae75e02SAlexander Aring 293ae75e02SAlexander Aring NL802154_CMD_GET_WPAN_PHY, /* can dump */ 303ae75e02SAlexander Aring NL802154_CMD_SET_WPAN_PHY, 313ae75e02SAlexander Aring NL802154_CMD_NEW_WPAN_PHY, 323ae75e02SAlexander Aring NL802154_CMD_DEL_WPAN_PHY, 333ae75e02SAlexander Aring 343ae75e02SAlexander Aring NL802154_CMD_GET_INTERFACE, /* can dump */ 353ae75e02SAlexander Aring NL802154_CMD_SET_INTERFACE, 363ae75e02SAlexander Aring NL802154_CMD_NEW_INTERFACE, 373ae75e02SAlexander Aring NL802154_CMD_DEL_INTERFACE, 383ae75e02SAlexander Aring 393ae75e02SAlexander Aring NL802154_CMD_SET_CHANNEL, 403ae75e02SAlexander Aring 413ae75e02SAlexander Aring NL802154_CMD_SET_PAN_ID, 423ae75e02SAlexander Aring NL802154_CMD_SET_SHORT_ADDR, 433ae75e02SAlexander Aring 443ae75e02SAlexander Aring NL802154_CMD_SET_TX_POWER, 453ae75e02SAlexander Aring NL802154_CMD_SET_CCA_MODE, 463ae75e02SAlexander Aring NL802154_CMD_SET_CCA_ED_LEVEL, 473ae75e02SAlexander Aring 483ae75e02SAlexander Aring NL802154_CMD_SET_MAX_FRAME_RETRIES, 493ae75e02SAlexander Aring 503ae75e02SAlexander Aring NL802154_CMD_SET_BACKOFF_EXPONENT, 513ae75e02SAlexander Aring NL802154_CMD_SET_MAX_CSMA_BACKOFFS, 523ae75e02SAlexander Aring 533ae75e02SAlexander Aring NL802154_CMD_SET_LBT_MODE, 543ae75e02SAlexander Aring 55*c91208d8SAlexander Aring NL802154_CMD_SET_ACKREQ_DEFAULT, 56*c91208d8SAlexander Aring 573ae75e02SAlexander Aring /* add new commands above here */ 583ae75e02SAlexander Aring 593ae75e02SAlexander Aring /* used to define NL802154_CMD_MAX below */ 603ae75e02SAlexander Aring __NL802154_CMD_AFTER_LAST, 613ae75e02SAlexander Aring NL802154_CMD_MAX = __NL802154_CMD_AFTER_LAST - 1 623ae75e02SAlexander Aring }; 633ae75e02SAlexander Aring 643ae75e02SAlexander Aring enum nl802154_attrs { 653ae75e02SAlexander Aring /* don't change the order or add anything between, this is ABI! */ 663ae75e02SAlexander Aring /* currently we don't shipping this file via uapi, ignore the above one */ 673ae75e02SAlexander Aring NL802154_ATTR_UNSPEC, 683ae75e02SAlexander Aring 693ae75e02SAlexander Aring NL802154_ATTR_WPAN_PHY, 703ae75e02SAlexander Aring NL802154_ATTR_WPAN_PHY_NAME, 713ae75e02SAlexander Aring 723ae75e02SAlexander Aring NL802154_ATTR_IFINDEX, 733ae75e02SAlexander Aring NL802154_ATTR_IFNAME, 743ae75e02SAlexander Aring NL802154_ATTR_IFTYPE, 753ae75e02SAlexander Aring 763ae75e02SAlexander Aring NL802154_ATTR_WPAN_DEV, 773ae75e02SAlexander Aring 783ae75e02SAlexander Aring NL802154_ATTR_PAGE, 793ae75e02SAlexander Aring NL802154_ATTR_CHANNEL, 803ae75e02SAlexander Aring 813ae75e02SAlexander Aring NL802154_ATTR_PAN_ID, 823ae75e02SAlexander Aring NL802154_ATTR_SHORT_ADDR, 833ae75e02SAlexander Aring 843ae75e02SAlexander Aring NL802154_ATTR_TX_POWER, 853ae75e02SAlexander Aring 863ae75e02SAlexander Aring NL802154_ATTR_CCA_MODE, 87ba2a9506SAlexander Aring NL802154_ATTR_CCA_OPT, 883ae75e02SAlexander Aring NL802154_ATTR_CCA_ED_LEVEL, 893ae75e02SAlexander Aring 903ae75e02SAlexander Aring NL802154_ATTR_MAX_FRAME_RETRIES, 913ae75e02SAlexander Aring 923ae75e02SAlexander Aring NL802154_ATTR_MAX_BE, 933ae75e02SAlexander Aring NL802154_ATTR_MIN_BE, 943ae75e02SAlexander Aring NL802154_ATTR_MAX_CSMA_BACKOFFS, 953ae75e02SAlexander Aring 963ae75e02SAlexander Aring NL802154_ATTR_LBT_MODE, 973ae75e02SAlexander Aring 983ae75e02SAlexander Aring NL802154_ATTR_GENERATION, 993ae75e02SAlexander Aring 1003ae75e02SAlexander Aring NL802154_ATTR_CHANNELS_SUPPORTED, 1013ae75e02SAlexander Aring NL802154_ATTR_SUPPORTED_CHANNEL, 1023ae75e02SAlexander Aring 1033ae75e02SAlexander Aring NL802154_ATTR_EXTENDED_ADDR, 1043ae75e02SAlexander Aring 1050e665457SAlexander Aring NL802154_ATTR_WPAN_PHY_CAPS, 1060e665457SAlexander Aring 107133be026SVarka Bhadram NL802154_ATTR_SUPPORTED_COMMANDS, 108133be026SVarka Bhadram 109*c91208d8SAlexander Aring NL802154_ATTR_ACKREQ_DEFAULT, 110*c91208d8SAlexander Aring 1113ae75e02SAlexander Aring /* add attributes here, update the policy in nl802154.c */ 1123ae75e02SAlexander Aring 1133ae75e02SAlexander Aring __NL802154_ATTR_AFTER_LAST, 1143ae75e02SAlexander Aring NL802154_ATTR_MAX = __NL802154_ATTR_AFTER_LAST - 1 1153ae75e02SAlexander Aring }; 1163ae75e02SAlexander Aring 1173ae75e02SAlexander Aring enum nl802154_iftype { 1183ae75e02SAlexander Aring /* for backwards compatibility TODO */ 1193ae75e02SAlexander Aring NL802154_IFTYPE_UNSPEC = -1, 1203ae75e02SAlexander Aring 1213ae75e02SAlexander Aring NL802154_IFTYPE_NODE, 1223ae75e02SAlexander Aring NL802154_IFTYPE_MONITOR, 1233ae75e02SAlexander Aring NL802154_IFTYPE_COORD, 1243ae75e02SAlexander Aring 1253ae75e02SAlexander Aring /* keep last */ 1263ae75e02SAlexander Aring NUM_NL802154_IFTYPES, 1273ae75e02SAlexander Aring NL802154_IFTYPE_MAX = NUM_NL802154_IFTYPES - 1 1283ae75e02SAlexander Aring }; 1293ae75e02SAlexander Aring 130b40d6376SAlexander Aring /** 1310e665457SAlexander Aring * enum nl802154_wpan_phy_capability_attr - wpan phy capability attributes 1320e665457SAlexander Aring * 1330e665457SAlexander Aring * @__NL802154_CAP_ATTR_INVALID: attribute number 0 is reserved 1340e665457SAlexander Aring * @NL802154_CAP_ATTR_CHANNELS: a nested attribute for nl802154_channel_attr 1350e665457SAlexander Aring * @NL802154_CAP_ATTR_TX_POWERS: a nested attribute for 1360e665457SAlexander Aring * nl802154_wpan_phy_tx_power 1370e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_CCA_ED_LEVEL: minimum value for cca_ed_level 1380e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_CCA_ED_LEVEL: maxmimum value for cca_ed_level 1390e665457SAlexander Aring * @NL802154_CAP_ATTR_CCA_MODES: nl802154_cca_modes flags 1400e665457SAlexander Aring * @NL802154_CAP_ATTR_CCA_OPTS: nl802154_cca_opts flags 1410e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_MINBE: minimum of minbe value 1420e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_MINBE: maximum of minbe value 1430e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_MAXBE: minimum of maxbe value 1440e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_MINBE: maximum of maxbe value 1450e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_CSMA_BACKOFFS: minimum of csma backoff value 1460e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_CSMA_BACKOFFS: maximum of csma backoffs value 1470e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_FRAME_RETRIES: minimum of frame retries value 1480e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_FRAME_RETRIES: maximum of frame retries value 1490e665457SAlexander Aring * @NL802154_CAP_ATTR_IFTYPES: nl802154_iftype flags 1500e665457SAlexander Aring * @NL802154_CAP_ATTR_LBT: nl802154_supported_bool_states flags 1510e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX: highest cap attribute currently defined 1520e665457SAlexander Aring * @__NL802154_CAP_ATTR_AFTER_LAST: internal use 1530e665457SAlexander Aring */ 1540e665457SAlexander Aring enum nl802154_wpan_phy_capability_attr { 1550e665457SAlexander Aring __NL802154_CAP_ATTR_INVALID, 1560e665457SAlexander Aring 1570e665457SAlexander Aring NL802154_CAP_ATTR_IFTYPES, 1580e665457SAlexander Aring 1590e665457SAlexander Aring NL802154_CAP_ATTR_CHANNELS, 1600e665457SAlexander Aring NL802154_CAP_ATTR_TX_POWERS, 1610e665457SAlexander Aring 1620e665457SAlexander Aring NL802154_CAP_ATTR_CCA_ED_LEVELS, 1630e665457SAlexander Aring NL802154_CAP_ATTR_CCA_MODES, 1640e665457SAlexander Aring NL802154_CAP_ATTR_CCA_OPTS, 1650e665457SAlexander Aring 1660e665457SAlexander Aring NL802154_CAP_ATTR_MIN_MINBE, 1670e665457SAlexander Aring NL802154_CAP_ATTR_MAX_MINBE, 1680e665457SAlexander Aring 1690e665457SAlexander Aring NL802154_CAP_ATTR_MIN_MAXBE, 1700e665457SAlexander Aring NL802154_CAP_ATTR_MAX_MAXBE, 1710e665457SAlexander Aring 1720e665457SAlexander Aring NL802154_CAP_ATTR_MIN_CSMA_BACKOFFS, 1730e665457SAlexander Aring NL802154_CAP_ATTR_MAX_CSMA_BACKOFFS, 1740e665457SAlexander Aring 1750e665457SAlexander Aring NL802154_CAP_ATTR_MIN_FRAME_RETRIES, 1760e665457SAlexander Aring NL802154_CAP_ATTR_MAX_FRAME_RETRIES, 1770e665457SAlexander Aring 1780e665457SAlexander Aring NL802154_CAP_ATTR_LBT, 1790e665457SAlexander Aring 1800e665457SAlexander Aring /* keep last */ 1810e665457SAlexander Aring __NL802154_CAP_ATTR_AFTER_LAST, 1820e665457SAlexander Aring NL802154_CAP_ATTR_MAX = __NL802154_CAP_ATTR_AFTER_LAST - 1 1830e665457SAlexander Aring }; 1840e665457SAlexander Aring 1850e665457SAlexander Aring /** 186b40d6376SAlexander Aring * enum nl802154_cca_modes - cca modes 187b40d6376SAlexander Aring * 188b40d6376SAlexander Aring * @__NL802154_CCA_INVALID: cca mode number 0 is reserved 189b40d6376SAlexander Aring * @NL802154_CCA_ENERGY: Energy above threshold 190b40d6376SAlexander Aring * @NL802154_CCA_CARRIER: Carrier sense only 191b40d6376SAlexander Aring * @NL802154_CCA_ENERGY_CARRIER: Carrier sense with energy above threshold 192b40d6376SAlexander Aring * @NL802154_CCA_ALOHA: CCA shall always report an idle medium 193b40d6376SAlexander Aring * @NL802154_CCA_UWB_SHR: UWB preamble sense based on the SHR of a frame 194d446278cSChristoffer Holmstedt * @NL802154_CCA_UWB_MULTIPLEXED: UWB preamble sense based on the packet with 195b40d6376SAlexander Aring * the multiplexed preamble 196b40d6376SAlexander Aring * @__NL802154_CCA_ATTR_AFTER_LAST: Internal 197b40d6376SAlexander Aring * @NL802154_CCA_ATTR_MAX: Maximum CCA attribute number 198b40d6376SAlexander Aring */ 199b40d6376SAlexander Aring enum nl802154_cca_modes { 200b40d6376SAlexander Aring __NL802154_CCA_INVALID, 201b40d6376SAlexander Aring NL802154_CCA_ENERGY, 202b40d6376SAlexander Aring NL802154_CCA_CARRIER, 203b40d6376SAlexander Aring NL802154_CCA_ENERGY_CARRIER, 204b40d6376SAlexander Aring NL802154_CCA_ALOHA, 205b40d6376SAlexander Aring NL802154_CCA_UWB_SHR, 206d446278cSChristoffer Holmstedt NL802154_CCA_UWB_MULTIPLEXED, 207b40d6376SAlexander Aring 208b40d6376SAlexander Aring /* keep last */ 209b40d6376SAlexander Aring __NL802154_CCA_ATTR_AFTER_LAST, 210b40d6376SAlexander Aring NL802154_CCA_ATTR_MAX = __NL802154_CCA_ATTR_AFTER_LAST - 1 211b40d6376SAlexander Aring }; 212b40d6376SAlexander Aring 213b40d6376SAlexander Aring /** 214b40d6376SAlexander Aring * enum nl802154_cca_opts - additional options for cca modes 215b40d6376SAlexander Aring * 216b40d6376SAlexander Aring * @NL802154_CCA_OPT_ENERGY_CARRIER_OR: NL802154_CCA_ENERGY_CARRIER with OR 217b40d6376SAlexander Aring * @NL802154_CCA_OPT_ENERGY_CARRIER_AND: NL802154_CCA_ENERGY_CARRIER with AND 218b40d6376SAlexander Aring */ 219b40d6376SAlexander Aring enum nl802154_cca_opts { 220b40d6376SAlexander Aring NL802154_CCA_OPT_ENERGY_CARRIER_AND, 221b40d6376SAlexander Aring NL802154_CCA_OPT_ENERGY_CARRIER_OR, 222b40d6376SAlexander Aring 223b40d6376SAlexander Aring /* keep last */ 224b40d6376SAlexander Aring __NL802154_CCA_OPT_ATTR_AFTER_LAST, 225b40d6376SAlexander Aring NL802154_CCA_OPT_ATTR_MAX = __NL802154_CCA_OPT_ATTR_AFTER_LAST - 1 226b40d6376SAlexander Aring }; 227b40d6376SAlexander Aring 228fea3318dSAlexander Aring /** 229fea3318dSAlexander Aring * enum nl802154_supported_bool_states - bool states for bool capability entry 230fea3318dSAlexander Aring * 231fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_FALSE: indicates to set false 232fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_TRUE: indicates to set true 233fea3318dSAlexander Aring * @__NL802154_SUPPORTED_BOOL_INVALD: reserved 234fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_BOTH: indicates to set true and false 235fea3318dSAlexander Aring * @__NL802154_SUPPORTED_BOOL_AFTER_LAST: Internal 236fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_MAX: highest value for bool states 237fea3318dSAlexander Aring */ 238fea3318dSAlexander Aring enum nl802154_supported_bool_states { 239fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_FALSE, 240fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_TRUE, 241fea3318dSAlexander Aring /* to handle them in a mask */ 242fea3318dSAlexander Aring __NL802154_SUPPORTED_BOOL_INVALD, 243fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_BOTH, 244fea3318dSAlexander Aring 245fea3318dSAlexander Aring /* keep last */ 246fea3318dSAlexander Aring __NL802154_SUPPORTED_BOOL_AFTER_LAST, 247fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_MAX = __NL802154_SUPPORTED_BOOL_AFTER_LAST - 1 248fea3318dSAlexander Aring }; 249fea3318dSAlexander Aring 2503ae75e02SAlexander Aring #endif /* __NL802154_H */ 251