--- health/hdp.c | 1 + health/hdp_util.c | 52 +++++++++++++++++++++++++++++++++++++--------------- 2 files changed, 38 insertions(+), 15 deletions(-) diff --git a/health/hdp.c b/health/hdp.c index 752714a..d38aff1 100644 --- a/health/hdp.c +++ b/health/hdp.c @@ -462,6 +462,7 @@ static void connect_health_instance(sdp_list_t *recs, int err, gpointer data) goto fail; } + info("psm = 0x%x, version = 0x%x", ccpsm, version); device_get_address(device->dev, &dst); mcap_create_mcl(hdpi->mi, &dst, ccpsm, &gerr, hdp_mcl_connect_cb, cb_data); diff --git a/health/hdp_util.c b/health/hdp_util.c index a7fc1d5..2706a74 100644 --- a/health/hdp_util.c +++ b/health/hdp_util.c @@ -884,29 +884,51 @@ gboolean hdp_get_data_exchange_spec(const sdp_record_t *rec, guint8 *val) return TRUE; } +static gboolean get_prot_desc_entry(sdp_data_t *entry, int type, guint16 *val) +{ + sdp_data_t *iter; + int proto; + + if (!entry || (entry->dtd != SDP_SEQ8)) + return FALSE; + + iter = entry->val.dataseq; + if (!(iter->dtd & SDP_UUID_UNSPEC)) + return FALSE; + + proto = sdp_uuid_to_proto(&iter->val.uuid); + if (proto != type) + return FALSE; + + iter = iter->next; + if (iter->dtd != SDP_UINT16) + return FALSE; + if (val) { + *val = iter->val.uint16; + } + return TRUE; +} + gboolean hdp_get_prot_desc_list(const sdp_record_t *rec, guint16 *psm, guint16 *version) { - if (!(psm || version)) + sdp_data_t *pdl, *p0, *p1; + + if (!psm && !version) return TRUE; - /* TODO: - sdp_data_t *pdl, *l; + pdl = sdp_data_get(rec, SDP_ATTR_PROTO_DESC_LIST); + if (pdl->dtd != SDP_SEQ8) + return FALSE; + + p0 = pdl->val.dataseq; - exspec = sdp_data_get(rec, SDP_ATTR_PROTO_DESC_LIST); - if (exspec->dtd != SDP_SEQ8) + if (!get_prot_desc_entry(p0, L2CAP_UUID, psm)) + return FALSE; + p1 = p0->next; + if (!get_prot_desc_entry(p1, MCAP_CTRL_UUID, version)) return FALSE; - for (l = pdl->val.dataseq; l; l = l->next) { - if (l->dtd != SDP_SEQ8) - continue; - epl = get_feature(epl, l->val.dataseq); - } - */ - if (psm) - *psm = 0x1001; - if (version) - *version = 0x0100; return TRUE; } -- 1.6.3.3 -- To unsubscribe from this list: send the line "unsubscribe linux-bluetooth" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html