mirror of
https://github.com/torvalds/linux.git
synced 2024-12-05 02:23:16 +00:00
26afbd826e
This adds the initial implementation of CIS connections and introduces the ISO packets/links. == Central: Set CIG Parameters, create a CIS and Setup Data Path == > tools/isotest -s <address> < HCI Command: LE Extended Create... (0x08|0x0043) plen 26 ... > HCI Event: Command Status (0x0f) plen 4 LE Extended Create Connection (0x08|0x0043) ncmd 1 Status: Success (0x00) > HCI Event: LE Meta Event (0x3e) plen 31 LE Enhanced Connection Complete (0x0a) ... < HCI Command: LE Create Connected... (0x08|0x0064) plen 5 ... > HCI Event: Command Status (0x0f) plen 4 LE Create Connected Isochronous Stream (0x08|0x0064) ncmd 1 Status: Success (0x00) > HCI Event: LE Meta Event (0x3e) plen 29 LE Connected Isochronous Stream Established (0x19) ... < HCI Command: LE Setup Isochronou.. (0x08|0x006e) plen 13 ... > HCI Event: Command Complete (0x0e) plen 6 LE Setup Isochronous Data Path (0x08|0x006e) ncmd 1 Status: Success (0x00) Handle: 257 < HCI Command: LE Setup Isochronou.. (0x08|0x006e) plen 13 ... > HCI Event: Command Complete (0x0e) plen 6 LE Setup Isochronous Data Path (0x08|0x006e) ncmd 1 Status: Success (0x00) Handle: 257 == Peripheral: Accept CIS and Setup Data Path == > tools/isotest -d HCI Event: LE Meta Event (0x3e) plen 7 LE Connected Isochronous Stream Request (0x1a) ... < HCI Command: LE Accept Co.. (0x08|0x0066) plen 2 ... > HCI Event: LE Meta Event (0x3e) plen 29 LE Connected Isochronous Stream Established (0x19) ... < HCI Command: LE Setup Is.. (0x08|0x006e) plen 13 ... > HCI Event: Command Complete (0x0e) plen 6 LE Setup Isochronous Data Path (0x08|0x006e) ncmd 1 Status: Success (0x00) Handle: 257 < HCI Command: LE Setup Is.. (0x08|0x006e) plen 13 ... > HCI Event: Command Complete (0x0e) plen 6 LE Setup Isochronous Data Path (0x08|0x006e) ncmd 1 Status: Success (0x00) Handle: 257 Signed-off-by: Luiz Augusto von Dentz <luiz.von.dentz@intel.com>
179 lines
3.9 KiB
C
179 lines
3.9 KiB
C
/*
|
|
BlueZ - Bluetooth protocol stack for Linux
|
|
Copyright (C) 2000-2001 Qualcomm Incorporated
|
|
|
|
Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
it under the terms of the GNU General Public License version 2 as
|
|
published by the Free Software Foundation;
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
|
|
OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.
|
|
IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY
|
|
CLAIM, OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
|
|
OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS,
|
|
COPYRIGHTS, TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS
|
|
SOFTWARE IS DISCLAIMED.
|
|
*/
|
|
|
|
#ifndef __HCI_SOCK_H
|
|
#define __HCI_SOCK_H
|
|
|
|
/* Socket options */
|
|
#define HCI_DATA_DIR 1
|
|
#define HCI_FILTER 2
|
|
#define HCI_TIME_STAMP 3
|
|
|
|
/* CMSG flags */
|
|
#define HCI_CMSG_DIR 0x01
|
|
#define HCI_CMSG_TSTAMP 0x02
|
|
|
|
struct sockaddr_hci {
|
|
sa_family_t hci_family;
|
|
unsigned short hci_dev;
|
|
unsigned short hci_channel;
|
|
};
|
|
#define HCI_DEV_NONE 0xffff
|
|
|
|
#define HCI_CHANNEL_RAW 0
|
|
#define HCI_CHANNEL_USER 1
|
|
#define HCI_CHANNEL_MONITOR 2
|
|
#define HCI_CHANNEL_CONTROL 3
|
|
#define HCI_CHANNEL_LOGGING 4
|
|
|
|
struct hci_filter {
|
|
unsigned long type_mask;
|
|
unsigned long event_mask[2];
|
|
__le16 opcode;
|
|
};
|
|
|
|
struct hci_ufilter {
|
|
__u32 type_mask;
|
|
__u32 event_mask[2];
|
|
__le16 opcode;
|
|
};
|
|
|
|
#define HCI_FLT_TYPE_BITS 31
|
|
#define HCI_FLT_EVENT_BITS 63
|
|
#define HCI_FLT_OGF_BITS 63
|
|
#define HCI_FLT_OCF_BITS 127
|
|
|
|
/* Ioctl defines */
|
|
#define HCIDEVUP _IOW('H', 201, int)
|
|
#define HCIDEVDOWN _IOW('H', 202, int)
|
|
#define HCIDEVRESET _IOW('H', 203, int)
|
|
#define HCIDEVRESTAT _IOW('H', 204, int)
|
|
|
|
#define HCIGETDEVLIST _IOR('H', 210, int)
|
|
#define HCIGETDEVINFO _IOR('H', 211, int)
|
|
#define HCIGETCONNLIST _IOR('H', 212, int)
|
|
#define HCIGETCONNINFO _IOR('H', 213, int)
|
|
#define HCIGETAUTHINFO _IOR('H', 215, int)
|
|
|
|
#define HCISETRAW _IOW('H', 220, int)
|
|
#define HCISETSCAN _IOW('H', 221, int)
|
|
#define HCISETAUTH _IOW('H', 222, int)
|
|
#define HCISETENCRYPT _IOW('H', 223, int)
|
|
#define HCISETPTYPE _IOW('H', 224, int)
|
|
#define HCISETLINKPOL _IOW('H', 225, int)
|
|
#define HCISETLINKMODE _IOW('H', 226, int)
|
|
#define HCISETACLMTU _IOW('H', 227, int)
|
|
#define HCISETSCOMTU _IOW('H', 228, int)
|
|
|
|
#define HCIBLOCKADDR _IOW('H', 230, int)
|
|
#define HCIUNBLOCKADDR _IOW('H', 231, int)
|
|
|
|
#define HCIINQUIRY _IOR('H', 240, int)
|
|
|
|
/* Ioctl requests structures */
|
|
struct hci_dev_stats {
|
|
__u32 err_rx;
|
|
__u32 err_tx;
|
|
__u32 cmd_tx;
|
|
__u32 evt_rx;
|
|
__u32 acl_tx;
|
|
__u32 acl_rx;
|
|
__u32 sco_tx;
|
|
__u32 sco_rx;
|
|
__u32 byte_rx;
|
|
__u32 byte_tx;
|
|
};
|
|
|
|
struct hci_dev_info {
|
|
__u16 dev_id;
|
|
char name[8];
|
|
|
|
bdaddr_t bdaddr;
|
|
|
|
__u32 flags;
|
|
__u8 type;
|
|
|
|
__u8 features[8];
|
|
|
|
__u32 pkt_type;
|
|
__u32 link_policy;
|
|
__u32 link_mode;
|
|
|
|
__u16 acl_mtu;
|
|
__u16 acl_pkts;
|
|
__u16 sco_mtu;
|
|
__u16 sco_pkts;
|
|
__u16 iso_mtu;
|
|
__u16 iso_pkts;
|
|
|
|
struct hci_dev_stats stat;
|
|
};
|
|
|
|
struct hci_conn_info {
|
|
__u16 handle;
|
|
bdaddr_t bdaddr;
|
|
__u8 type;
|
|
__u8 out;
|
|
__u16 state;
|
|
__u32 link_mode;
|
|
};
|
|
|
|
struct hci_dev_req {
|
|
__u16 dev_id;
|
|
__u32 dev_opt;
|
|
};
|
|
|
|
struct hci_dev_list_req {
|
|
__u16 dev_num;
|
|
struct hci_dev_req dev_req[]; /* hci_dev_req structures */
|
|
};
|
|
|
|
struct hci_conn_list_req {
|
|
__u16 dev_id;
|
|
__u16 conn_num;
|
|
struct hci_conn_info conn_info[];
|
|
};
|
|
|
|
struct hci_conn_info_req {
|
|
bdaddr_t bdaddr;
|
|
__u8 type;
|
|
struct hci_conn_info conn_info[];
|
|
};
|
|
|
|
struct hci_auth_info_req {
|
|
bdaddr_t bdaddr;
|
|
__u8 type;
|
|
};
|
|
|
|
struct hci_inquiry_req {
|
|
__u16 dev_id;
|
|
__u16 flags;
|
|
__u8 lap[3];
|
|
__u8 length;
|
|
__u8 num_rsp;
|
|
};
|
|
#define IREQ_CACHE_FLUSH 0x0001
|
|
|
|
#endif /* __HCI_SOCK_H */
|