1 /* $NetBSD: sdp.c,v 1.2 2008/12/06 20:01:14 plunky Exp $ */
4 * SPDX-License-Identifier: BSD-2-Clause-NetBSD
6 * Copyright (c) 2008 Iain Hibbert
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions
12 * 1. Redistributions of source code must retain the above copyright
13 * notice, this list of conditions and the following disclaimer.
14 * 2. Redistributions in binary form must reproduce the above copyright
15 * notice, this list of conditions and the following disclaimer in the
16 * documentation and/or other materials provided with the distribution.
18 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20 * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21 * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24 * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25 * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27 * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
32 #include <sys/cdefs.h>
33 __RCSID("$NetBSD: sdp.c,v 1.2 2008/12/06 20:01:14 plunky Exp $");
37 #define L2CAP_SOCKET_CHECKED
41 * SDP data stream manipulation routines
44 /* Bluetooth Base UUID */
45 static const uuid_t BASE_UUID = {
51 { 0x00, 0x80, 0x5f, 0x9b, 0x34, 0xfb }
55 * _sdp_match_uuid16(ptr, limit, uuid)
57 * examine SDP data stream at ptr for a UUID, and return
58 * true if it matches the supplied short alias bluetooth UUID.
59 * limit is the first address past the end of valid data.
62 _sdp_match_uuid16(uint8_t **ptr, uint8_t *limit, uint16_t uuid)
67 memcpy(&u1, &BASE_UUID, sizeof(uuid_t));
70 if (!_sdp_get_uuid(&p, limit, &u2)
71 || !uuid_equal(&u1, &u2, NULL))
79 * _sdp_get_uuid(ptr, limit, uuid)
81 * examine SDP data stream at ptr for a UUID, and extract
82 * to given storage, advancing ptr.
83 * limit is the first address past the end of valid data.
86 _sdp_get_uuid(uint8_t **ptr, uint8_t *limit, uuid_t *uuid)
98 memcpy(uuid, &BASE_UUID, sizeof(uuid_t));
99 uuid->time_low = be16dec(p);
103 case SDP_DATA_UUID32:
107 memcpy(uuid, &BASE_UUID, sizeof(uuid_t));
108 uuid->time_low = be32dec(p);
112 case SDP_DATA_UUID128:
116 uuid_dec_be(p, uuid);
129 * _sdp_get_seq(ptr, limit, seq)
131 * examine SDP data stream at ptr for a sequence. return
132 * seq pointer if found and advance ptr to next object.
133 * limit is the first address past the end of valid data.
136 _sdp_get_seq(uint8_t **ptr, uint8_t *limit, uint8_t **seq)
181 * _sdp_get_uint16(ptr, limit, value)
183 * examine SDP data stream at ptr for a uint16_t, and
184 * extract to given storage, advancing ptr.
185 * limit is the first address past the end of valid data.
188 _sdp_get_uint16(uint8_t **ptr, uint8_t *limit, uint16_t *value)
197 case SDP_DATA_UINT16: