diff options
author | Johan Hedberg <johan.hedberg@intel.com> | 2012-03-01 15:23:42 -0500 |
---|---|---|
committer | Johan Hedberg <johan.hedberg@intel.com> | 2012-03-01 16:55:58 -0500 |
commit | 9d1acbfb774fa5e043a44adedfcc36c9837a5e61 (patch) | |
tree | 81e551faeed6a542e31c2310353921fae379de31 | |
parent | 0f4e68cf6e70fc219f219799c799a8a3e3c13100 (diff) |
Bluetooth: mgmt: Add defines for command sizes
These defines are shorter than "sizeof(struct mgmt_cp_foo_bar...)" and
will be helpful when extending the command lookup table to contain the
expected command size information.
Signed-off-by: Johan Hedberg <johan.hedberg@intel.com>
Acked-by: Marcel Holtmann <marcel@holtmann.org>
-rw-r--r-- | include/net/bluetooth/mgmt.h | 34 |
1 files changed, 34 insertions, 0 deletions
diff --git a/include/net/bluetooth/mgmt.h b/include/net/bluetooth/mgmt.h index 7aab53e6b813..d33457d657c3 100644 --- a/include/net/bluetooth/mgmt.h +++ b/include/net/bluetooth/mgmt.h | |||
@@ -52,14 +52,17 @@ struct mgmt_addr_info { | |||
52 | bdaddr_t bdaddr; | 52 | bdaddr_t bdaddr; |
53 | __u8 type; | 53 | __u8 type; |
54 | } __packed; | 54 | } __packed; |
55 | #define MGMT_ADDR_INFO_SIZE 7 | ||
55 | 56 | ||
56 | #define MGMT_OP_READ_VERSION 0x0001 | 57 | #define MGMT_OP_READ_VERSION 0x0001 |
58 | #define MGMT_READ_VERSION_SIZE 0 | ||
57 | struct mgmt_rp_read_version { | 59 | struct mgmt_rp_read_version { |
58 | __u8 version; | 60 | __u8 version; |
59 | __le16 revision; | 61 | __le16 revision; |
60 | } __packed; | 62 | } __packed; |
61 | 63 | ||
62 | #define MGMT_OP_READ_COMMANDS 0x0002 | 64 | #define MGMT_OP_READ_COMMANDS 0x0002 |
65 | #define MGMT_READ_COMMANDS_SIZE 0 | ||
63 | struct mgmt_rp_read_commands { | 66 | struct mgmt_rp_read_commands { |
64 | __le16 num_commands; | 67 | __le16 num_commands; |
65 | __le16 num_events; | 68 | __le16 num_events; |
@@ -67,6 +70,7 @@ struct mgmt_rp_read_commands { | |||
67 | } __packed; | 70 | } __packed; |
68 | 71 | ||
69 | #define MGMT_OP_READ_INDEX_LIST 0x0003 | 72 | #define MGMT_OP_READ_INDEX_LIST 0x0003 |
73 | #define MGMT_READ_INDEX_LIST_SIZE 0 | ||
70 | struct mgmt_rp_read_index_list { | 74 | struct mgmt_rp_read_index_list { |
71 | __le16 num_controllers; | 75 | __le16 num_controllers; |
72 | __le16 index[0]; | 76 | __le16 index[0]; |
@@ -89,6 +93,7 @@ struct mgmt_rp_read_index_list { | |||
89 | #define MGMT_SETTING_LE 0x00000200 | 93 | #define MGMT_SETTING_LE 0x00000200 |
90 | 94 | ||
91 | #define MGMT_OP_READ_INFO 0x0004 | 95 | #define MGMT_OP_READ_INFO 0x0004 |
96 | #define MGMT_READ_INFO_SIZE 0 | ||
92 | struct mgmt_rp_read_info { | 97 | struct mgmt_rp_read_info { |
93 | bdaddr_t bdaddr; | 98 | bdaddr_t bdaddr; |
94 | __u8 version; | 99 | __u8 version; |
@@ -104,6 +109,8 @@ struct mgmt_mode { | |||
104 | __u8 val; | 109 | __u8 val; |
105 | } __packed; | 110 | } __packed; |
106 | 111 | ||
112 | #define MGMT_SETTING_SIZE 1 | ||
113 | |||
107 | #define MGMT_OP_SET_POWERED 0x0005 | 114 | #define MGMT_OP_SET_POWERED 0x0005 |
108 | 115 | ||
109 | #define MGMT_OP_SET_DISCOVERABLE 0x0006 | 116 | #define MGMT_OP_SET_DISCOVERABLE 0x0006 |
@@ -111,6 +118,7 @@ struct mgmt_cp_set_discoverable { | |||
111 | __u8 val; | 118 | __u8 val; |
112 | __u16 timeout; | 119 | __u16 timeout; |
113 | } __packed; | 120 | } __packed; |
121 | #define MGMT_SET_DISCOVERABLE_SIZE 3 | ||
114 | 122 | ||
115 | #define MGMT_OP_SET_CONNECTABLE 0x0007 | 123 | #define MGMT_OP_SET_CONNECTABLE 0x0007 |
116 | 124 | ||
@@ -131,23 +139,27 @@ struct mgmt_cp_set_dev_class { | |||
131 | __u8 major; | 139 | __u8 major; |
132 | __u8 minor; | 140 | __u8 minor; |
133 | } __packed; | 141 | } __packed; |
142 | #define MGMT_SET_DEV_CLASS_SIZE 2 | ||
134 | 143 | ||
135 | #define MGMT_OP_SET_LOCAL_NAME 0x000F | 144 | #define MGMT_OP_SET_LOCAL_NAME 0x000F |
136 | struct mgmt_cp_set_local_name { | 145 | struct mgmt_cp_set_local_name { |
137 | __u8 name[MGMT_MAX_NAME_LENGTH]; | 146 | __u8 name[MGMT_MAX_NAME_LENGTH]; |
138 | __u8 short_name[MGMT_MAX_SHORT_NAME_LENGTH]; | 147 | __u8 short_name[MGMT_MAX_SHORT_NAME_LENGTH]; |
139 | } __packed; | 148 | } __packed; |
149 | #define MGMT_SET_LOCAL_NAME_SIZE 260 | ||
140 | 150 | ||
141 | #define MGMT_OP_ADD_UUID 0x0010 | 151 | #define MGMT_OP_ADD_UUID 0x0010 |
142 | struct mgmt_cp_add_uuid { | 152 | struct mgmt_cp_add_uuid { |
143 | __u8 uuid[16]; | 153 | __u8 uuid[16]; |
144 | __u8 svc_hint; | 154 | __u8 svc_hint; |
145 | } __packed; | 155 | } __packed; |
156 | #define MGMT_ADD_UUID_SIZE 17 | ||
146 | 157 | ||
147 | #define MGMT_OP_REMOVE_UUID 0x0011 | 158 | #define MGMT_OP_REMOVE_UUID 0x0011 |
148 | struct mgmt_cp_remove_uuid { | 159 | struct mgmt_cp_remove_uuid { |
149 | __u8 uuid[16]; | 160 | __u8 uuid[16]; |
150 | } __packed; | 161 | } __packed; |
162 | #define MGMT_REMOVE_UUID_SIZE 16 | ||
151 | 163 | ||
152 | struct mgmt_link_key_info { | 164 | struct mgmt_link_key_info { |
153 | struct mgmt_addr_info addr; | 165 | struct mgmt_addr_info addr; |
@@ -162,6 +174,7 @@ struct mgmt_cp_load_link_keys { | |||
162 | __le16 key_count; | 174 | __le16 key_count; |
163 | struct mgmt_link_key_info keys[0]; | 175 | struct mgmt_link_key_info keys[0]; |
164 | } __packed; | 176 | } __packed; |
177 | #define MGMT_LOAD_LINK_KEYS_SIZE 3 | ||
165 | 178 | ||
166 | struct mgmt_ltk_info { | 179 | struct mgmt_ltk_info { |
167 | struct mgmt_addr_info addr; | 180 | struct mgmt_addr_info addr; |
@@ -178,16 +191,19 @@ struct mgmt_cp_load_long_term_keys { | |||
178 | __le16 key_count; | 191 | __le16 key_count; |
179 | struct mgmt_ltk_info keys[0]; | 192 | struct mgmt_ltk_info keys[0]; |
180 | } __packed; | 193 | } __packed; |
194 | #define MGMT_LOAD_LONG_TERM_KEYS_SIZE 2 | ||
181 | 195 | ||
182 | #define MGMT_OP_DISCONNECT 0x0014 | 196 | #define MGMT_OP_DISCONNECT 0x0014 |
183 | struct mgmt_cp_disconnect { | 197 | struct mgmt_cp_disconnect { |
184 | struct mgmt_addr_info addr; | 198 | struct mgmt_addr_info addr; |
185 | } __packed; | 199 | } __packed; |
200 | #define MGMT_DISCONNECT_SIZE MGMT_ADDR_INFO_SIZE | ||
186 | struct mgmt_rp_disconnect { | 201 | struct mgmt_rp_disconnect { |
187 | struct mgmt_addr_info addr; | 202 | struct mgmt_addr_info addr; |
188 | } __packed; | 203 | } __packed; |
189 | 204 | ||
190 | #define MGMT_OP_GET_CONNECTIONS 0x0015 | 205 | #define MGMT_OP_GET_CONNECTIONS 0x0015 |
206 | #define MGMT_GET_CONNECTIONS_SIZE 0 | ||
191 | struct mgmt_rp_get_connections { | 207 | struct mgmt_rp_get_connections { |
192 | __le16 conn_count; | 208 | __le16 conn_count; |
193 | struct mgmt_addr_info addr[0]; | 209 | struct mgmt_addr_info addr[0]; |
@@ -199,6 +215,7 @@ struct mgmt_cp_pin_code_reply { | |||
199 | __u8 pin_len; | 215 | __u8 pin_len; |
200 | __u8 pin_code[16]; | 216 | __u8 pin_code[16]; |
201 | } __packed; | 217 | } __packed; |
218 | #define MGMT_PIN_CODE_REPLY_SIZE (MGMT_ADDR_INFO_SIZE + 17) | ||
202 | struct mgmt_rp_pin_code_reply { | 219 | struct mgmt_rp_pin_code_reply { |
203 | struct mgmt_addr_info addr; | 220 | struct mgmt_addr_info addr; |
204 | } __packed; | 221 | } __packed; |
@@ -207,28 +224,33 @@ struct mgmt_rp_pin_code_reply { | |||
207 | struct mgmt_cp_pin_code_neg_reply { | 224 | struct mgmt_cp_pin_code_neg_reply { |
208 | struct mgmt_addr_info addr; | 225 | struct mgmt_addr_info addr; |
209 | } __packed; | 226 | } __packed; |
227 | #define MGMT_PIN_CODE_NEG_REPLY_SIZE MGMT_ADDR_INFO_SIZE | ||
210 | 228 | ||
211 | #define MGMT_OP_SET_IO_CAPABILITY 0x0018 | 229 | #define MGMT_OP_SET_IO_CAPABILITY 0x0018 |
212 | struct mgmt_cp_set_io_capability { | 230 | struct mgmt_cp_set_io_capability { |
213 | __u8 io_capability; | 231 | __u8 io_capability; |
214 | } __packed; | 232 | } __packed; |
233 | #define MGMT_SET_IO_CAPABILITY_SIZE 1 | ||
215 | 234 | ||
216 | #define MGMT_OP_PAIR_DEVICE 0x0019 | 235 | #define MGMT_OP_PAIR_DEVICE 0x0019 |
217 | struct mgmt_cp_pair_device { | 236 | struct mgmt_cp_pair_device { |
218 | struct mgmt_addr_info addr; | 237 | struct mgmt_addr_info addr; |
219 | __u8 io_cap; | 238 | __u8 io_cap; |
220 | } __packed; | 239 | } __packed; |
240 | #define MGMT_PAIR_DEVICE_SIZE (MGMT_ADDR_INFO_SIZE + 1) | ||
221 | struct mgmt_rp_pair_device { | 241 | struct mgmt_rp_pair_device { |
222 | struct mgmt_addr_info addr; | 242 | struct mgmt_addr_info addr; |
223 | } __packed; | 243 | } __packed; |
224 | 244 | ||
225 | #define MGMT_OP_CANCEL_PAIR_DEVICE 0x001A | 245 | #define MGMT_OP_CANCEL_PAIR_DEVICE 0x001A |
246 | #define MGMT_CANCEL_PAIR_DEVICE_SIZE MGMT_ADDR_INFO_SIZE | ||
226 | 247 | ||
227 | #define MGMT_OP_UNPAIR_DEVICE 0x001B | 248 | #define MGMT_OP_UNPAIR_DEVICE 0x001B |
228 | struct mgmt_cp_unpair_device { | 249 | struct mgmt_cp_unpair_device { |
229 | struct mgmt_addr_info addr; | 250 | struct mgmt_addr_info addr; |
230 | __u8 disconnect; | 251 | __u8 disconnect; |
231 | } __packed; | 252 | } __packed; |
253 | #define MGMT_UNPAIR_DEVICE_SIZE (MGMT_ADDR_INFO_SIZE + 1) | ||
232 | struct mgmt_rp_unpair_device { | 254 | struct mgmt_rp_unpair_device { |
233 | struct mgmt_addr_info addr; | 255 | struct mgmt_addr_info addr; |
234 | }; | 256 | }; |
@@ -237,6 +259,7 @@ struct mgmt_rp_unpair_device { | |||
237 | struct mgmt_cp_user_confirm_reply { | 259 | struct mgmt_cp_user_confirm_reply { |
238 | struct mgmt_addr_info addr; | 260 | struct mgmt_addr_info addr; |
239 | } __packed; | 261 | } __packed; |
262 | #define MGMT_USER_CONFIRM_REPLY_SIZE MGMT_ADDR_INFO_SIZE | ||
240 | struct mgmt_rp_user_confirm_reply { | 263 | struct mgmt_rp_user_confirm_reply { |
241 | struct mgmt_addr_info addr; | 264 | struct mgmt_addr_info addr; |
242 | } __packed; | 265 | } __packed; |
@@ -245,12 +268,14 @@ struct mgmt_rp_user_confirm_reply { | |||
245 | struct mgmt_cp_user_confirm_neg_reply { | 268 | struct mgmt_cp_user_confirm_neg_reply { |
246 | struct mgmt_addr_info addr; | 269 | struct mgmt_addr_info addr; |
247 | } __packed; | 270 | } __packed; |
271 | #define MGMT_USER_CONFIRM_NEG_REPLY_SIZE MGMT_ADDR_INFO_SIZE | ||
248 | 272 | ||
249 | #define MGMT_OP_USER_PASSKEY_REPLY 0x001E | 273 | #define MGMT_OP_USER_PASSKEY_REPLY 0x001E |
250 | struct mgmt_cp_user_passkey_reply { | 274 | struct mgmt_cp_user_passkey_reply { |
251 | struct mgmt_addr_info addr; | 275 | struct mgmt_addr_info addr; |
252 | __le32 passkey; | 276 | __le32 passkey; |
253 | } __packed; | 277 | } __packed; |
278 | #define MGMT_USER_PASSKEY_REPLY_SIZE (MGMT_ADDR_INFO_SIZE + 4) | ||
254 | struct mgmt_rp_user_passkey_reply { | 279 | struct mgmt_rp_user_passkey_reply { |
255 | struct mgmt_addr_info addr; | 280 | struct mgmt_addr_info addr; |
256 | } __packed; | 281 | } __packed; |
@@ -259,8 +284,10 @@ struct mgmt_rp_user_passkey_reply { | |||
259 | struct mgmt_cp_user_passkey_neg_reply { | 284 | struct mgmt_cp_user_passkey_neg_reply { |
260 | struct mgmt_addr_info addr; | 285 | struct mgmt_addr_info addr; |
261 | } __packed; | 286 | } __packed; |
287 | #define MGMT_USER_PASSKEY_NEG_REPLY_SIZE MGMT_ADDR_INFO_SIZE | ||
262 | 288 | ||
263 | #define MGMT_OP_READ_LOCAL_OOB_DATA 0x0020 | 289 | #define MGMT_OP_READ_LOCAL_OOB_DATA 0x0020 |
290 | #define MGMT_READ_LOCAL_OOB_DATA_SIZE 0 | ||
264 | struct mgmt_rp_read_local_oob_data { | 291 | struct mgmt_rp_read_local_oob_data { |
265 | __u8 hash[16]; | 292 | __u8 hash[16]; |
266 | __u8 randomizer[16]; | 293 | __u8 randomizer[16]; |
@@ -272,27 +299,32 @@ struct mgmt_cp_add_remote_oob_data { | |||
272 | __u8 hash[16]; | 299 | __u8 hash[16]; |
273 | __u8 randomizer[16]; | 300 | __u8 randomizer[16]; |
274 | } __packed; | 301 | } __packed; |
302 | #define MGMT_ADD_REMOTE_OOB_DATA_SIZE (MGMT_ADDR_INFO_SIZE + 32) | ||
275 | 303 | ||
276 | #define MGMT_OP_REMOVE_REMOTE_OOB_DATA 0x0022 | 304 | #define MGMT_OP_REMOVE_REMOTE_OOB_DATA 0x0022 |
277 | struct mgmt_cp_remove_remote_oob_data { | 305 | struct mgmt_cp_remove_remote_oob_data { |
278 | struct mgmt_addr_info addr; | 306 | struct mgmt_addr_info addr; |
279 | } __packed; | 307 | } __packed; |
308 | #define MGMT_REMOVE_REMOTE_OOB_DATA_SIZE MGMT_ADDR_INFO_SIZE | ||
280 | 309 | ||
281 | #define MGMT_OP_START_DISCOVERY 0x0023 | 310 | #define MGMT_OP_START_DISCOVERY 0x0023 |
282 | struct mgmt_cp_start_discovery { | 311 | struct mgmt_cp_start_discovery { |
283 | __u8 type; | 312 | __u8 type; |
284 | } __packed; | 313 | } __packed; |
314 | #define MGMT_START_DISCOVERY_SIZE 1 | ||
285 | 315 | ||
286 | #define MGMT_OP_STOP_DISCOVERY 0x0024 | 316 | #define MGMT_OP_STOP_DISCOVERY 0x0024 |
287 | struct mgmt_cp_stop_discovery { | 317 | struct mgmt_cp_stop_discovery { |
288 | __u8 type; | 318 | __u8 type; |
289 | } __packed; | 319 | } __packed; |
320 | #define MGMT_STOP_DISCOVERY_SIZE 1 | ||
290 | 321 | ||
291 | #define MGMT_OP_CONFIRM_NAME 0x0025 | 322 | #define MGMT_OP_CONFIRM_NAME 0x0025 |
292 | struct mgmt_cp_confirm_name { | 323 | struct mgmt_cp_confirm_name { |
293 | struct mgmt_addr_info addr; | 324 | struct mgmt_addr_info addr; |
294 | __u8 name_known; | 325 | __u8 name_known; |
295 | } __packed; | 326 | } __packed; |
327 | #define MGMT_CONFIRM_NAME_SIZE (MGMT_ADDR_INFO_SIZE + 1) | ||
296 | struct mgmt_rp_confirm_name { | 328 | struct mgmt_rp_confirm_name { |
297 | struct mgmt_addr_info addr; | 329 | struct mgmt_addr_info addr; |
298 | } __packed; | 330 | } __packed; |
@@ -301,11 +333,13 @@ struct mgmt_rp_confirm_name { | |||
301 | struct mgmt_cp_block_device { | 333 | struct mgmt_cp_block_device { |
302 | struct mgmt_addr_info addr; | 334 | struct mgmt_addr_info addr; |
303 | } __packed; | 335 | } __packed; |
336 | #define MGMT_BLOCK_DEVICE_SIZE MGMT_ADDR_INFO_SIZE | ||
304 | 337 | ||
305 | #define MGMT_OP_UNBLOCK_DEVICE 0x0027 | 338 | #define MGMT_OP_UNBLOCK_DEVICE 0x0027 |
306 | struct mgmt_cp_unblock_device { | 339 | struct mgmt_cp_unblock_device { |
307 | struct mgmt_addr_info addr; | 340 | struct mgmt_addr_info addr; |
308 | } __packed; | 341 | } __packed; |
342 | #define MGMT_UNBLOCK_DEVICE_SIZE MGMT_ADDR_INFO_SIZE | ||
309 | 343 | ||
310 | #define MGMT_EV_CMD_COMPLETE 0x0001 | 344 | #define MGMT_EV_CMD_COMPLETE 0x0001 |
311 | struct mgmt_ev_cmd_complete { | 345 | struct mgmt_ev_cmd_complete { |