|
@@ -38,7 +38,7 @@ struct sco_param {
|
|
|
u16 max_latency;
|
|
|
};
|
|
|
|
|
|
-static const struct sco_param sco_param_cvsd[] = {
|
|
|
+static const struct sco_param esco_param_cvsd[] = {
|
|
|
{ EDR_ESCO_MASK & ~ESCO_2EV3, 0x000a }, /* S3 */
|
|
|
{ EDR_ESCO_MASK & ~ESCO_2EV3, 0x0007 }, /* S2 */
|
|
|
{ EDR_ESCO_MASK | ESCO_EV3, 0x0007 }, /* S1 */
|
|
@@ -46,6 +46,11 @@ static const struct sco_param sco_param_cvsd[] = {
|
|
|
{ EDR_ESCO_MASK | ESCO_HV1, 0xffff }, /* D0 */
|
|
|
};
|
|
|
|
|
|
+static const struct sco_param sco_param_cvsd[] = {
|
|
|
+ { EDR_ESCO_MASK | ESCO_HV3, 0xffff }, /* D1 */
|
|
|
+ { EDR_ESCO_MASK | ESCO_HV1, 0xffff }, /* D0 */
|
|
|
+};
|
|
|
+
|
|
|
static const struct sco_param sco_param_wideband[] = {
|
|
|
{ EDR_ESCO_MASK & ~ESCO_2EV3, 0x000d }, /* T2 */
|
|
|
{ EDR_ESCO_MASK | ESCO_EV3, 0x0008 }, /* T1 */
|
|
@@ -207,10 +212,17 @@ bool hci_setup_sync(struct hci_conn *conn, __u16 handle)
|
|
|
param = &sco_param_wideband[conn->attempt - 1];
|
|
|
break;
|
|
|
case SCO_AIRMODE_CVSD:
|
|
|
- if (conn->attempt > ARRAY_SIZE(sco_param_cvsd))
|
|
|
- return false;
|
|
|
- cp.retrans_effort = 0x01;
|
|
|
- param = &sco_param_cvsd[conn->attempt - 1];
|
|
|
+ if (lmp_esco_capable(conn->link)) {
|
|
|
+ if (conn->attempt > ARRAY_SIZE(esco_param_cvsd))
|
|
|
+ return false;
|
|
|
+ cp.retrans_effort = 0x01;
|
|
|
+ param = &esco_param_cvsd[conn->attempt - 1];
|
|
|
+ } else {
|
|
|
+ if (conn->attempt > ARRAY_SIZE(sco_param_cvsd))
|
|
|
+ return false;
|
|
|
+ cp.retrans_effort = 0xff;
|
|
|
+ param = &sco_param_cvsd[conn->attempt - 1];
|
|
|
+ }
|
|
|
break;
|
|
|
default:
|
|
|
return false;
|