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 553ae75e02SAlexander Aring /* add new commands above here */ 563ae75e02SAlexander Aring 573ae75e02SAlexander Aring /* used to define NL802154_CMD_MAX below */ 583ae75e02SAlexander Aring __NL802154_CMD_AFTER_LAST, 593ae75e02SAlexander Aring NL802154_CMD_MAX = __NL802154_CMD_AFTER_LAST - 1 603ae75e02SAlexander Aring }; 613ae75e02SAlexander Aring 623ae75e02SAlexander Aring enum nl802154_attrs { 633ae75e02SAlexander Aring /* don't change the order or add anything between, this is ABI! */ 643ae75e02SAlexander Aring /* currently we don't shipping this file via uapi, ignore the above one */ 653ae75e02SAlexander Aring NL802154_ATTR_UNSPEC, 663ae75e02SAlexander Aring 673ae75e02SAlexander Aring NL802154_ATTR_WPAN_PHY, 683ae75e02SAlexander Aring NL802154_ATTR_WPAN_PHY_NAME, 693ae75e02SAlexander Aring 703ae75e02SAlexander Aring NL802154_ATTR_IFINDEX, 713ae75e02SAlexander Aring NL802154_ATTR_IFNAME, 723ae75e02SAlexander Aring NL802154_ATTR_IFTYPE, 733ae75e02SAlexander Aring 743ae75e02SAlexander Aring NL802154_ATTR_WPAN_DEV, 753ae75e02SAlexander Aring 763ae75e02SAlexander Aring NL802154_ATTR_PAGE, 773ae75e02SAlexander Aring NL802154_ATTR_CHANNEL, 783ae75e02SAlexander Aring 793ae75e02SAlexander Aring NL802154_ATTR_PAN_ID, 803ae75e02SAlexander Aring NL802154_ATTR_SHORT_ADDR, 813ae75e02SAlexander Aring 823ae75e02SAlexander Aring NL802154_ATTR_TX_POWER, 833ae75e02SAlexander Aring 843ae75e02SAlexander Aring NL802154_ATTR_CCA_MODE, 85ba2a9506SAlexander Aring NL802154_ATTR_CCA_OPT, 863ae75e02SAlexander Aring NL802154_ATTR_CCA_ED_LEVEL, 873ae75e02SAlexander Aring 883ae75e02SAlexander Aring NL802154_ATTR_MAX_FRAME_RETRIES, 893ae75e02SAlexander Aring 903ae75e02SAlexander Aring NL802154_ATTR_MAX_BE, 913ae75e02SAlexander Aring NL802154_ATTR_MIN_BE, 923ae75e02SAlexander Aring NL802154_ATTR_MAX_CSMA_BACKOFFS, 933ae75e02SAlexander Aring 943ae75e02SAlexander Aring NL802154_ATTR_LBT_MODE, 953ae75e02SAlexander Aring 963ae75e02SAlexander Aring NL802154_ATTR_GENERATION, 973ae75e02SAlexander Aring 983ae75e02SAlexander Aring NL802154_ATTR_CHANNELS_SUPPORTED, 993ae75e02SAlexander Aring NL802154_ATTR_SUPPORTED_CHANNEL, 1003ae75e02SAlexander Aring 1013ae75e02SAlexander Aring NL802154_ATTR_EXTENDED_ADDR, 1023ae75e02SAlexander Aring 103*0e665457SAlexander Aring NL802154_ATTR_WPAN_PHY_CAPS, 104*0e665457SAlexander Aring 1053ae75e02SAlexander Aring /* add attributes here, update the policy in nl802154.c */ 1063ae75e02SAlexander Aring 1073ae75e02SAlexander Aring __NL802154_ATTR_AFTER_LAST, 1083ae75e02SAlexander Aring NL802154_ATTR_MAX = __NL802154_ATTR_AFTER_LAST - 1 1093ae75e02SAlexander Aring }; 1103ae75e02SAlexander Aring 1113ae75e02SAlexander Aring enum nl802154_iftype { 1123ae75e02SAlexander Aring /* for backwards compatibility TODO */ 1133ae75e02SAlexander Aring NL802154_IFTYPE_UNSPEC = -1, 1143ae75e02SAlexander Aring 1153ae75e02SAlexander Aring NL802154_IFTYPE_NODE, 1163ae75e02SAlexander Aring NL802154_IFTYPE_MONITOR, 1173ae75e02SAlexander Aring NL802154_IFTYPE_COORD, 1183ae75e02SAlexander Aring 1193ae75e02SAlexander Aring /* keep last */ 1203ae75e02SAlexander Aring NUM_NL802154_IFTYPES, 1213ae75e02SAlexander Aring NL802154_IFTYPE_MAX = NUM_NL802154_IFTYPES - 1 1223ae75e02SAlexander Aring }; 1233ae75e02SAlexander Aring 124b40d6376SAlexander Aring /** 125*0e665457SAlexander Aring * enum nl802154_wpan_phy_capability_attr - wpan phy capability attributes 126*0e665457SAlexander Aring * 127*0e665457SAlexander Aring * @__NL802154_CAP_ATTR_INVALID: attribute number 0 is reserved 128*0e665457SAlexander Aring * @NL802154_CAP_ATTR_CHANNELS: a nested attribute for nl802154_channel_attr 129*0e665457SAlexander Aring * @NL802154_CAP_ATTR_TX_POWERS: a nested attribute for 130*0e665457SAlexander Aring * nl802154_wpan_phy_tx_power 131*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_CCA_ED_LEVEL: minimum value for cca_ed_level 132*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_CCA_ED_LEVEL: maxmimum value for cca_ed_level 133*0e665457SAlexander Aring * @NL802154_CAP_ATTR_CCA_MODES: nl802154_cca_modes flags 134*0e665457SAlexander Aring * @NL802154_CAP_ATTR_CCA_OPTS: nl802154_cca_opts flags 135*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_MINBE: minimum of minbe value 136*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_MINBE: maximum of minbe value 137*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_MAXBE: minimum of maxbe value 138*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_MINBE: maximum of maxbe value 139*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_CSMA_BACKOFFS: minimum of csma backoff value 140*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_CSMA_BACKOFFS: maximum of csma backoffs value 141*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MIN_FRAME_RETRIES: minimum of frame retries value 142*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX_FRAME_RETRIES: maximum of frame retries value 143*0e665457SAlexander Aring * @NL802154_CAP_ATTR_IFTYPES: nl802154_iftype flags 144*0e665457SAlexander Aring * @NL802154_CAP_ATTR_LBT: nl802154_supported_bool_states flags 145*0e665457SAlexander Aring * @NL802154_CAP_ATTR_MAX: highest cap attribute currently defined 146*0e665457SAlexander Aring * @__NL802154_CAP_ATTR_AFTER_LAST: internal use 147*0e665457SAlexander Aring */ 148*0e665457SAlexander Aring enum nl802154_wpan_phy_capability_attr { 149*0e665457SAlexander Aring __NL802154_CAP_ATTR_INVALID, 150*0e665457SAlexander Aring 151*0e665457SAlexander Aring NL802154_CAP_ATTR_IFTYPES, 152*0e665457SAlexander Aring 153*0e665457SAlexander Aring NL802154_CAP_ATTR_CHANNELS, 154*0e665457SAlexander Aring NL802154_CAP_ATTR_TX_POWERS, 155*0e665457SAlexander Aring 156*0e665457SAlexander Aring NL802154_CAP_ATTR_CCA_ED_LEVELS, 157*0e665457SAlexander Aring NL802154_CAP_ATTR_CCA_MODES, 158*0e665457SAlexander Aring NL802154_CAP_ATTR_CCA_OPTS, 159*0e665457SAlexander Aring 160*0e665457SAlexander Aring NL802154_CAP_ATTR_MIN_MINBE, 161*0e665457SAlexander Aring NL802154_CAP_ATTR_MAX_MINBE, 162*0e665457SAlexander Aring 163*0e665457SAlexander Aring NL802154_CAP_ATTR_MIN_MAXBE, 164*0e665457SAlexander Aring NL802154_CAP_ATTR_MAX_MAXBE, 165*0e665457SAlexander Aring 166*0e665457SAlexander Aring NL802154_CAP_ATTR_MIN_CSMA_BACKOFFS, 167*0e665457SAlexander Aring NL802154_CAP_ATTR_MAX_CSMA_BACKOFFS, 168*0e665457SAlexander Aring 169*0e665457SAlexander Aring NL802154_CAP_ATTR_MIN_FRAME_RETRIES, 170*0e665457SAlexander Aring NL802154_CAP_ATTR_MAX_FRAME_RETRIES, 171*0e665457SAlexander Aring 172*0e665457SAlexander Aring NL802154_CAP_ATTR_LBT, 173*0e665457SAlexander Aring 174*0e665457SAlexander Aring /* keep last */ 175*0e665457SAlexander Aring __NL802154_CAP_ATTR_AFTER_LAST, 176*0e665457SAlexander Aring NL802154_CAP_ATTR_MAX = __NL802154_CAP_ATTR_AFTER_LAST - 1 177*0e665457SAlexander Aring }; 178*0e665457SAlexander Aring 179*0e665457SAlexander Aring /** 180b40d6376SAlexander Aring * enum nl802154_cca_modes - cca modes 181b40d6376SAlexander Aring * 182b40d6376SAlexander Aring * @__NL802154_CCA_INVALID: cca mode number 0 is reserved 183b40d6376SAlexander Aring * @NL802154_CCA_ENERGY: Energy above threshold 184b40d6376SAlexander Aring * @NL802154_CCA_CARRIER: Carrier sense only 185b40d6376SAlexander Aring * @NL802154_CCA_ENERGY_CARRIER: Carrier sense with energy above threshold 186b40d6376SAlexander Aring * @NL802154_CCA_ALOHA: CCA shall always report an idle medium 187b40d6376SAlexander Aring * @NL802154_CCA_UWB_SHR: UWB preamble sense based on the SHR of a frame 188b40d6376SAlexander Aring * @NL802154_CCA_UWB_MULTIPEXED: UWB preamble sense based on the packet with 189b40d6376SAlexander Aring * the multiplexed preamble 190b40d6376SAlexander Aring * @__NL802154_CCA_ATTR_AFTER_LAST: Internal 191b40d6376SAlexander Aring * @NL802154_CCA_ATTR_MAX: Maximum CCA attribute number 192b40d6376SAlexander Aring */ 193b40d6376SAlexander Aring enum nl802154_cca_modes { 194b40d6376SAlexander Aring __NL802154_CCA_INVALID, 195b40d6376SAlexander Aring NL802154_CCA_ENERGY, 196b40d6376SAlexander Aring NL802154_CCA_CARRIER, 197b40d6376SAlexander Aring NL802154_CCA_ENERGY_CARRIER, 198b40d6376SAlexander Aring NL802154_CCA_ALOHA, 199b40d6376SAlexander Aring NL802154_CCA_UWB_SHR, 200b40d6376SAlexander Aring NL802154_CCA_UWB_MULTIPEXED, 201b40d6376SAlexander Aring 202b40d6376SAlexander Aring /* keep last */ 203b40d6376SAlexander Aring __NL802154_CCA_ATTR_AFTER_LAST, 204b40d6376SAlexander Aring NL802154_CCA_ATTR_MAX = __NL802154_CCA_ATTR_AFTER_LAST - 1 205b40d6376SAlexander Aring }; 206b40d6376SAlexander Aring 207b40d6376SAlexander Aring /** 208b40d6376SAlexander Aring * enum nl802154_cca_opts - additional options for cca modes 209b40d6376SAlexander Aring * 210b40d6376SAlexander Aring * @NL802154_CCA_OPT_ENERGY_CARRIER_OR: NL802154_CCA_ENERGY_CARRIER with OR 211b40d6376SAlexander Aring * @NL802154_CCA_OPT_ENERGY_CARRIER_AND: NL802154_CCA_ENERGY_CARRIER with AND 212b40d6376SAlexander Aring */ 213b40d6376SAlexander Aring enum nl802154_cca_opts { 214b40d6376SAlexander Aring NL802154_CCA_OPT_ENERGY_CARRIER_AND, 215b40d6376SAlexander Aring NL802154_CCA_OPT_ENERGY_CARRIER_OR, 216b40d6376SAlexander Aring 217b40d6376SAlexander Aring /* keep last */ 218b40d6376SAlexander Aring __NL802154_CCA_OPT_ATTR_AFTER_LAST, 219b40d6376SAlexander Aring NL802154_CCA_OPT_ATTR_MAX = __NL802154_CCA_OPT_ATTR_AFTER_LAST - 1 220b40d6376SAlexander Aring }; 221b40d6376SAlexander Aring 222fea3318dSAlexander Aring /** 223fea3318dSAlexander Aring * enum nl802154_supported_bool_states - bool states for bool capability entry 224fea3318dSAlexander Aring * 225fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_FALSE: indicates to set false 226fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_TRUE: indicates to set true 227fea3318dSAlexander Aring * @__NL802154_SUPPORTED_BOOL_INVALD: reserved 228fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_BOTH: indicates to set true and false 229fea3318dSAlexander Aring * @__NL802154_SUPPORTED_BOOL_AFTER_LAST: Internal 230fea3318dSAlexander Aring * @NL802154_SUPPORTED_BOOL_MAX: highest value for bool states 231fea3318dSAlexander Aring */ 232fea3318dSAlexander Aring enum nl802154_supported_bool_states { 233fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_FALSE, 234fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_TRUE, 235fea3318dSAlexander Aring /* to handle them in a mask */ 236fea3318dSAlexander Aring __NL802154_SUPPORTED_BOOL_INVALD, 237fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_BOTH, 238fea3318dSAlexander Aring 239fea3318dSAlexander Aring /* keep last */ 240fea3318dSAlexander Aring __NL802154_SUPPORTED_BOOL_AFTER_LAST, 241fea3318dSAlexander Aring NL802154_SUPPORTED_BOOL_MAX = __NL802154_SUPPORTED_BOOL_AFTER_LAST - 1 242fea3318dSAlexander Aring }; 243fea3318dSAlexander Aring 2443ae75e02SAlexander Aring #endif /* __NL802154_H */ 245