diff options
author | Gustavo F. Padovan <padovan@profusion.mobi> | 2010-07-19 01:00:13 -0400 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2010-07-21 13:39:13 -0400 |
commit | 66c853cc21bd387a9a2109dcf3b3d53cc9ee9edf (patch) | |
tree | 7cff1a1c452f0cdd3420523b0f5f966900c2336a /include | |
parent | d1c4a17d58a6dfacb48935aa430aa986559a885f (diff) |
Bluetooth: Use __packed annotation
To make net/ and include/net/ code consistent use __packed instead of
__attribute__ ((packed)). Bluetooth subsystem was one of the last net
subsys still using __attribute__ ((packed)).
Signed-off-by: Gustavo F. Padovan <padovan@profusion.mobi>
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'include')
-rw-r--r-- | include/net/bluetooth/bluetooth.h | 2 | ||||
-rw-r--r-- | include/net/bluetooth/hci.h | 184 | ||||
-rw-r--r-- | include/net/bluetooth/l2cap.h | 26 | ||||
-rw-r--r-- | include/net/bluetooth/rfcomm.h | 14 |
4 files changed, 113 insertions, 113 deletions
diff --git a/include/net/bluetooth/bluetooth.h b/include/net/bluetooth/bluetooth.h index d6b150c679ff..27a902d9b3a9 100644 --- a/include/net/bluetooth/bluetooth.h +++ b/include/net/bluetooth/bluetooth.h | |||
@@ -84,7 +84,7 @@ enum { | |||
84 | /* BD Address */ | 84 | /* BD Address */ |
85 | typedef struct { | 85 | typedef struct { |
86 | __u8 b[6]; | 86 | __u8 b[6]; |
87 | } __attribute__((packed)) bdaddr_t; | 87 | } __packed bdaddr_t; |
88 | 88 | ||
89 | #define BDADDR_ANY (&(bdaddr_t) {{0, 0, 0, 0, 0, 0}}) | 89 | #define BDADDR_ANY (&(bdaddr_t) {{0, 0, 0, 0, 0, 0}}) |
90 | #define BDADDR_LOCAL (&(bdaddr_t) {{0, 0, 0, 0xff, 0xff, 0xff}}) | 90 | #define BDADDR_LOCAL (&(bdaddr_t) {{0, 0, 0, 0xff, 0xff, 0xff}}) |
diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index ca2518e0574e..bcbdd6d4e6dd 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h | |||
@@ -230,7 +230,7 @@ struct hci_cp_inquiry { | |||
230 | __u8 lap[3]; | 230 | __u8 lap[3]; |
231 | __u8 length; | 231 | __u8 length; |
232 | __u8 num_rsp; | 232 | __u8 num_rsp; |
233 | } __attribute__ ((packed)); | 233 | } __packed; |
234 | 234 | ||
235 | #define HCI_OP_INQUIRY_CANCEL 0x0402 | 235 | #define HCI_OP_INQUIRY_CANCEL 0x0402 |
236 | 236 | ||
@@ -244,81 +244,81 @@ struct hci_cp_create_conn { | |||
244 | __u8 pscan_mode; | 244 | __u8 pscan_mode; |
245 | __le16 clock_offset; | 245 | __le16 clock_offset; |
246 | __u8 role_switch; | 246 | __u8 role_switch; |
247 | } __attribute__ ((packed)); | 247 | } __packed; |
248 | 248 | ||
249 | #define HCI_OP_DISCONNECT 0x0406 | 249 | #define HCI_OP_DISCONNECT 0x0406 |
250 | struct hci_cp_disconnect { | 250 | struct hci_cp_disconnect { |
251 | __le16 handle; | 251 | __le16 handle; |
252 | __u8 reason; | 252 | __u8 reason; |
253 | } __attribute__ ((packed)); | 253 | } __packed; |
254 | 254 | ||
255 | #define HCI_OP_ADD_SCO 0x0407 | 255 | #define HCI_OP_ADD_SCO 0x0407 |
256 | struct hci_cp_add_sco { | 256 | struct hci_cp_add_sco { |
257 | __le16 handle; | 257 | __le16 handle; |
258 | __le16 pkt_type; | 258 | __le16 pkt_type; |
259 | } __attribute__ ((packed)); | 259 | } __packed; |
260 | 260 | ||
261 | #define HCI_OP_CREATE_CONN_CANCEL 0x0408 | 261 | #define HCI_OP_CREATE_CONN_CANCEL 0x0408 |
262 | struct hci_cp_create_conn_cancel { | 262 | struct hci_cp_create_conn_cancel { |
263 | bdaddr_t bdaddr; | 263 | bdaddr_t bdaddr; |
264 | } __attribute__ ((packed)); | 264 | } __packed; |
265 | 265 | ||
266 | #define HCI_OP_ACCEPT_CONN_REQ 0x0409 | 266 | #define HCI_OP_ACCEPT_CONN_REQ 0x0409 |
267 | struct hci_cp_accept_conn_req { | 267 | struct hci_cp_accept_conn_req { |
268 | bdaddr_t bdaddr; | 268 | bdaddr_t bdaddr; |
269 | __u8 role; | 269 | __u8 role; |
270 | } __attribute__ ((packed)); | 270 | } __packed; |
271 | 271 | ||
272 | #define HCI_OP_REJECT_CONN_REQ 0x040a | 272 | #define HCI_OP_REJECT_CONN_REQ 0x040a |
273 | struct hci_cp_reject_conn_req { | 273 | struct hci_cp_reject_conn_req { |
274 | bdaddr_t bdaddr; | 274 | bdaddr_t bdaddr; |
275 | __u8 reason; | 275 | __u8 reason; |
276 | } __attribute__ ((packed)); | 276 | } __packed; |
277 | 277 | ||
278 | #define HCI_OP_LINK_KEY_REPLY 0x040b | 278 | #define HCI_OP_LINK_KEY_REPLY 0x040b |
279 | struct hci_cp_link_key_reply { | 279 | struct hci_cp_link_key_reply { |
280 | bdaddr_t bdaddr; | 280 | bdaddr_t bdaddr; |
281 | __u8 link_key[16]; | 281 | __u8 link_key[16]; |
282 | } __attribute__ ((packed)); | 282 | } __packed; |
283 | 283 | ||
284 | #define HCI_OP_LINK_KEY_NEG_REPLY 0x040c | 284 | #define HCI_OP_LINK_KEY_NEG_REPLY 0x040c |
285 | struct hci_cp_link_key_neg_reply { | 285 | struct hci_cp_link_key_neg_reply { |
286 | bdaddr_t bdaddr; | 286 | bdaddr_t bdaddr; |
287 | } __attribute__ ((packed)); | 287 | } __packed; |
288 | 288 | ||
289 | #define HCI_OP_PIN_CODE_REPLY 0x040d | 289 | #define HCI_OP_PIN_CODE_REPLY 0x040d |
290 | struct hci_cp_pin_code_reply { | 290 | struct hci_cp_pin_code_reply { |
291 | bdaddr_t bdaddr; | 291 | bdaddr_t bdaddr; |
292 | __u8 pin_len; | 292 | __u8 pin_len; |
293 | __u8 pin_code[16]; | 293 | __u8 pin_code[16]; |
294 | } __attribute__ ((packed)); | 294 | } __packed; |
295 | 295 | ||
296 | #define HCI_OP_PIN_CODE_NEG_REPLY 0x040e | 296 | #define HCI_OP_PIN_CODE_NEG_REPLY 0x040e |
297 | struct hci_cp_pin_code_neg_reply { | 297 | struct hci_cp_pin_code_neg_reply { |
298 | bdaddr_t bdaddr; | 298 | bdaddr_t bdaddr; |
299 | } __attribute__ ((packed)); | 299 | } __packed; |
300 | 300 | ||
301 | #define HCI_OP_CHANGE_CONN_PTYPE 0x040f | 301 | #define HCI_OP_CHANGE_CONN_PTYPE 0x040f |
302 | struct hci_cp_change_conn_ptype { | 302 | struct hci_cp_change_conn_ptype { |
303 | __le16 handle; | 303 | __le16 handle; |
304 | __le16 pkt_type; | 304 | __le16 pkt_type; |
305 | } __attribute__ ((packed)); | 305 | } __packed; |
306 | 306 | ||
307 | #define HCI_OP_AUTH_REQUESTED 0x0411 | 307 | #define HCI_OP_AUTH_REQUESTED 0x0411 |
308 | struct hci_cp_auth_requested { | 308 | struct hci_cp_auth_requested { |
309 | __le16 handle; | 309 | __le16 handle; |
310 | } __attribute__ ((packed)); | 310 | } __packed; |
311 | 311 | ||
312 | #define HCI_OP_SET_CONN_ENCRYPT 0x0413 | 312 | #define HCI_OP_SET_CONN_ENCRYPT 0x0413 |
313 | struct hci_cp_set_conn_encrypt { | 313 | struct hci_cp_set_conn_encrypt { |
314 | __le16 handle; | 314 | __le16 handle; |
315 | __u8 encrypt; | 315 | __u8 encrypt; |
316 | } __attribute__ ((packed)); | 316 | } __packed; |
317 | 317 | ||
318 | #define HCI_OP_CHANGE_CONN_LINK_KEY 0x0415 | 318 | #define HCI_OP_CHANGE_CONN_LINK_KEY 0x0415 |
319 | struct hci_cp_change_conn_link_key { | 319 | struct hci_cp_change_conn_link_key { |
320 | __le16 handle; | 320 | __le16 handle; |
321 | } __attribute__ ((packed)); | 321 | } __packed; |
322 | 322 | ||
323 | #define HCI_OP_REMOTE_NAME_REQ 0x0419 | 323 | #define HCI_OP_REMOTE_NAME_REQ 0x0419 |
324 | struct hci_cp_remote_name_req { | 324 | struct hci_cp_remote_name_req { |
@@ -326,28 +326,28 @@ struct hci_cp_remote_name_req { | |||
326 | __u8 pscan_rep_mode; | 326 | __u8 pscan_rep_mode; |
327 | __u8 pscan_mode; | 327 | __u8 pscan_mode; |
328 | __le16 clock_offset; | 328 | __le16 clock_offset; |
329 | } __attribute__ ((packed)); | 329 | } __packed; |
330 | 330 | ||
331 | #define HCI_OP_REMOTE_NAME_REQ_CANCEL 0x041a | 331 | #define HCI_OP_REMOTE_NAME_REQ_CANCEL 0x041a |
332 | struct hci_cp_remote_name_req_cancel { | 332 | struct hci_cp_remote_name_req_cancel { |
333 | bdaddr_t bdaddr; | 333 | bdaddr_t bdaddr; |
334 | } __attribute__ ((packed)); | 334 | } __packed; |
335 | 335 | ||
336 | #define HCI_OP_READ_REMOTE_FEATURES 0x041b | 336 | #define HCI_OP_READ_REMOTE_FEATURES 0x041b |
337 | struct hci_cp_read_remote_features { | 337 | struct hci_cp_read_remote_features { |
338 | __le16 handle; | 338 | __le16 handle; |
339 | } __attribute__ ((packed)); | 339 | } __packed; |
340 | 340 | ||
341 | #define HCI_OP_READ_REMOTE_EXT_FEATURES 0x041c | 341 | #define HCI_OP_READ_REMOTE_EXT_FEATURES 0x041c |
342 | struct hci_cp_read_remote_ext_features { | 342 | struct hci_cp_read_remote_ext_features { |
343 | __le16 handle; | 343 | __le16 handle; |
344 | __u8 page; | 344 | __u8 page; |
345 | } __attribute__ ((packed)); | 345 | } __packed; |
346 | 346 | ||
347 | #define HCI_OP_READ_REMOTE_VERSION 0x041d | 347 | #define HCI_OP_READ_REMOTE_VERSION 0x041d |
348 | struct hci_cp_read_remote_version { | 348 | struct hci_cp_read_remote_version { |
349 | __le16 handle; | 349 | __le16 handle; |
350 | } __attribute__ ((packed)); | 350 | } __packed; |
351 | 351 | ||
352 | #define HCI_OP_SETUP_SYNC_CONN 0x0428 | 352 | #define HCI_OP_SETUP_SYNC_CONN 0x0428 |
353 | struct hci_cp_setup_sync_conn { | 353 | struct hci_cp_setup_sync_conn { |
@@ -358,7 +358,7 @@ struct hci_cp_setup_sync_conn { | |||
358 | __le16 voice_setting; | 358 | __le16 voice_setting; |
359 | __u8 retrans_effort; | 359 | __u8 retrans_effort; |
360 | __le16 pkt_type; | 360 | __le16 pkt_type; |
361 | } __attribute__ ((packed)); | 361 | } __packed; |
362 | 362 | ||
363 | #define HCI_OP_ACCEPT_SYNC_CONN_REQ 0x0429 | 363 | #define HCI_OP_ACCEPT_SYNC_CONN_REQ 0x0429 |
364 | struct hci_cp_accept_sync_conn_req { | 364 | struct hci_cp_accept_sync_conn_req { |
@@ -369,13 +369,13 @@ struct hci_cp_accept_sync_conn_req { | |||
369 | __le16 content_format; | 369 | __le16 content_format; |
370 | __u8 retrans_effort; | 370 | __u8 retrans_effort; |
371 | __le16 pkt_type; | 371 | __le16 pkt_type; |
372 | } __attribute__ ((packed)); | 372 | } __packed; |
373 | 373 | ||
374 | #define HCI_OP_REJECT_SYNC_CONN_REQ 0x042a | 374 | #define HCI_OP_REJECT_SYNC_CONN_REQ 0x042a |
375 | struct hci_cp_reject_sync_conn_req { | 375 | struct hci_cp_reject_sync_conn_req { |
376 | bdaddr_t bdaddr; | 376 | bdaddr_t bdaddr; |
377 | __u8 reason; | 377 | __u8 reason; |
378 | } __attribute__ ((packed)); | 378 | } __packed; |
379 | 379 | ||
380 | #define HCI_OP_SNIFF_MODE 0x0803 | 380 | #define HCI_OP_SNIFF_MODE 0x0803 |
381 | struct hci_cp_sniff_mode { | 381 | struct hci_cp_sniff_mode { |
@@ -384,59 +384,59 @@ struct hci_cp_sniff_mode { | |||
384 | __le16 min_interval; | 384 | __le16 min_interval; |
385 | __le16 attempt; | 385 | __le16 attempt; |
386 | __le16 timeout; | 386 | __le16 timeout; |
387 | } __attribute__ ((packed)); | 387 | } __packed; |
388 | 388 | ||
389 | #define HCI_OP_EXIT_SNIFF_MODE 0x0804 | 389 | #define HCI_OP_EXIT_SNIFF_MODE 0x0804 |
390 | struct hci_cp_exit_sniff_mode { | 390 | struct hci_cp_exit_sniff_mode { |
391 | __le16 handle; | 391 | __le16 handle; |
392 | } __attribute__ ((packed)); | 392 | } __packed; |
393 | 393 | ||
394 | #define HCI_OP_ROLE_DISCOVERY 0x0809 | 394 | #define HCI_OP_ROLE_DISCOVERY 0x0809 |
395 | struct hci_cp_role_discovery { | 395 | struct hci_cp_role_discovery { |
396 | __le16 handle; | 396 | __le16 handle; |
397 | } __attribute__ ((packed)); | 397 | } __packed; |
398 | struct hci_rp_role_discovery { | 398 | struct hci_rp_role_discovery { |
399 | __u8 status; | 399 | __u8 status; |
400 | __le16 handle; | 400 | __le16 handle; |
401 | __u8 role; | 401 | __u8 role; |
402 | } __attribute__ ((packed)); | 402 | } __packed; |
403 | 403 | ||
404 | #define HCI_OP_SWITCH_ROLE 0x080b | 404 | #define HCI_OP_SWITCH_ROLE 0x080b |
405 | struct hci_cp_switch_role { | 405 | struct hci_cp_switch_role { |
406 | bdaddr_t bdaddr; | 406 | bdaddr_t bdaddr; |
407 | __u8 role; | 407 | __u8 role; |
408 | } __attribute__ ((packed)); | 408 | } __packed; |
409 | 409 | ||
410 | #define HCI_OP_READ_LINK_POLICY 0x080c | 410 | #define HCI_OP_READ_LINK_POLICY 0x080c |
411 | struct hci_cp_read_link_policy { | 411 | struct hci_cp_read_link_policy { |
412 | __le16 handle; | 412 | __le16 handle; |
413 | } __attribute__ ((packed)); | 413 | } __packed; |
414 | struct hci_rp_read_link_policy { | 414 | struct hci_rp_read_link_policy { |
415 | __u8 status; | 415 | __u8 status; |
416 | __le16 handle; | 416 | __le16 handle; |
417 | __le16 policy; | 417 | __le16 policy; |
418 | } __attribute__ ((packed)); | 418 | } __packed; |
419 | 419 | ||
420 | #define HCI_OP_WRITE_LINK_POLICY 0x080d | 420 | #define HCI_OP_WRITE_LINK_POLICY 0x080d |
421 | struct hci_cp_write_link_policy { | 421 | struct hci_cp_write_link_policy { |
422 | __le16 handle; | 422 | __le16 handle; |
423 | __le16 policy; | 423 | __le16 policy; |
424 | } __attribute__ ((packed)); | 424 | } __packed; |
425 | struct hci_rp_write_link_policy { | 425 | struct hci_rp_write_link_policy { |
426 | __u8 status; | 426 | __u8 status; |
427 | __le16 handle; | 427 | __le16 handle; |
428 | } __attribute__ ((packed)); | 428 | } __packed; |
429 | 429 | ||
430 | #define HCI_OP_READ_DEF_LINK_POLICY 0x080e | 430 | #define HCI_OP_READ_DEF_LINK_POLICY 0x080e |
431 | struct hci_rp_read_def_link_policy { | 431 | struct hci_rp_read_def_link_policy { |
432 | __u8 status; | 432 | __u8 status; |
433 | __le16 policy; | 433 | __le16 policy; |
434 | } __attribute__ ((packed)); | 434 | } __packed; |
435 | 435 | ||
436 | #define HCI_OP_WRITE_DEF_LINK_POLICY 0x080f | 436 | #define HCI_OP_WRITE_DEF_LINK_POLICY 0x080f |
437 | struct hci_cp_write_def_link_policy { | 437 | struct hci_cp_write_def_link_policy { |
438 | __le16 policy; | 438 | __le16 policy; |
439 | } __attribute__ ((packed)); | 439 | } __packed; |
440 | 440 | ||
441 | #define HCI_OP_SNIFF_SUBRATE 0x0811 | 441 | #define HCI_OP_SNIFF_SUBRATE 0x0811 |
442 | struct hci_cp_sniff_subrate { | 442 | struct hci_cp_sniff_subrate { |
@@ -444,12 +444,12 @@ struct hci_cp_sniff_subrate { | |||
444 | __le16 max_latency; | 444 | __le16 max_latency; |
445 | __le16 min_remote_timeout; | 445 | __le16 min_remote_timeout; |
446 | __le16 min_local_timeout; | 446 | __le16 min_local_timeout; |
447 | } __attribute__ ((packed)); | 447 | } __packed; |
448 | 448 | ||
449 | #define HCI_OP_SET_EVENT_MASK 0x0c01 | 449 | #define HCI_OP_SET_EVENT_MASK 0x0c01 |
450 | struct hci_cp_set_event_mask { | 450 | struct hci_cp_set_event_mask { |
451 | __u8 mask[8]; | 451 | __u8 mask[8]; |
452 | } __attribute__ ((packed)); | 452 | } __packed; |
453 | 453 | ||
454 | #define HCI_OP_RESET 0x0c03 | 454 | #define HCI_OP_RESET 0x0c03 |
455 | 455 | ||
@@ -458,7 +458,7 @@ struct hci_cp_set_event_flt { | |||
458 | __u8 flt_type; | 458 | __u8 flt_type; |
459 | __u8 cond_type; | 459 | __u8 cond_type; |
460 | __u8 condition[0]; | 460 | __u8 condition[0]; |
461 | } __attribute__ ((packed)); | 461 | } __packed; |
462 | 462 | ||
463 | /* Filter types */ | 463 | /* Filter types */ |
464 | #define HCI_FLT_CLEAR_ALL 0x00 | 464 | #define HCI_FLT_CLEAR_ALL 0x00 |
@@ -477,13 +477,13 @@ struct hci_cp_set_event_flt { | |||
477 | #define HCI_OP_WRITE_LOCAL_NAME 0x0c13 | 477 | #define HCI_OP_WRITE_LOCAL_NAME 0x0c13 |
478 | struct hci_cp_write_local_name { | 478 | struct hci_cp_write_local_name { |
479 | __u8 name[248]; | 479 | __u8 name[248]; |
480 | } __attribute__ ((packed)); | 480 | } __packed; |
481 | 481 | ||
482 | #define HCI_OP_READ_LOCAL_NAME 0x0c14 | 482 | #define HCI_OP_READ_LOCAL_NAME 0x0c14 |
483 | struct hci_rp_read_local_name { | 483 | struct hci_rp_read_local_name { |
484 | __u8 status; | 484 | __u8 status; |
485 | __u8 name[248]; | 485 | __u8 name[248]; |
486 | } __attribute__ ((packed)); | 486 | } __packed; |
487 | 487 | ||
488 | #define HCI_OP_WRITE_CA_TIMEOUT 0x0c16 | 488 | #define HCI_OP_WRITE_CA_TIMEOUT 0x0c16 |
489 | 489 | ||
@@ -511,23 +511,23 @@ struct hci_rp_read_local_name { | |||
511 | struct hci_rp_read_class_of_dev { | 511 | struct hci_rp_read_class_of_dev { |
512 | __u8 status; | 512 | __u8 status; |
513 | __u8 dev_class[3]; | 513 | __u8 dev_class[3]; |
514 | } __attribute__ ((packed)); | 514 | } __packed; |
515 | 515 | ||
516 | #define HCI_OP_WRITE_CLASS_OF_DEV 0x0c24 | 516 | #define HCI_OP_WRITE_CLASS_OF_DEV 0x0c24 |
517 | struct hci_cp_write_class_of_dev { | 517 | struct hci_cp_write_class_of_dev { |
518 | __u8 dev_class[3]; | 518 | __u8 dev_class[3]; |
519 | } __attribute__ ((packed)); | 519 | } __packed; |
520 | 520 | ||
521 | #define HCI_OP_READ_VOICE_SETTING 0x0c25 | 521 | #define HCI_OP_READ_VOICE_SETTING 0x0c25 |
522 | struct hci_rp_read_voice_setting { | 522 | struct hci_rp_read_voice_setting { |
523 | __u8 status; | 523 | __u8 status; |
524 | __le16 voice_setting; | 524 | __le16 voice_setting; |
525 | } __attribute__ ((packed)); | 525 | } __packed; |
526 | 526 | ||
527 | #define HCI_OP_WRITE_VOICE_SETTING 0x0c26 | 527 | #define HCI_OP_WRITE_VOICE_SETTING 0x0c26 |
528 | struct hci_cp_write_voice_setting { | 528 | struct hci_cp_write_voice_setting { |
529 | __le16 voice_setting; | 529 | __le16 voice_setting; |
530 | } __attribute__ ((packed)); | 530 | } __packed; |
531 | 531 | ||
532 | #define HCI_OP_HOST_BUFFER_SIZE 0x0c33 | 532 | #define HCI_OP_HOST_BUFFER_SIZE 0x0c33 |
533 | struct hci_cp_host_buffer_size { | 533 | struct hci_cp_host_buffer_size { |
@@ -535,18 +535,18 @@ struct hci_cp_host_buffer_size { | |||
535 | __u8 sco_mtu; | 535 | __u8 sco_mtu; |
536 | __le16 acl_max_pkt; | 536 | __le16 acl_max_pkt; |
537 | __le16 sco_max_pkt; | 537 | __le16 sco_max_pkt; |
538 | } __attribute__ ((packed)); | 538 | } __packed; |
539 | 539 | ||
540 | #define HCI_OP_READ_SSP_MODE 0x0c55 | 540 | #define HCI_OP_READ_SSP_MODE 0x0c55 |
541 | struct hci_rp_read_ssp_mode { | 541 | struct hci_rp_read_ssp_mode { |
542 | __u8 status; | 542 | __u8 status; |
543 | __u8 mode; | 543 | __u8 mode; |
544 | } __attribute__ ((packed)); | 544 | } __packed; |
545 | 545 | ||
546 | #define HCI_OP_WRITE_SSP_MODE 0x0c56 | 546 | #define HCI_OP_WRITE_SSP_MODE 0x0c56 |
547 | struct hci_cp_write_ssp_mode { | 547 | struct hci_cp_write_ssp_mode { |
548 | __u8 mode; | 548 | __u8 mode; |
549 | } __attribute__ ((packed)); | 549 | } __packed; |
550 | 550 | ||
551 | #define HCI_OP_READ_LOCAL_VERSION 0x1001 | 551 | #define HCI_OP_READ_LOCAL_VERSION 0x1001 |
552 | struct hci_rp_read_local_version { | 552 | struct hci_rp_read_local_version { |
@@ -556,19 +556,19 @@ struct hci_rp_read_local_version { | |||
556 | __u8 lmp_ver; | 556 | __u8 lmp_ver; |
557 | __le16 manufacturer; | 557 | __le16 manufacturer; |
558 | __le16 lmp_subver; | 558 | __le16 lmp_subver; |
559 | } __attribute__ ((packed)); | 559 | } __packed; |
560 | 560 | ||
561 | #define HCI_OP_READ_LOCAL_COMMANDS 0x1002 | 561 | #define HCI_OP_READ_LOCAL_COMMANDS 0x1002 |
562 | struct hci_rp_read_local_commands { | 562 | struct hci_rp_read_local_commands { |
563 | __u8 status; | 563 | __u8 status; |
564 | __u8 commands[64]; | 564 | __u8 commands[64]; |
565 | } __attribute__ ((packed)); | 565 | } __packed; |
566 | 566 | ||
567 | #define HCI_OP_READ_LOCAL_FEATURES 0x1003 | 567 | #define HCI_OP_READ_LOCAL_FEATURES 0x1003 |
568 | struct hci_rp_read_local_features { | 568 | struct hci_rp_read_local_features { |
569 | __u8 status; | 569 | __u8 status; |
570 | __u8 features[8]; | 570 | __u8 features[8]; |
571 | } __attribute__ ((packed)); | 571 | } __packed; |
572 | 572 | ||
573 | #define HCI_OP_READ_LOCAL_EXT_FEATURES 0x1004 | 573 | #define HCI_OP_READ_LOCAL_EXT_FEATURES 0x1004 |
574 | struct hci_rp_read_local_ext_features { | 574 | struct hci_rp_read_local_ext_features { |
@@ -576,7 +576,7 @@ struct hci_rp_read_local_ext_features { | |||
576 | __u8 page; | 576 | __u8 page; |
577 | __u8 max_page; | 577 | __u8 max_page; |
578 | __u8 features[8]; | 578 | __u8 features[8]; |
579 | } __attribute__ ((packed)); | 579 | } __packed; |
580 | 580 | ||
581 | #define HCI_OP_READ_BUFFER_SIZE 0x1005 | 581 | #define HCI_OP_READ_BUFFER_SIZE 0x1005 |
582 | struct hci_rp_read_buffer_size { | 582 | struct hci_rp_read_buffer_size { |
@@ -585,13 +585,13 @@ struct hci_rp_read_buffer_size { | |||
585 | __u8 sco_mtu; | 585 | __u8 sco_mtu; |
586 | __le16 acl_max_pkt; | 586 | __le16 acl_max_pkt; |
587 | __le16 sco_max_pkt; | 587 | __le16 sco_max_pkt; |
588 | } __attribute__ ((packed)); | 588 | } __packed; |
589 | 589 | ||
590 | #define HCI_OP_READ_BD_ADDR 0x1009 | 590 | #define HCI_OP_READ_BD_ADDR 0x1009 |
591 | struct hci_rp_read_bd_addr { | 591 | struct hci_rp_read_bd_addr { |
592 | __u8 status; | 592 | __u8 status; |
593 | bdaddr_t bdaddr; | 593 | bdaddr_t bdaddr; |
594 | } __attribute__ ((packed)); | 594 | } __packed; |
595 | 595 | ||
596 | /* ---- HCI Events ---- */ | 596 | /* ---- HCI Events ---- */ |
597 | #define HCI_EV_INQUIRY_COMPLETE 0x01 | 597 | #define HCI_EV_INQUIRY_COMPLETE 0x01 |
@@ -604,7 +604,7 @@ struct inquiry_info { | |||
604 | __u8 pscan_mode; | 604 | __u8 pscan_mode; |
605 | __u8 dev_class[3]; | 605 | __u8 dev_class[3]; |
606 | __le16 clock_offset; | 606 | __le16 clock_offset; |
607 | } __attribute__ ((packed)); | 607 | } __packed; |
608 | 608 | ||
609 | #define HCI_EV_CONN_COMPLETE 0x03 | 609 | #define HCI_EV_CONN_COMPLETE 0x03 |
610 | struct hci_ev_conn_complete { | 610 | struct hci_ev_conn_complete { |
@@ -613,54 +613,54 @@ struct hci_ev_conn_complete { | |||
613 | bdaddr_t bdaddr; | 613 | bdaddr_t bdaddr; |
614 | __u8 link_type; | 614 | __u8 link_type; |
615 | __u8 encr_mode; | 615 | __u8 encr_mode; |
616 | } __attribute__ ((packed)); | 616 | } __packed; |
617 | 617 | ||
618 | #define HCI_EV_CONN_REQUEST 0x04 | 618 | #define HCI_EV_CONN_REQUEST 0x04 |
619 | struct hci_ev_conn_request { | 619 | struct hci_ev_conn_request { |
620 | bdaddr_t bdaddr; | 620 | bdaddr_t bdaddr; |
621 | __u8 dev_class[3]; | 621 | __u8 dev_class[3]; |
622 | __u8 link_type; | 622 | __u8 link_type; |
623 | } __attribute__ ((packed)); | 623 | } __packed; |
624 | 624 | ||
625 | #define HCI_EV_DISCONN_COMPLETE 0x05 | 625 | #define HCI_EV_DISCONN_COMPLETE 0x05 |
626 | struct hci_ev_disconn_complete { | 626 | struct hci_ev_disconn_complete { |
627 | __u8 status; | 627 | __u8 status; |
628 | __le16 handle; | 628 | __le16 handle; |
629 | __u8 reason; | 629 | __u8 reason; |
630 | } __attribute__ ((packed)); | 630 | } __packed; |
631 | 631 | ||
632 | #define HCI_EV_AUTH_COMPLETE 0x06 | 632 | #define HCI_EV_AUTH_COMPLETE 0x06 |
633 | struct hci_ev_auth_complete { | 633 | struct hci_ev_auth_complete { |
634 | __u8 status; | 634 | __u8 status; |
635 | __le16 handle; | 635 | __le16 handle; |
636 | } __attribute__ ((packed)); | 636 | } __packed; |
637 | 637 | ||
638 | #define HCI_EV_REMOTE_NAME 0x07 | 638 | #define HCI_EV_REMOTE_NAME 0x07 |
639 | struct hci_ev_remote_name { | 639 | struct hci_ev_remote_name { |
640 | __u8 status; | 640 | __u8 status; |
641 | bdaddr_t bdaddr; | 641 | bdaddr_t bdaddr; |
642 | __u8 name[248]; | 642 | __u8 name[248]; |
643 | } __attribute__ ((packed)); | 643 | } __packed; |
644 | 644 | ||
645 | #define HCI_EV_ENCRYPT_CHANGE 0x08 | 645 | #define HCI_EV_ENCRYPT_CHANGE 0x08 |
646 | struct hci_ev_encrypt_change { | 646 | struct hci_ev_encrypt_change { |
647 | __u8 status; | 647 | __u8 status; |
648 | __le16 handle; | 648 | __le16 handle; |
649 | __u8 encrypt; | 649 | __u8 encrypt; |
650 | } __attribute__ ((packed)); | 650 | } __packed; |
651 | 651 | ||
652 | #define HCI_EV_CHANGE_LINK_KEY_COMPLETE 0x09 | 652 | #define HCI_EV_CHANGE_LINK_KEY_COMPLETE 0x09 |
653 | struct hci_ev_change_link_key_complete { | 653 | struct hci_ev_change_link_key_complete { |
654 | __u8 status; | 654 | __u8 status; |
655 | __le16 handle; | 655 | __le16 handle; |
656 | } __attribute__ ((packed)); | 656 | } __packed; |
657 | 657 | ||
658 | #define HCI_EV_REMOTE_FEATURES 0x0b | 658 | #define HCI_EV_REMOTE_FEATURES 0x0b |
659 | struct hci_ev_remote_features { | 659 | struct hci_ev_remote_features { |
660 | __u8 status; | 660 | __u8 status; |
661 | __le16 handle; | 661 | __le16 handle; |
662 | __u8 features[8]; | 662 | __u8 features[8]; |
663 | } __attribute__ ((packed)); | 663 | } __packed; |
664 | 664 | ||
665 | #define HCI_EV_REMOTE_VERSION 0x0c | 665 | #define HCI_EV_REMOTE_VERSION 0x0c |
666 | struct hci_ev_remote_version { | 666 | struct hci_ev_remote_version { |
@@ -669,7 +669,7 @@ struct hci_ev_remote_version { | |||
669 | __u8 lmp_ver; | 669 | __u8 lmp_ver; |
670 | __le16 manufacturer; | 670 | __le16 manufacturer; |
671 | __le16 lmp_subver; | 671 | __le16 lmp_subver; |
672 | } __attribute__ ((packed)); | 672 | } __packed; |
673 | 673 | ||
674 | #define HCI_EV_QOS_SETUP_COMPLETE 0x0d | 674 | #define HCI_EV_QOS_SETUP_COMPLETE 0x0d |
675 | struct hci_qos { | 675 | struct hci_qos { |
@@ -678,38 +678,38 @@ struct hci_qos { | |||
678 | __u32 peak_bandwidth; | 678 | __u32 peak_bandwidth; |
679 | __u32 latency; | 679 | __u32 latency; |
680 | __u32 delay_variation; | 680 | __u32 delay_variation; |
681 | } __attribute__ ((packed)); | 681 | } __packed; |
682 | struct hci_ev_qos_setup_complete { | 682 | struct hci_ev_qos_setup_complete { |
683 | __u8 status; | 683 | __u8 status; |
684 | __le16 handle; | 684 | __le16 handle; |
685 | struct hci_qos qos; | 685 | struct hci_qos qos; |
686 | } __attribute__ ((packed)); | 686 | } __packed; |
687 | 687 | ||
688 | #define HCI_EV_CMD_COMPLETE 0x0e | 688 | #define HCI_EV_CMD_COMPLETE 0x0e |
689 | struct hci_ev_cmd_complete { | 689 | struct hci_ev_cmd_complete { |
690 | __u8 ncmd; | 690 | __u8 ncmd; |
691 | __le16 opcode; | 691 | __le16 opcode; |
692 | } __attribute__ ((packed)); | 692 | } __packed; |
693 | 693 | ||
694 | #define HCI_EV_CMD_STATUS 0x0f | 694 | #define HCI_EV_CMD_STATUS 0x0f |
695 | struct hci_ev_cmd_status { | 695 | struct hci_ev_cmd_status { |
696 | __u8 status; | 696 | __u8 status; |
697 | __u8 ncmd; | 697 | __u8 ncmd; |
698 | __le16 opcode; | 698 | __le16 opcode; |
699 | } __attribute__ ((packed)); | 699 | } __packed; |
700 | 700 | ||
701 | #define HCI_EV_ROLE_CHANGE 0x12 | 701 | #define HCI_EV_ROLE_CHANGE 0x12 |
702 | struct hci_ev_role_change { | 702 | struct hci_ev_role_change { |
703 | __u8 status; | 703 | __u8 status; |
704 | bdaddr_t bdaddr; | 704 | bdaddr_t bdaddr; |
705 | __u8 role; | 705 | __u8 role; |
706 | } __attribute__ ((packed)); | 706 | } __packed; |
707 | 707 | ||
708 | #define HCI_EV_NUM_COMP_PKTS 0x13 | 708 | #define HCI_EV_NUM_COMP_PKTS 0x13 |
709 | struct hci_ev_num_comp_pkts { | 709 | struct hci_ev_num_comp_pkts { |
710 | __u8 num_hndl; | 710 | __u8 num_hndl; |
711 | /* variable length part */ | 711 | /* variable length part */ |
712 | } __attribute__ ((packed)); | 712 | } __packed; |
713 | 713 | ||
714 | #define HCI_EV_MODE_CHANGE 0x14 | 714 | #define HCI_EV_MODE_CHANGE 0x14 |
715 | struct hci_ev_mode_change { | 715 | struct hci_ev_mode_change { |
@@ -717,44 +717,44 @@ struct hci_ev_mode_change { | |||
717 | __le16 handle; | 717 | __le16 handle; |
718 | __u8 mode; | 718 | __u8 mode; |
719 | __le16 interval; | 719 | __le16 interval; |
720 | } __attribute__ ((packed)); | 720 | } __packed; |
721 | 721 | ||
722 | #define HCI_EV_PIN_CODE_REQ 0x16 | 722 | #define HCI_EV_PIN_CODE_REQ 0x16 |
723 | struct hci_ev_pin_code_req { | 723 | struct hci_ev_pin_code_req { |
724 | bdaddr_t bdaddr; | 724 | bdaddr_t bdaddr; |
725 | } __attribute__ ((packed)); | 725 | } __packed; |
726 | 726 | ||
727 | #define HCI_EV_LINK_KEY_REQ 0x17 | 727 | #define HCI_EV_LINK_KEY_REQ 0x17 |
728 | struct hci_ev_link_key_req { | 728 | struct hci_ev_link_key_req { |
729 | bdaddr_t bdaddr; | 729 | bdaddr_t bdaddr; |
730 | } __attribute__ ((packed)); | 730 | } __packed; |
731 | 731 | ||
732 | #define HCI_EV_LINK_KEY_NOTIFY 0x18 | 732 | #define HCI_EV_LINK_KEY_NOTIFY 0x18 |
733 | struct hci_ev_link_key_notify { | 733 | struct hci_ev_link_key_notify { |
734 | bdaddr_t bdaddr; | 734 | bdaddr_t bdaddr; |
735 | __u8 link_key[16]; | 735 | __u8 link_key[16]; |
736 | __u8 key_type; | 736 | __u8 key_type; |
737 | } __attribute__ ((packed)); | 737 | } __packed; |
738 | 738 | ||
739 | #define HCI_EV_CLOCK_OFFSET 0x1c | 739 | #define HCI_EV_CLOCK_OFFSET 0x1c |
740 | struct hci_ev_clock_offset { | 740 | struct hci_ev_clock_offset { |
741 | __u8 status; | 741 | __u8 status; |
742 | __le16 handle; | 742 | __le16 handle; |
743 | __le16 clock_offset; | 743 | __le16 clock_offset; |
744 | } __attribute__ ((packed)); | 744 | } __packed; |
745 | 745 | ||
746 | #define HCI_EV_PKT_TYPE_CHANGE 0x1d | 746 | #define HCI_EV_PKT_TYPE_CHANGE 0x1d |
747 | struct hci_ev_pkt_type_change { | 747 | struct hci_ev_pkt_type_change { |
748 | __u8 status; | 748 | __u8 status; |
749 | __le16 handle; | 749 | __le16 handle; |
750 | __le16 pkt_type; | 750 | __le16 pkt_type; |
751 | } __attribute__ ((packed)); | 751 | } __packed; |
752 | 752 | ||
753 | #define HCI_EV_PSCAN_REP_MODE 0x20 | 753 | #define HCI_EV_PSCAN_REP_MODE 0x20 |
754 | struct hci_ev_pscan_rep_mode { | 754 | struct hci_ev_pscan_rep_mode { |
755 | bdaddr_t bdaddr; | 755 | bdaddr_t bdaddr; |
756 | __u8 pscan_rep_mode; | 756 | __u8 pscan_rep_mode; |
757 | } __attribute__ ((packed)); | 757 | } __packed; |
758 | 758 | ||
759 | #define HCI_EV_INQUIRY_RESULT_WITH_RSSI 0x22 | 759 | #define HCI_EV_INQUIRY_RESULT_WITH_RSSI 0x22 |
760 | struct inquiry_info_with_rssi { | 760 | struct inquiry_info_with_rssi { |
@@ -764,7 +764,7 @@ struct inquiry_info_with_rssi { | |||
764 | __u8 dev_class[3]; | 764 | __u8 dev_class[3]; |
765 | __le16 clock_offset; | 765 | __le16 clock_offset; |
766 | __s8 rssi; | 766 | __s8 rssi; |
767 | } __attribute__ ((packed)); | 767 | } __packed; |
768 | struct inquiry_info_with_rssi_and_pscan_mode { | 768 | struct inquiry_info_with_rssi_and_pscan_mode { |
769 | bdaddr_t bdaddr; | 769 | bdaddr_t bdaddr; |
770 | __u8 pscan_rep_mode; | 770 | __u8 pscan_rep_mode; |
@@ -773,7 +773,7 @@ struct inquiry_info_with_rssi_and_pscan_mode { | |||
773 | __u8 dev_class[3]; | 773 | __u8 dev_class[3]; |
774 | __le16 clock_offset; | 774 | __le16 clock_offset; |
775 | __s8 rssi; | 775 | __s8 rssi; |
776 | } __attribute__ ((packed)); | 776 | } __packed; |
777 | 777 | ||
778 | #define HCI_EV_REMOTE_EXT_FEATURES 0x23 | 778 | #define HCI_EV_REMOTE_EXT_FEATURES 0x23 |
779 | struct hci_ev_remote_ext_features { | 779 | struct hci_ev_remote_ext_features { |
@@ -782,7 +782,7 @@ struct hci_ev_remote_ext_features { | |||
782 | __u8 page; | 782 | __u8 page; |
783 | __u8 max_page; | 783 | __u8 max_page; |
784 | __u8 features[8]; | 784 | __u8 features[8]; |
785 | } __attribute__ ((packed)); | 785 | } __packed; |
786 | 786 | ||
787 | #define HCI_EV_SYNC_CONN_COMPLETE 0x2c | 787 | #define HCI_EV_SYNC_CONN_COMPLETE 0x2c |
788 | struct hci_ev_sync_conn_complete { | 788 | struct hci_ev_sync_conn_complete { |
@@ -795,7 +795,7 @@ struct hci_ev_sync_conn_complete { | |||
795 | __le16 rx_pkt_len; | 795 | __le16 rx_pkt_len; |
796 | __le16 tx_pkt_len; | 796 | __le16 tx_pkt_len; |
797 | __u8 air_mode; | 797 | __u8 air_mode; |
798 | } __attribute__ ((packed)); | 798 | } __packed; |
799 | 799 | ||
800 | #define HCI_EV_SYNC_CONN_CHANGED 0x2d | 800 | #define HCI_EV_SYNC_CONN_CHANGED 0x2d |
801 | struct hci_ev_sync_conn_changed { | 801 | struct hci_ev_sync_conn_changed { |
@@ -805,7 +805,7 @@ struct hci_ev_sync_conn_changed { | |||
805 | __u8 retrans_window; | 805 | __u8 retrans_window; |
806 | __le16 rx_pkt_len; | 806 | __le16 rx_pkt_len; |
807 | __le16 tx_pkt_len; | 807 | __le16 tx_pkt_len; |
808 | } __attribute__ ((packed)); | 808 | } __packed; |
809 | 809 | ||
810 | #define HCI_EV_SNIFF_SUBRATE 0x2e | 810 | #define HCI_EV_SNIFF_SUBRATE 0x2e |
811 | struct hci_ev_sniff_subrate { | 811 | struct hci_ev_sniff_subrate { |
@@ -815,7 +815,7 @@ struct hci_ev_sniff_subrate { | |||
815 | __le16 max_rx_latency; | 815 | __le16 max_rx_latency; |
816 | __le16 max_remote_timeout; | 816 | __le16 max_remote_timeout; |
817 | __le16 max_local_timeout; | 817 | __le16 max_local_timeout; |
818 | } __attribute__ ((packed)); | 818 | } __packed; |
819 | 819 | ||
820 | #define HCI_EV_EXTENDED_INQUIRY_RESULT 0x2f | 820 | #define HCI_EV_EXTENDED_INQUIRY_RESULT 0x2f |
821 | struct extended_inquiry_info { | 821 | struct extended_inquiry_info { |
@@ -826,37 +826,37 @@ struct extended_inquiry_info { | |||
826 | __le16 clock_offset; | 826 | __le16 clock_offset; |
827 | __s8 rssi; | 827 | __s8 rssi; |
828 | __u8 data[240]; | 828 | __u8 data[240]; |
829 | } __attribute__ ((packed)); | 829 | } __packed; |
830 | 830 | ||
831 | #define HCI_EV_IO_CAPA_REQUEST 0x31 | 831 | #define HCI_EV_IO_CAPA_REQUEST 0x31 |
832 | struct hci_ev_io_capa_request { | 832 | struct hci_ev_io_capa_request { |
833 | bdaddr_t bdaddr; | 833 | bdaddr_t bdaddr; |
834 | } __attribute__ ((packed)); | 834 | } __packed; |
835 | 835 | ||
836 | #define HCI_EV_SIMPLE_PAIR_COMPLETE 0x36 | 836 | #define HCI_EV_SIMPLE_PAIR_COMPLETE 0x36 |
837 | struct hci_ev_simple_pair_complete { | 837 | struct hci_ev_simple_pair_complete { |
838 | __u8 status; | 838 | __u8 status; |
839 | bdaddr_t bdaddr; | 839 | bdaddr_t bdaddr; |
840 | } __attribute__ ((packed)); | 840 | } __packed; |
841 | 841 | ||
842 | #define HCI_EV_REMOTE_HOST_FEATURES 0x3d | 842 | #define HCI_EV_REMOTE_HOST_FEATURES 0x3d |
843 | struct hci_ev_remote_host_features { | 843 | struct hci_ev_remote_host_features { |
844 | bdaddr_t bdaddr; | 844 | bdaddr_t bdaddr; |
845 | __u8 features[8]; | 845 | __u8 features[8]; |
846 | } __attribute__ ((packed)); | 846 | } __packed; |
847 | 847 | ||
848 | /* Internal events generated by Bluetooth stack */ | 848 | /* Internal events generated by Bluetooth stack */ |
849 | #define HCI_EV_STACK_INTERNAL 0xfd | 849 | #define HCI_EV_STACK_INTERNAL 0xfd |
850 | struct hci_ev_stack_internal { | 850 | struct hci_ev_stack_internal { |
851 | __u16 type; | 851 | __u16 type; |
852 | __u8 data[0]; | 852 | __u8 data[0]; |
853 | } __attribute__ ((packed)); | 853 | } __packed; |
854 | 854 | ||
855 | #define HCI_EV_SI_DEVICE 0x01 | 855 | #define HCI_EV_SI_DEVICE 0x01 |
856 | struct hci_ev_si_device { | 856 | struct hci_ev_si_device { |
857 | __u16 event; | 857 | __u16 event; |
858 | __u16 dev_id; | 858 | __u16 dev_id; |
859 | } __attribute__ ((packed)); | 859 | } __packed; |
860 | 860 | ||
861 | #define HCI_EV_SI_SECURITY 0x02 | 861 | #define HCI_EV_SI_SECURITY 0x02 |
862 | struct hci_ev_si_security { | 862 | struct hci_ev_si_security { |
@@ -864,7 +864,7 @@ struct hci_ev_si_security { | |||
864 | __u16 proto; | 864 | __u16 proto; |
865 | __u16 subproto; | 865 | __u16 subproto; |
866 | __u8 incoming; | 866 | __u8 incoming; |
867 | } __attribute__ ((packed)); | 867 | } __packed; |
868 | 868 | ||
869 | /* ---- HCI Packet structures ---- */ | 869 | /* ---- HCI Packet structures ---- */ |
870 | #define HCI_COMMAND_HDR_SIZE 3 | 870 | #define HCI_COMMAND_HDR_SIZE 3 |
@@ -875,22 +875,22 @@ struct hci_ev_si_security { | |||
875 | struct hci_command_hdr { | 875 | struct hci_command_hdr { |
876 | __le16 opcode; /* OCF & OGF */ | 876 | __le16 opcode; /* OCF & OGF */ |
877 | __u8 plen; | 877 | __u8 plen; |
878 | } __attribute__ ((packed)); | 878 | } __packed; |
879 | 879 | ||
880 | struct hci_event_hdr { | 880 | struct hci_event_hdr { |
881 | __u8 evt; | 881 | __u8 evt; |
882 | __u8 plen; | 882 | __u8 plen; |
883 | } __attribute__ ((packed)); | 883 | } __packed; |
884 | 884 | ||
885 | struct hci_acl_hdr { | 885 | struct hci_acl_hdr { |
886 | __le16 handle; /* Handle & Flags(PB, BC) */ | 886 | __le16 handle; /* Handle & Flags(PB, BC) */ |
887 | __le16 dlen; | 887 | __le16 dlen; |
888 | } __attribute__ ((packed)); | 888 | } __packed; |
889 | 889 | ||
890 | struct hci_sco_hdr { | 890 | struct hci_sco_hdr { |
891 | __le16 handle; | 891 | __le16 handle; |
892 | __u8 dlen; | 892 | __u8 dlen; |
893 | } __attribute__ ((packed)); | 893 | } __packed; |
894 | 894 | ||
895 | #ifdef __KERNEL__ | 895 | #ifdef __KERNEL__ |
896 | #include <linux/skbuff.h> | 896 | #include <linux/skbuff.h> |
diff --git a/include/net/bluetooth/l2cap.h b/include/net/bluetooth/l2cap.h index 4b86c783976c..636724b203ee 100644 --- a/include/net/bluetooth/l2cap.h +++ b/include/net/bluetooth/l2cap.h | |||
@@ -131,31 +131,31 @@ struct l2cap_conninfo { | |||
131 | struct l2cap_hdr { | 131 | struct l2cap_hdr { |
132 | __le16 len; | 132 | __le16 len; |
133 | __le16 cid; | 133 | __le16 cid; |
134 | } __attribute__ ((packed)); | 134 | } __packed; |
135 | #define L2CAP_HDR_SIZE 4 | 135 | #define L2CAP_HDR_SIZE 4 |
136 | 136 | ||
137 | struct l2cap_cmd_hdr { | 137 | struct l2cap_cmd_hdr { |
138 | __u8 code; | 138 | __u8 code; |
139 | __u8 ident; | 139 | __u8 ident; |
140 | __le16 len; | 140 | __le16 len; |
141 | } __attribute__ ((packed)); | 141 | } __packed; |
142 | #define L2CAP_CMD_HDR_SIZE 4 | 142 | #define L2CAP_CMD_HDR_SIZE 4 |
143 | 143 | ||
144 | struct l2cap_cmd_rej { | 144 | struct l2cap_cmd_rej { |
145 | __le16 reason; | 145 | __le16 reason; |
146 | } __attribute__ ((packed)); | 146 | } __packed; |
147 | 147 | ||
148 | struct l2cap_conn_req { | 148 | struct l2cap_conn_req { |
149 | __le16 psm; | 149 | __le16 psm; |
150 | __le16 scid; | 150 | __le16 scid; |
151 | } __attribute__ ((packed)); | 151 | } __packed; |
152 | 152 | ||
153 | struct l2cap_conn_rsp { | 153 | struct l2cap_conn_rsp { |
154 | __le16 dcid; | 154 | __le16 dcid; |
155 | __le16 scid; | 155 | __le16 scid; |
156 | __le16 result; | 156 | __le16 result; |
157 | __le16 status; | 157 | __le16 status; |
158 | } __attribute__ ((packed)); | 158 | } __packed; |
159 | 159 | ||
160 | /* channel indentifier */ | 160 | /* channel indentifier */ |
161 | #define L2CAP_CID_SIGNALING 0x0001 | 161 | #define L2CAP_CID_SIGNALING 0x0001 |
@@ -179,14 +179,14 @@ struct l2cap_conf_req { | |||
179 | __le16 dcid; | 179 | __le16 dcid; |
180 | __le16 flags; | 180 | __le16 flags; |
181 | __u8 data[0]; | 181 | __u8 data[0]; |
182 | } __attribute__ ((packed)); | 182 | } __packed; |
183 | 183 | ||
184 | struct l2cap_conf_rsp { | 184 | struct l2cap_conf_rsp { |
185 | __le16 scid; | 185 | __le16 scid; |
186 | __le16 flags; | 186 | __le16 flags; |
187 | __le16 result; | 187 | __le16 result; |
188 | __u8 data[0]; | 188 | __u8 data[0]; |
189 | } __attribute__ ((packed)); | 189 | } __packed; |
190 | 190 | ||
191 | #define L2CAP_CONF_SUCCESS 0x0000 | 191 | #define L2CAP_CONF_SUCCESS 0x0000 |
192 | #define L2CAP_CONF_UNACCEPT 0x0001 | 192 | #define L2CAP_CONF_UNACCEPT 0x0001 |
@@ -197,7 +197,7 @@ struct l2cap_conf_opt { | |||
197 | __u8 type; | 197 | __u8 type; |
198 | __u8 len; | 198 | __u8 len; |
199 | __u8 val[0]; | 199 | __u8 val[0]; |
200 | } __attribute__ ((packed)); | 200 | } __packed; |
201 | #define L2CAP_CONF_OPT_SIZE 2 | 201 | #define L2CAP_CONF_OPT_SIZE 2 |
202 | 202 | ||
203 | #define L2CAP_CONF_HINT 0x80 | 203 | #define L2CAP_CONF_HINT 0x80 |
@@ -218,7 +218,7 @@ struct l2cap_conf_rfc { | |||
218 | __le16 retrans_timeout; | 218 | __le16 retrans_timeout; |
219 | __le16 monitor_timeout; | 219 | __le16 monitor_timeout; |
220 | __le16 max_pdu_size; | 220 | __le16 max_pdu_size; |
221 | } __attribute__ ((packed)); | 221 | } __packed; |
222 | 222 | ||
223 | #define L2CAP_MODE_BASIC 0x00 | 223 | #define L2CAP_MODE_BASIC 0x00 |
224 | #define L2CAP_MODE_RETRANS 0x01 | 224 | #define L2CAP_MODE_RETRANS 0x01 |
@@ -229,22 +229,22 @@ struct l2cap_conf_rfc { | |||
229 | struct l2cap_disconn_req { | 229 | struct l2cap_disconn_req { |
230 | __le16 dcid; | 230 | __le16 dcid; |
231 | __le16 scid; | 231 | __le16 scid; |
232 | } __attribute__ ((packed)); | 232 | } __packed; |
233 | 233 | ||
234 | struct l2cap_disconn_rsp { | 234 | struct l2cap_disconn_rsp { |
235 | __le16 dcid; | 235 | __le16 dcid; |
236 | __le16 scid; | 236 | __le16 scid; |
237 | } __attribute__ ((packed)); | 237 | } __packed; |
238 | 238 | ||
239 | struct l2cap_info_req { | 239 | struct l2cap_info_req { |
240 | __le16 type; | 240 | __le16 type; |
241 | } __attribute__ ((packed)); | 241 | } __packed; |
242 | 242 | ||
243 | struct l2cap_info_rsp { | 243 | struct l2cap_info_rsp { |
244 | __le16 type; | 244 | __le16 type; |
245 | __le16 result; | 245 | __le16 result; |
246 | __u8 data[0]; | 246 | __u8 data[0]; |
247 | } __attribute__ ((packed)); | 247 | } __packed; |
248 | 248 | ||
249 | /* info type */ | 249 | /* info type */ |
250 | #define L2CAP_IT_CL_MTU 0x0001 | 250 | #define L2CAP_IT_CL_MTU 0x0001 |
diff --git a/include/net/bluetooth/rfcomm.h b/include/net/bluetooth/rfcomm.h index 921d7b3c7f8d..a140847d622c 100644 --- a/include/net/bluetooth/rfcomm.h +++ b/include/net/bluetooth/rfcomm.h | |||
@@ -106,19 +106,19 @@ struct rfcomm_hdr { | |||
106 | u8 addr; | 106 | u8 addr; |
107 | u8 ctrl; | 107 | u8 ctrl; |
108 | u8 len; // Actual size can be 2 bytes | 108 | u8 len; // Actual size can be 2 bytes |
109 | } __attribute__ ((packed)); | 109 | } __packed; |
110 | 110 | ||
111 | struct rfcomm_cmd { | 111 | struct rfcomm_cmd { |
112 | u8 addr; | 112 | u8 addr; |
113 | u8 ctrl; | 113 | u8 ctrl; |
114 | u8 len; | 114 | u8 len; |
115 | u8 fcs; | 115 | u8 fcs; |
116 | } __attribute__ ((packed)); | 116 | } __packed; |
117 | 117 | ||
118 | struct rfcomm_mcc { | 118 | struct rfcomm_mcc { |
119 | u8 type; | 119 | u8 type; |
120 | u8 len; | 120 | u8 len; |
121 | } __attribute__ ((packed)); | 121 | } __packed; |
122 | 122 | ||
123 | struct rfcomm_pn { | 123 | struct rfcomm_pn { |
124 | u8 dlci; | 124 | u8 dlci; |
@@ -128,7 +128,7 @@ struct rfcomm_pn { | |||
128 | __le16 mtu; | 128 | __le16 mtu; |
129 | u8 max_retrans; | 129 | u8 max_retrans; |
130 | u8 credits; | 130 | u8 credits; |
131 | } __attribute__ ((packed)); | 131 | } __packed; |
132 | 132 | ||
133 | struct rfcomm_rpn { | 133 | struct rfcomm_rpn { |
134 | u8 dlci; | 134 | u8 dlci; |
@@ -138,17 +138,17 @@ struct rfcomm_rpn { | |||
138 | u8 xon_char; | 138 | u8 xon_char; |
139 | u8 xoff_char; | 139 | u8 xoff_char; |
140 | __le16 param_mask; | 140 | __le16 param_mask; |
141 | } __attribute__ ((packed)); | 141 | } __packed; |
142 | 142 | ||
143 | struct rfcomm_rls { | 143 | struct rfcomm_rls { |
144 | u8 dlci; | 144 | u8 dlci; |
145 | u8 status; | 145 | u8 status; |
146 | } __attribute__ ((packed)); | 146 | } __packed; |
147 | 147 | ||
148 | struct rfcomm_msc { | 148 | struct rfcomm_msc { |
149 | u8 dlci; | 149 | u8 dlci; |
150 | u8 v24_sig; | 150 | u8 v24_sig; |
151 | } __attribute__ ((packed)); | 151 | } __packed; |
152 | 152 | ||
153 | /* ---- Core structures, flags etc ---- */ | 153 | /* ---- Core structures, flags etc ---- */ |
154 | 154 | ||