diff options
| author | Marcel Holtmann <marcel@holtmann.org> | 2007-07-11 03:51:55 -0400 |
|---|---|---|
| committer | Marcel Holtmann <marcel@holtmann.org> | 2007-07-11 01:35:32 -0400 |
| commit | 5b7f990927fe87ad3bec762a33c0e72bcbf6841e (patch) | |
| tree | 1c9356fe04e235e938fa7a1a7a2c7a75bc124de0 /include/net/bluetooth | |
| parent | 8de0a15483b357d0f0b821330ec84d1660cadc4e (diff) | |
[Bluetooth] Add basics to better support and handle eSCO links
To better support and handle eSCO links in the future a bunch of
constants needs to be added and some basic routines need to be
updated. This is the initial step.
Signed-off-by: Marcel Holtmann <marcel@holtmann.org>
Diffstat (limited to 'include/net/bluetooth')
| -rw-r--r-- | include/net/bluetooth/hci.h | 18 | ||||
| -rw-r--r-- | include/net/bluetooth/hci_core.h | 2 |
2 files changed, 18 insertions, 2 deletions
diff --git a/include/net/bluetooth/hci.h b/include/net/bluetooth/hci.h index 93ce272a5d..ebfb96b411 100644 --- a/include/net/bluetooth/hci.h +++ b/include/net/bluetooth/hci.h | |||
| @@ -107,14 +107,14 @@ enum { | |||
| 107 | #define HCI_IDLE_TIMEOUT (6000) /* 6 seconds */ | 107 | #define HCI_IDLE_TIMEOUT (6000) /* 6 seconds */ |
| 108 | #define HCI_INIT_TIMEOUT (10000) /* 10 seconds */ | 108 | #define HCI_INIT_TIMEOUT (10000) /* 10 seconds */ |
| 109 | 109 | ||
| 110 | /* HCI Packet types */ | 110 | /* HCI data types */ |
| 111 | #define HCI_COMMAND_PKT 0x01 | 111 | #define HCI_COMMAND_PKT 0x01 |
| 112 | #define HCI_ACLDATA_PKT 0x02 | 112 | #define HCI_ACLDATA_PKT 0x02 |
| 113 | #define HCI_SCODATA_PKT 0x03 | 113 | #define HCI_SCODATA_PKT 0x03 |
| 114 | #define HCI_EVENT_PKT 0x04 | 114 | #define HCI_EVENT_PKT 0x04 |
| 115 | #define HCI_VENDOR_PKT 0xff | 115 | #define HCI_VENDOR_PKT 0xff |
| 116 | 116 | ||
| 117 | /* HCI Packet types */ | 117 | /* HCI packet types */ |
| 118 | #define HCI_DM1 0x0008 | 118 | #define HCI_DM1 0x0008 |
| 119 | #define HCI_DM3 0x0400 | 119 | #define HCI_DM3 0x0400 |
| 120 | #define HCI_DM5 0x4000 | 120 | #define HCI_DM5 0x4000 |
| @@ -129,6 +129,14 @@ enum { | |||
| 129 | #define SCO_PTYPE_MASK (HCI_HV1 | HCI_HV2 | HCI_HV3) | 129 | #define SCO_PTYPE_MASK (HCI_HV1 | HCI_HV2 | HCI_HV3) |
| 130 | #define ACL_PTYPE_MASK (~SCO_PTYPE_MASK) | 130 | #define ACL_PTYPE_MASK (~SCO_PTYPE_MASK) |
| 131 | 131 | ||
| 132 | /* eSCO packet types */ | ||
| 133 | #define ESCO_HV1 0x0001 | ||
| 134 | #define ESCO_HV2 0x0002 | ||
| 135 | #define ESCO_HV3 0x0004 | ||
| 136 | #define ESCO_EV3 0x0008 | ||
| 137 | #define ESCO_EV4 0x0010 | ||
| 138 | #define ESCO_EV5 0x0020 | ||
| 139 | |||
| 132 | /* ACL flags */ | 140 | /* ACL flags */ |
| 133 | #define ACL_CONT 0x01 | 141 | #define ACL_CONT 0x01 |
| 134 | #define ACL_START 0x02 | 142 | #define ACL_START 0x02 |
| @@ -138,6 +146,7 @@ enum { | |||
| 138 | /* Baseband links */ | 146 | /* Baseband links */ |
| 139 | #define SCO_LINK 0x00 | 147 | #define SCO_LINK 0x00 |
| 140 | #define ACL_LINK 0x01 | 148 | #define ACL_LINK 0x01 |
| 149 | #define ESCO_LINK 0x02 | ||
| 141 | 150 | ||
| 142 | /* LMP features */ | 151 | /* LMP features */ |
| 143 | #define LMP_3SLOT 0x01 | 152 | #define LMP_3SLOT 0x01 |
| @@ -162,6 +171,11 @@ enum { | |||
| 162 | #define LMP_PSCHEME 0x02 | 171 | #define LMP_PSCHEME 0x02 |
| 163 | #define LMP_PCONTROL 0x04 | 172 | #define LMP_PCONTROL 0x04 |
| 164 | 173 | ||
| 174 | #define LMP_ESCO 0x80 | ||
| 175 | |||
| 176 | #define LMP_EV4 0x01 | ||
| 177 | #define LMP_EV5 0x02 | ||
| 178 | |||
| 165 | #define LMP_SNIFF_SUBR 0x02 | 179 | #define LMP_SNIFF_SUBR 0x02 |
| 166 | 180 | ||
| 167 | /* Connection modes */ | 181 | /* Connection modes */ |
diff --git a/include/net/bluetooth/hci_core.h b/include/net/bluetooth/hci_core.h index 7c78744ec0..8f67c8a716 100644 --- a/include/net/bluetooth/hci_core.h +++ b/include/net/bluetooth/hci_core.h | |||
| @@ -78,6 +78,7 @@ struct hci_dev { | |||
| 78 | __u16 voice_setting; | 78 | __u16 voice_setting; |
| 79 | 79 | ||
| 80 | __u16 pkt_type; | 80 | __u16 pkt_type; |
| 81 | __u16 esco_type; | ||
| 81 | __u16 link_policy; | 82 | __u16 link_policy; |
| 82 | __u16 link_mode; | 83 | __u16 link_mode; |
| 83 | 84 | ||
| @@ -452,6 +453,7 @@ void hci_conn_del_sysfs(struct hci_conn *conn); | |||
| 452 | #define lmp_encrypt_capable(dev) ((dev)->features[0] & LMP_ENCRYPT) | 453 | #define lmp_encrypt_capable(dev) ((dev)->features[0] & LMP_ENCRYPT) |
| 453 | #define lmp_sniff_capable(dev) ((dev)->features[0] & LMP_SNIFF) | 454 | #define lmp_sniff_capable(dev) ((dev)->features[0] & LMP_SNIFF) |
| 454 | #define lmp_sniffsubr_capable(dev) ((dev)->features[5] & LMP_SNIFF_SUBR) | 455 | #define lmp_sniffsubr_capable(dev) ((dev)->features[5] & LMP_SNIFF_SUBR) |
| 456 | #define lmp_esco_capable(dev) ((dev)->features[3] & LMP_ESCO) | ||
| 455 | 457 | ||
| 456 | /* ----- HCI protocols ----- */ | 458 | /* ----- HCI protocols ----- */ |
| 457 | struct hci_proto { | 459 | struct hci_proto { |
