diff options
author | Marcel Holtmann <marcel@holtmann.org> | 2005-05-08 17:18:18 +0000 |
---|---|---|
committer | Marcel Holtmann <marcel@holtmann.org> | 2005-05-08 17:18:18 +0000 |
commit | 0a2a889c91f9b671b7c31bcb6e4e53daf306fb7e (patch) | |
tree | f108e6a11200b22c6ccd2a3467f9579b23c5c594 /src | |
parent | a28f053fed22e73e57c701d146983e1fcd0dcac3 (diff) |
Add SDP_WAIT_ON_CLOSE flag for sdp_connect()
Diffstat (limited to 'src')
-rw-r--r-- | src/sdp.c | 8 |
1 files changed, 6 insertions, 2 deletions
@@ -3167,13 +3167,17 @@ sdp_session_t *sdp_connect(const bdaddr_t *src, const bdaddr_t *dst, uint32_t fl sa.l2_psm = 0; if (bacmp(src, BDADDR_ANY) != 0) { sa.l2_bdaddr = *src; - if (0 > bind(session->sock, (struct sockaddr *)&sa, sizeof(sa))) + if (bind(session->sock, (struct sockaddr *) &sa, sizeof(sa)) < 0) goto fail; } + if (flags & SDP_WAIT_ON_CLOSE) { + struct linger l = { .l_onoff = 1, .l_linger = 1 }; + setsockopt(session->sock, SOL_SOCKET, SO_LINGER, &l, sizeof(l)); + } sa.l2_psm = htobs(SDP_PSM); sa.l2_bdaddr = *dst; do - if (connect(session->sock, (struct sockaddr *)&sa, sizeof(sa)) == 0) + if (connect(session->sock, (struct sockaddr *) &sa, sizeof(sa)) == 0) return session; while (errno == EBUSY && (flags & SDP_RETRY_IF_BUSY)); } |