blob: 2c7a38d76a3a6dbfcdb2f827e7fb0b8654850d96 [file] [log] [blame]
Thomas Gleixner1802d0b2019-05-27 08:55:21 +02001// SPDX-License-Identifier: GPL-2.0-only
Sergey Lapin2c21d112009-06-08 12:18:49 +00002/*
3 * nl802154.h
4 *
5 * Copyright (C) 2007, 2008 Siemens AG
Sergey Lapin2c21d112009-06-08 12:18:49 +00006 */
7
8#include <linux/kernel.h>
9#include <net/netlink.h>
10#include <linux/nl802154.h>
11
12#define NLA_HW_ADDR NLA_U64
13
Dmitry Baryshkov78090a52009-08-07 02:58:38 +000014const struct nla_policy ieee802154_policy[IEEE802154_ATTR_MAX + 1] = {
Sergey Lapin2c21d112009-06-08 12:18:49 +000015 [IEEE802154_ATTR_DEV_NAME] = { .type = NLA_STRING, },
16 [IEEE802154_ATTR_DEV_INDEX] = { .type = NLA_U32, },
Dmitry Eremin-Solenikov1eaa9d02009-09-15 17:04:44 +040017 [IEEE802154_ATTR_PHY_NAME] = { .type = NLA_STRING, },
Sergey Lapin2c21d112009-06-08 12:18:49 +000018
19 [IEEE802154_ATTR_STATUS] = { .type = NLA_U8, },
20 [IEEE802154_ATTR_SHORT_ADDR] = { .type = NLA_U16, },
21 [IEEE802154_ATTR_HW_ADDR] = { .type = NLA_HW_ADDR, },
22 [IEEE802154_ATTR_PAN_ID] = { .type = NLA_U16, },
23 [IEEE802154_ATTR_CHANNEL] = { .type = NLA_U8, },
Dmitry Eremin-Solenikov16eea492009-08-19 19:32:24 +040024 [IEEE802154_ATTR_PAGE] = { .type = NLA_U8, },
Sergey Lapin2c21d112009-06-08 12:18:49 +000025 [IEEE802154_ATTR_COORD_SHORT_ADDR] = { .type = NLA_U16, },
26 [IEEE802154_ATTR_COORD_HW_ADDR] = { .type = NLA_HW_ADDR, },
27 [IEEE802154_ATTR_COORD_PAN_ID] = { .type = NLA_U16, },
28 [IEEE802154_ATTR_SRC_SHORT_ADDR] = { .type = NLA_U16, },
29 [IEEE802154_ATTR_SRC_HW_ADDR] = { .type = NLA_HW_ADDR, },
30 [IEEE802154_ATTR_SRC_PAN_ID] = { .type = NLA_U16, },
31 [IEEE802154_ATTR_DEST_SHORT_ADDR] = { .type = NLA_U16, },
32 [IEEE802154_ATTR_DEST_HW_ADDR] = { .type = NLA_HW_ADDR, },
33 [IEEE802154_ATTR_DEST_PAN_ID] = { .type = NLA_U16, },
34
35 [IEEE802154_ATTR_CAPABILITY] = { .type = NLA_U8, },
36 [IEEE802154_ATTR_REASON] = { .type = NLA_U8, },
37 [IEEE802154_ATTR_SCAN_TYPE] = { .type = NLA_U8, },
38 [IEEE802154_ATTR_CHANNELS] = { .type = NLA_U32, },
39 [IEEE802154_ATTR_DURATION] = { .type = NLA_U8, },
40 [IEEE802154_ATTR_ED_LIST] = { .len = 27 },
Dmitry Eremin-Solenikov1eaa9d02009-09-15 17:04:44 +040041 [IEEE802154_ATTR_CHANNEL_PAGE_LIST] = { .len = 32 * 4, },
Phoebe Buckheister9b2777d2014-02-17 11:34:08 +010042
43 [IEEE802154_ATTR_TXPOWER] = { .type = NLA_S8, },
Phoebe Buckheister84dda3c2014-02-17 11:34:10 +010044 [IEEE802154_ATTR_LBT_ENABLED] = { .type = NLA_U8, },
Phoebe Buckheisterba08fea2014-02-17 11:34:11 +010045 [IEEE802154_ATTR_CCA_MODE] = { .type = NLA_U8, },
Phoebe Buckheister6ca00192014-02-17 11:34:12 +010046 [IEEE802154_ATTR_CCA_ED_LEVEL] = { .type = NLA_S32, },
Phoebe Buckheister4244db12014-02-17 11:34:14 +010047 [IEEE802154_ATTR_CSMA_RETRIES] = { .type = NLA_U8, },
48 [IEEE802154_ATTR_CSMA_MIN_BE] = { .type = NLA_U8, },
49 [IEEE802154_ATTR_CSMA_MAX_BE] = { .type = NLA_U8, },
50
51 [IEEE802154_ATTR_FRAME_RETRIES] = { .type = NLA_S8, },
Phoebe Buckheister3e9c1562014-05-16 17:46:44 +020052
53 [IEEE802154_ATTR_LLSEC_ENABLED] = { .type = NLA_U8, },
54 [IEEE802154_ATTR_LLSEC_SECLEVEL] = { .type = NLA_U8, },
55 [IEEE802154_ATTR_LLSEC_KEY_MODE] = { .type = NLA_U8, },
56 [IEEE802154_ATTR_LLSEC_KEY_SOURCE_SHORT] = { .type = NLA_U32, },
57 [IEEE802154_ATTR_LLSEC_KEY_SOURCE_EXTENDED] = { .type = NLA_HW_ADDR, },
58 [IEEE802154_ATTR_LLSEC_KEY_ID] = { .type = NLA_U8, },
59 [IEEE802154_ATTR_LLSEC_FRAME_COUNTER] = { .type = NLA_U32 },
60 [IEEE802154_ATTR_LLSEC_KEY_BYTES] = { .len = 16, },
61 [IEEE802154_ATTR_LLSEC_KEY_USAGE_FRAME_TYPES] = { .type = NLA_U8, },
62 [IEEE802154_ATTR_LLSEC_KEY_USAGE_COMMANDS] = { .len = 258 / 8 },
63 [IEEE802154_ATTR_LLSEC_FRAME_TYPE] = { .type = NLA_U8, },
64 [IEEE802154_ATTR_LLSEC_CMD_FRAME_ID] = { .type = NLA_U8, },
65 [IEEE802154_ATTR_LLSEC_SECLEVELS] = { .type = NLA_U8, },
66 [IEEE802154_ATTR_LLSEC_DEV_OVERRIDE] = { .type = NLA_U8, },
67 [IEEE802154_ATTR_LLSEC_DEV_KEY_MODE] = { .type = NLA_U8, },
Sergey Lapin2c21d112009-06-08 12:18:49 +000068};