diff options
author | Alexey Dobriyan <adobriyan@gmail.com> | 2010-02-18 03:14:31 -0500 |
---|---|---|
committer | David S. Miller <davem@davemloft.net> | 2010-02-18 17:30:18 -0500 |
commit | b54452b07a7b1b8cc1385edba3ef2ef6d4679d5a (patch) | |
tree | c8a7271b14c4cd9e0dc22a5d0a3bed9e79c88e36 | |
parent | 3ffe533c87281b68d469b279ff3a5056f9c75862 (diff) |
const: struct nla_policy
Make remaining netlink policies as const.
Fixup coding style where needed.
Signed-off-by: Alexey Dobriyan <adobriyan@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
-rw-r--r-- | include/net/netlink.h | 2 | ||||
-rw-r--r-- | kernel/taskstats.c | 6 | ||||
-rw-r--r-- | net/dcb/dcbnl.c | 16 | ||||
-rw-r--r-- | net/irda/irnetlink.c | 2 | ||||
-rw-r--r-- | net/wimax/op-msg.c | 3 | ||||
-rw-r--r-- | net/wimax/op-reset.c | 3 | ||||
-rw-r--r-- | net/wimax/op-rfkill.c | 3 | ||||
-rw-r--r-- | net/wimax/op-state-get.c | 3 | ||||
-rw-r--r-- | net/wimax/stack.c | 3 | ||||
-rw-r--r-- | net/wireless/nl80211.c | 14 |
10 files changed, 22 insertions, 33 deletions
diff --git a/include/net/netlink.h b/include/net/netlink.h index a63b2192ac1c..f82e463c875a 100644 --- a/include/net/netlink.h +++ b/include/net/netlink.h | |||
@@ -196,7 +196,7 @@ enum { | |||
196 | * All other Exact length of attribute payload | 196 | * All other Exact length of attribute payload |
197 | * | 197 | * |
198 | * Example: | 198 | * Example: |
199 | * static struct nla_policy my_policy[ATTR_MAX+1] __read_mostly = { | 199 | * static const struct nla_policy my_policy[ATTR_MAX+1] = { |
200 | * [ATTR_FOO] = { .type = NLA_U16 }, | 200 | * [ATTR_FOO] = { .type = NLA_U16 }, |
201 | * [ATTR_BAR] = { .type = NLA_STRING, .len = BARSIZ }, | 201 | * [ATTR_BAR] = { .type = NLA_STRING, .len = BARSIZ }, |
202 | * [ATTR_BAZ] = { .len = sizeof(struct mystruct) }, | 202 | * [ATTR_BAZ] = { .len = sizeof(struct mystruct) }, |
diff --git a/kernel/taskstats.c b/kernel/taskstats.c index ea8384d3caa7..899ca51be5e8 100644 --- a/kernel/taskstats.c +++ b/kernel/taskstats.c | |||
@@ -46,15 +46,13 @@ static struct genl_family family = { | |||
46 | .maxattr = TASKSTATS_CMD_ATTR_MAX, | 46 | .maxattr = TASKSTATS_CMD_ATTR_MAX, |
47 | }; | 47 | }; |
48 | 48 | ||
49 | static struct nla_policy taskstats_cmd_get_policy[TASKSTATS_CMD_ATTR_MAX+1] | 49 | static const struct nla_policy taskstats_cmd_get_policy[TASKSTATS_CMD_ATTR_MAX+1] = { |
50 | __read_mostly = { | ||
51 | [TASKSTATS_CMD_ATTR_PID] = { .type = NLA_U32 }, | 50 | [TASKSTATS_CMD_ATTR_PID] = { .type = NLA_U32 }, |
52 | [TASKSTATS_CMD_ATTR_TGID] = { .type = NLA_U32 }, | 51 | [TASKSTATS_CMD_ATTR_TGID] = { .type = NLA_U32 }, |
53 | [TASKSTATS_CMD_ATTR_REGISTER_CPUMASK] = { .type = NLA_STRING }, | 52 | [TASKSTATS_CMD_ATTR_REGISTER_CPUMASK] = { .type = NLA_STRING }, |
54 | [TASKSTATS_CMD_ATTR_DEREGISTER_CPUMASK] = { .type = NLA_STRING },}; | 53 | [TASKSTATS_CMD_ATTR_DEREGISTER_CPUMASK] = { .type = NLA_STRING },}; |
55 | 54 | ||
56 | static struct nla_policy | 55 | static const struct nla_policy cgroupstats_cmd_get_policy[CGROUPSTATS_CMD_ATTR_MAX+1] = { |
57 | cgroupstats_cmd_get_policy[CGROUPSTATS_CMD_ATTR_MAX+1] __read_mostly = { | ||
58 | [CGROUPSTATS_CMD_ATTR_FD] = { .type = NLA_U32 }, | 56 | [CGROUPSTATS_CMD_ATTR_FD] = { .type = NLA_U32 }, |
59 | }; | 57 | }; |
60 | 58 | ||
diff --git a/net/dcb/dcbnl.c b/net/dcb/dcbnl.c index db9f5b39388f..813e399220a7 100644 --- a/net/dcb/dcbnl.c +++ b/net/dcb/dcbnl.c | |||
@@ -54,7 +54,7 @@ MODULE_LICENSE("GPL"); | |||
54 | /**************** DCB attribute policies *************************************/ | 54 | /**************** DCB attribute policies *************************************/ |
55 | 55 | ||
56 | /* DCB netlink attributes policy */ | 56 | /* DCB netlink attributes policy */ |
57 | static struct nla_policy dcbnl_rtnl_policy[DCB_ATTR_MAX + 1] = { | 57 | static const struct nla_policy dcbnl_rtnl_policy[DCB_ATTR_MAX + 1] = { |
58 | [DCB_ATTR_IFNAME] = {.type = NLA_NUL_STRING, .len = IFNAMSIZ - 1}, | 58 | [DCB_ATTR_IFNAME] = {.type = NLA_NUL_STRING, .len = IFNAMSIZ - 1}, |
59 | [DCB_ATTR_STATE] = {.type = NLA_U8}, | 59 | [DCB_ATTR_STATE] = {.type = NLA_U8}, |
60 | [DCB_ATTR_PFC_CFG] = {.type = NLA_NESTED}, | 60 | [DCB_ATTR_PFC_CFG] = {.type = NLA_NESTED}, |
@@ -68,7 +68,7 @@ static struct nla_policy dcbnl_rtnl_policy[DCB_ATTR_MAX + 1] = { | |||
68 | }; | 68 | }; |
69 | 69 | ||
70 | /* DCB priority flow control to User Priority nested attributes */ | 70 | /* DCB priority flow control to User Priority nested attributes */ |
71 | static struct nla_policy dcbnl_pfc_up_nest[DCB_PFC_UP_ATTR_MAX + 1] = { | 71 | static const struct nla_policy dcbnl_pfc_up_nest[DCB_PFC_UP_ATTR_MAX + 1] = { |
72 | [DCB_PFC_UP_ATTR_0] = {.type = NLA_U8}, | 72 | [DCB_PFC_UP_ATTR_0] = {.type = NLA_U8}, |
73 | [DCB_PFC_UP_ATTR_1] = {.type = NLA_U8}, | 73 | [DCB_PFC_UP_ATTR_1] = {.type = NLA_U8}, |
74 | [DCB_PFC_UP_ATTR_2] = {.type = NLA_U8}, | 74 | [DCB_PFC_UP_ATTR_2] = {.type = NLA_U8}, |
@@ -81,7 +81,7 @@ static struct nla_policy dcbnl_pfc_up_nest[DCB_PFC_UP_ATTR_MAX + 1] = { | |||
81 | }; | 81 | }; |
82 | 82 | ||
83 | /* DCB priority grouping nested attributes */ | 83 | /* DCB priority grouping nested attributes */ |
84 | static struct nla_policy dcbnl_pg_nest[DCB_PG_ATTR_MAX + 1] = { | 84 | static const struct nla_policy dcbnl_pg_nest[DCB_PG_ATTR_MAX + 1] = { |
85 | [DCB_PG_ATTR_TC_0] = {.type = NLA_NESTED}, | 85 | [DCB_PG_ATTR_TC_0] = {.type = NLA_NESTED}, |
86 | [DCB_PG_ATTR_TC_1] = {.type = NLA_NESTED}, | 86 | [DCB_PG_ATTR_TC_1] = {.type = NLA_NESTED}, |
87 | [DCB_PG_ATTR_TC_2] = {.type = NLA_NESTED}, | 87 | [DCB_PG_ATTR_TC_2] = {.type = NLA_NESTED}, |
@@ -103,7 +103,7 @@ static struct nla_policy dcbnl_pg_nest[DCB_PG_ATTR_MAX + 1] = { | |||
103 | }; | 103 | }; |
104 | 104 | ||
105 | /* DCB traffic class nested attributes. */ | 105 | /* DCB traffic class nested attributes. */ |
106 | static struct nla_policy dcbnl_tc_param_nest[DCB_TC_ATTR_PARAM_MAX + 1] = { | 106 | static const struct nla_policy dcbnl_tc_param_nest[DCB_TC_ATTR_PARAM_MAX + 1] = { |
107 | [DCB_TC_ATTR_PARAM_PGID] = {.type = NLA_U8}, | 107 | [DCB_TC_ATTR_PARAM_PGID] = {.type = NLA_U8}, |
108 | [DCB_TC_ATTR_PARAM_UP_MAPPING] = {.type = NLA_U8}, | 108 | [DCB_TC_ATTR_PARAM_UP_MAPPING] = {.type = NLA_U8}, |
109 | [DCB_TC_ATTR_PARAM_STRICT_PRIO] = {.type = NLA_U8}, | 109 | [DCB_TC_ATTR_PARAM_STRICT_PRIO] = {.type = NLA_U8}, |
@@ -112,7 +112,7 @@ static struct nla_policy dcbnl_tc_param_nest[DCB_TC_ATTR_PARAM_MAX + 1] = { | |||
112 | }; | 112 | }; |
113 | 113 | ||
114 | /* DCB capabilities nested attributes. */ | 114 | /* DCB capabilities nested attributes. */ |
115 | static struct nla_policy dcbnl_cap_nest[DCB_CAP_ATTR_MAX + 1] = { | 115 | static const struct nla_policy dcbnl_cap_nest[DCB_CAP_ATTR_MAX + 1] = { |
116 | [DCB_CAP_ATTR_ALL] = {.type = NLA_FLAG}, | 116 | [DCB_CAP_ATTR_ALL] = {.type = NLA_FLAG}, |
117 | [DCB_CAP_ATTR_PG] = {.type = NLA_U8}, | 117 | [DCB_CAP_ATTR_PG] = {.type = NLA_U8}, |
118 | [DCB_CAP_ATTR_PFC] = {.type = NLA_U8}, | 118 | [DCB_CAP_ATTR_PFC] = {.type = NLA_U8}, |
@@ -124,14 +124,14 @@ static struct nla_policy dcbnl_cap_nest[DCB_CAP_ATTR_MAX + 1] = { | |||
124 | }; | 124 | }; |
125 | 125 | ||
126 | /* DCB capabilities nested attributes. */ | 126 | /* DCB capabilities nested attributes. */ |
127 | static struct nla_policy dcbnl_numtcs_nest[DCB_NUMTCS_ATTR_MAX + 1] = { | 127 | static const struct nla_policy dcbnl_numtcs_nest[DCB_NUMTCS_ATTR_MAX + 1] = { |
128 | [DCB_NUMTCS_ATTR_ALL] = {.type = NLA_FLAG}, | 128 | [DCB_NUMTCS_ATTR_ALL] = {.type = NLA_FLAG}, |
129 | [DCB_NUMTCS_ATTR_PG] = {.type = NLA_U8}, | 129 | [DCB_NUMTCS_ATTR_PG] = {.type = NLA_U8}, |
130 | [DCB_NUMTCS_ATTR_PFC] = {.type = NLA_U8}, | 130 | [DCB_NUMTCS_ATTR_PFC] = {.type = NLA_U8}, |
131 | }; | 131 | }; |
132 | 132 | ||
133 | /* DCB BCN nested attributes. */ | 133 | /* DCB BCN nested attributes. */ |
134 | static struct nla_policy dcbnl_bcn_nest[DCB_BCN_ATTR_MAX + 1] = { | 134 | static const struct nla_policy dcbnl_bcn_nest[DCB_BCN_ATTR_MAX + 1] = { |
135 | [DCB_BCN_ATTR_RP_0] = {.type = NLA_U8}, | 135 | [DCB_BCN_ATTR_RP_0] = {.type = NLA_U8}, |
136 | [DCB_BCN_ATTR_RP_1] = {.type = NLA_U8}, | 136 | [DCB_BCN_ATTR_RP_1] = {.type = NLA_U8}, |
137 | [DCB_BCN_ATTR_RP_2] = {.type = NLA_U8}, | 137 | [DCB_BCN_ATTR_RP_2] = {.type = NLA_U8}, |
@@ -160,7 +160,7 @@ static struct nla_policy dcbnl_bcn_nest[DCB_BCN_ATTR_MAX + 1] = { | |||
160 | }; | 160 | }; |
161 | 161 | ||
162 | /* DCB APP nested attributes. */ | 162 | /* DCB APP nested attributes. */ |
163 | static struct nla_policy dcbnl_app_nest[DCB_APP_ATTR_MAX + 1] = { | 163 | static const struct nla_policy dcbnl_app_nest[DCB_APP_ATTR_MAX + 1] = { |
164 | [DCB_APP_ATTR_IDTYPE] = {.type = NLA_U8}, | 164 | [DCB_APP_ATTR_IDTYPE] = {.type = NLA_U8}, |
165 | [DCB_APP_ATTR_ID] = {.type = NLA_U16}, | 165 | [DCB_APP_ATTR_ID] = {.type = NLA_U16}, |
166 | [DCB_APP_ATTR_PRIORITY] = {.type = NLA_U8}, | 166 | [DCB_APP_ATTR_PRIORITY] = {.type = NLA_U8}, |
diff --git a/net/irda/irnetlink.c b/net/irda/irnetlink.c index 476b307bd801..69b5b75f5431 100644 --- a/net/irda/irnetlink.c +++ b/net/irda/irnetlink.c | |||
@@ -124,7 +124,7 @@ static int irda_nl_get_mode(struct sk_buff *skb, struct genl_info *info) | |||
124 | return ret; | 124 | return ret; |
125 | } | 125 | } |
126 | 126 | ||
127 | static struct nla_policy irda_nl_policy[IRDA_NL_ATTR_MAX + 1] = { | 127 | static const struct nla_policy irda_nl_policy[IRDA_NL_ATTR_MAX + 1] = { |
128 | [IRDA_NL_ATTR_IFNAME] = { .type = NLA_NUL_STRING, | 128 | [IRDA_NL_ATTR_IFNAME] = { .type = NLA_NUL_STRING, |
129 | .len = IFNAMSIZ-1 }, | 129 | .len = IFNAMSIZ-1 }, |
130 | [IRDA_NL_ATTR_MODE] = { .type = NLA_U32 }, | 130 | [IRDA_NL_ATTR_MODE] = { .type = NLA_U32 }, |
diff --git a/net/wimax/op-msg.c b/net/wimax/op-msg.c index d3bfb6ef13ae..7718657e93dc 100644 --- a/net/wimax/op-msg.c +++ b/net/wimax/op-msg.c | |||
@@ -320,8 +320,7 @@ int wimax_msg(struct wimax_dev *wimax_dev, const char *pipe_name, | |||
320 | EXPORT_SYMBOL_GPL(wimax_msg); | 320 | EXPORT_SYMBOL_GPL(wimax_msg); |
321 | 321 | ||
322 | 322 | ||
323 | static const | 323 | static const struct nla_policy wimax_gnl_msg_policy[WIMAX_GNL_ATTR_MAX + 1] = { |
324 | struct nla_policy wimax_gnl_msg_policy[WIMAX_GNL_ATTR_MAX + 1] = { | ||
325 | [WIMAX_GNL_MSG_IFIDX] = { | 324 | [WIMAX_GNL_MSG_IFIDX] = { |
326 | .type = NLA_U32, | 325 | .type = NLA_U32, |
327 | }, | 326 | }, |
diff --git a/net/wimax/op-reset.c b/net/wimax/op-reset.c index 35f370091f4f..4dc82a54ba30 100644 --- a/net/wimax/op-reset.c +++ b/net/wimax/op-reset.c | |||
@@ -91,8 +91,7 @@ int wimax_reset(struct wimax_dev *wimax_dev) | |||
91 | EXPORT_SYMBOL(wimax_reset); | 91 | EXPORT_SYMBOL(wimax_reset); |
92 | 92 | ||
93 | 93 | ||
94 | static const | 94 | static const struct nla_policy wimax_gnl_reset_policy[WIMAX_GNL_ATTR_MAX + 1] = { |
95 | struct nla_policy wimax_gnl_reset_policy[WIMAX_GNL_ATTR_MAX + 1] = { | ||
96 | [WIMAX_GNL_RESET_IFIDX] = { | 95 | [WIMAX_GNL_RESET_IFIDX] = { |
97 | .type = NLA_U32, | 96 | .type = NLA_U32, |
98 | }, | 97 | }, |
diff --git a/net/wimax/op-rfkill.c b/net/wimax/op-rfkill.c index ae752a64d920..e978c7136c97 100644 --- a/net/wimax/op-rfkill.c +++ b/net/wimax/op-rfkill.c | |||
@@ -410,8 +410,7 @@ void wimax_rfkill_rm(struct wimax_dev *wimax_dev) | |||
410 | * just query). | 410 | * just query). |
411 | */ | 411 | */ |
412 | 412 | ||
413 | static const | 413 | static const struct nla_policy wimax_gnl_rfkill_policy[WIMAX_GNL_ATTR_MAX + 1] = { |
414 | struct nla_policy wimax_gnl_rfkill_policy[WIMAX_GNL_ATTR_MAX + 1] = { | ||
415 | [WIMAX_GNL_RFKILL_IFIDX] = { | 414 | [WIMAX_GNL_RFKILL_IFIDX] = { |
416 | .type = NLA_U32, | 415 | .type = NLA_U32, |
417 | }, | 416 | }, |
diff --git a/net/wimax/op-state-get.c b/net/wimax/op-state-get.c index a76b8fcb056d..11ad3356eb56 100644 --- a/net/wimax/op-state-get.c +++ b/net/wimax/op-state-get.c | |||
@@ -33,8 +33,7 @@ | |||
33 | #include "debug-levels.h" | 33 | #include "debug-levels.h" |
34 | 34 | ||
35 | 35 | ||
36 | static const | 36 | static const struct nla_policy wimax_gnl_state_get_policy[WIMAX_GNL_ATTR_MAX + 1] = { |
37 | struct nla_policy wimax_gnl_state_get_policy[WIMAX_GNL_ATTR_MAX + 1] = { | ||
38 | [WIMAX_GNL_STGET_IFIDX] = { | 37 | [WIMAX_GNL_STGET_IFIDX] = { |
39 | .type = NLA_U32, | 38 | .type = NLA_U32, |
40 | }, | 39 | }, |
diff --git a/net/wimax/stack.c b/net/wimax/stack.c index c8866412f830..813e1eaea29b 100644 --- a/net/wimax/stack.c +++ b/net/wimax/stack.c | |||
@@ -75,8 +75,7 @@ MODULE_PARM_DESC(debug, | |||
75 | * close to where the data is generated. | 75 | * close to where the data is generated. |
76 | */ | 76 | */ |
77 | /* | 77 | /* |
78 | static const | 78 | static const struct nla_policy wimax_gnl_re_status_change[WIMAX_GNL_ATTR_MAX + 1] = { |
79 | struct nla_policy wimax_gnl_re_status_change[WIMAX_GNL_ATTR_MAX + 1] = { | ||
80 | [WIMAX_GNL_STCH_STATE_OLD] = { .type = NLA_U8 }, | 79 | [WIMAX_GNL_STCH_STATE_OLD] = { .type = NLA_U8 }, |
81 | [WIMAX_GNL_STCH_STATE_NEW] = { .type = NLA_U8 }, | 80 | [WIMAX_GNL_STCH_STATE_NEW] = { .type = NLA_U8 }, |
82 | }; | 81 | }; |
diff --git a/net/wireless/nl80211.c b/net/wireless/nl80211.c index 5b79ecf17bea..a001ea32cb7d 100644 --- a/net/wireless/nl80211.c +++ b/net/wireless/nl80211.c | |||
@@ -58,7 +58,7 @@ static int get_rdev_dev_by_info_ifindex(struct genl_info *info, | |||
58 | } | 58 | } |
59 | 59 | ||
60 | /* policy for the attributes */ | 60 | /* policy for the attributes */ |
61 | static struct nla_policy nl80211_policy[NL80211_ATTR_MAX+1] __read_mostly = { | 61 | static const struct nla_policy nl80211_policy[NL80211_ATTR_MAX+1] = { |
62 | [NL80211_ATTR_WIPHY] = { .type = NLA_U32 }, | 62 | [NL80211_ATTR_WIPHY] = { .type = NLA_U32 }, |
63 | [NL80211_ATTR_WIPHY_NAME] = { .type = NLA_NUL_STRING, | 63 | [NL80211_ATTR_WIPHY_NAME] = { .type = NLA_NUL_STRING, |
64 | .len = 20-1 }, | 64 | .len = 20-1 }, |
@@ -148,8 +148,7 @@ static struct nla_policy nl80211_policy[NL80211_ATTR_MAX+1] __read_mostly = { | |||
148 | }; | 148 | }; |
149 | 149 | ||
150 | /* policy for the attributes */ | 150 | /* policy for the attributes */ |
151 | static struct nla_policy | 151 | static const struct nla_policy nl80211_key_policy[NL80211_KEY_MAX + 1] = { |
152 | nl80211_key_policy[NL80211_KEY_MAX + 1] __read_mostly = { | ||
153 | [NL80211_KEY_DATA] = { .type = NLA_BINARY, .len = WLAN_MAX_KEY_LEN }, | 152 | [NL80211_KEY_DATA] = { .type = NLA_BINARY, .len = WLAN_MAX_KEY_LEN }, |
154 | [NL80211_KEY_IDX] = { .type = NLA_U8 }, | 153 | [NL80211_KEY_IDX] = { .type = NLA_U8 }, |
155 | [NL80211_KEY_CIPHER] = { .type = NLA_U32 }, | 154 | [NL80211_KEY_CIPHER] = { .type = NLA_U32 }, |
@@ -2501,8 +2500,7 @@ static int nl80211_set_bss(struct sk_buff *skb, struct genl_info *info) | |||
2501 | return err; | 2500 | return err; |
2502 | } | 2501 | } |
2503 | 2502 | ||
2504 | static const struct nla_policy | 2503 | static const struct nla_policy reg_rule_policy[NL80211_REG_RULE_ATTR_MAX + 1] = { |
2505 | reg_rule_policy[NL80211_REG_RULE_ATTR_MAX + 1] = { | ||
2506 | [NL80211_ATTR_REG_RULE_FLAGS] = { .type = NLA_U32 }, | 2504 | [NL80211_ATTR_REG_RULE_FLAGS] = { .type = NLA_U32 }, |
2507 | [NL80211_ATTR_FREQ_RANGE_START] = { .type = NLA_U32 }, | 2505 | [NL80211_ATTR_FREQ_RANGE_START] = { .type = NLA_U32 }, |
2508 | [NL80211_ATTR_FREQ_RANGE_END] = { .type = NLA_U32 }, | 2506 | [NL80211_ATTR_FREQ_RANGE_END] = { .type = NLA_U32 }, |
@@ -2671,8 +2669,7 @@ do {\ | |||
2671 | } \ | 2669 | } \ |
2672 | } while (0);\ | 2670 | } while (0);\ |
2673 | 2671 | ||
2674 | static struct nla_policy | 2672 | static const struct nla_policy nl80211_meshconf_params_policy[NL80211_MESHCONF_ATTR_MAX+1] = { |
2675 | nl80211_meshconf_params_policy[NL80211_MESHCONF_ATTR_MAX+1] __read_mostly = { | ||
2676 | [NL80211_MESHCONF_RETRY_TIMEOUT] = { .type = NLA_U16 }, | 2673 | [NL80211_MESHCONF_RETRY_TIMEOUT] = { .type = NLA_U16 }, |
2677 | [NL80211_MESHCONF_CONFIRM_TIMEOUT] = { .type = NLA_U16 }, | 2674 | [NL80211_MESHCONF_CONFIRM_TIMEOUT] = { .type = NLA_U16 }, |
2678 | [NL80211_MESHCONF_HOLDING_TIMEOUT] = { .type = NLA_U16 }, | 2675 | [NL80211_MESHCONF_HOLDING_TIMEOUT] = { .type = NLA_U16 }, |
@@ -4470,8 +4467,7 @@ static u32 rateset_to_mask(struct ieee80211_supported_band *sband, | |||
4470 | return mask; | 4467 | return mask; |
4471 | } | 4468 | } |
4472 | 4469 | ||
4473 | static struct nla_policy | 4470 | static const struct nla_policy nl80211_txattr_policy[NL80211_TXRATE_MAX + 1] = { |
4474 | nl80211_txattr_policy[NL80211_TXRATE_MAX + 1] __read_mostly = { | ||
4475 | [NL80211_TXRATE_LEGACY] = { .type = NLA_BINARY, | 4471 | [NL80211_TXRATE_LEGACY] = { .type = NLA_BINARY, |
4476 | .len = NL80211_MAX_SUPP_RATES }, | 4472 | .len = NL80211_MAX_SUPP_RATES }, |
4477 | }; | 4473 | }; |