⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 record.c

📁 蓝牙的各种编程接口和各种按理介绍,还有一些例子和说明
💻 C
字号:
/*  Service Discovery Protocol (SDP)  Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>, Stephen Crane <steve.crane@rococosoft.com>     Based on original SDP implementation by Nokia Corporation.  Copyright (C) 2001,2002 Nokia Corporation.  Original author Guruprasad Krishnamurthy <guruprasad.krishnamurthy@nokia.com>     This program is free software; you can redistribute it and/or modify  it under the terms of the GNU General Public License version 2 as  published by the Free Software Foundation;     THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF THIRD PARTY RIGHTS.  IN NO EVENT SHALL THE COPYRIGHT HOLDER(S) AND AUTHOR(S) BE LIABLE FOR ANY CLAIM,  OR ANY SPECIAL INDIRECT OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER  RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,  NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE  USE OR PERFORMANCE OF THIS SOFTWARE.     ALL LIABILITY, INCLUDING LIABILITY FOR INFRINGEMENT OF ANY PATENTS, COPYRIGHTS,  TRADEMARKS OR OTHER RIGHTS, RELATING TO USE OF THIS SOFTWARE IS DISCLAIMED.*//*  SDP service registration  Fixes:  Guruprasad Krishnamurthy <guruprasad.krishnamurthy@nokia.com>  Manel Guerrero Zapata <manel.guerrero-zapata@nokia.com>*//* * $Id: record.c,v 1.42 2003/09/19 15:02:55 holtmann Exp $ */#include <malloc.h>#include <errno.h>#include "sdp.h"#include "sdp_internal.h"#include "sdp_lib.h"/* * Registers an sdp record. * * It is incorrect to call this method on a record that * has been already registered with the server. * * Returns a non-null value (a pointer) to a service * record if successful, else -1 setting errno */int sdp_record_register(sdp_session_t *session, sdp_record_t *rec, uint8_t flags){	char *p;	int status = 0;	char *req, *rsp;	int reqsize, rspsize;	sdp_pdu_hdr_t *reqhdr, *rsphdr;	sdp_buf_t pdu;	SDPDBG("");	if (!session->local) {		errno = EREMOTE;		return -1;	}	req = (char *)malloc(SDP_REQ_BUFFER_SIZE);	rsp = (char *)malloc(SDP_RSP_BUFFER_SIZE);	if (req == NULL || rsp == NULL) {		status = -1;		errno = ENOMEM;		goto end;	}	reqhdr = (sdp_pdu_hdr_t *)req;	reqhdr->pdu_id = SDP_SVC_REGISTER_REQ;	reqhdr->tid    = htons(sdp_gen_tid(session));	reqsize = sizeof(sdp_pdu_hdr_t) + 1;	p = req + sizeof(sdp_pdu_hdr_t);	*p++ = flags;	if (0 > sdp_gen_record_pdu(rec, &pdu)) {		status = -1;		errno = ENOMEM;		goto end;	}	memcpy(p, pdu.data, pdu.data_size);	free(pdu.data);	reqsize += pdu.data_size;	reqhdr->plen = htons(reqsize - sizeof(sdp_pdu_hdr_t));	status = sdp_send_req_w4_rsp(session, req, rsp, reqsize, &rspsize);	if (status < 0)		goto end;	rsphdr = (sdp_pdu_hdr_t *)rsp;	p = rsp + sizeof(sdp_pdu_hdr_t);	if (rsphdr->pdu_id == SDP_SVC_REGISTER_RSP) {		uint32_t handle  = ntohl(sdp_get_unaligned((uint32_t *)p));		sdp_data_t *data = sdp_data_alloc(SDP_UINT32, &handle);		rec->handle = handle;		sdp_attr_replace(rec, SDP_ATTR_RECORD_HANDLE, data);	}end:	if (req)		free(req);	if (rsp)		free(rsp);	return status;}/* * unregister a service record */int sdp_record_unregister(sdp_session_t *session, sdp_record_t *rec){	char *p;	int status = 0;	char *reqbuf, *rspbuf;	int reqsize = 0, rspsize = 0;	sdp_pdu_hdr_t *reqhdr, *rsphdr;	uint32_t handle = 0;	SDPDBG("");	handle = rec->handle;	if (handle == SDP_SERVER_RECORD_HANDLE) {		errno = EINVAL;		return -1;	}	if (!session->local) {		errno = EREMOTE;		return -1;	}	reqbuf = (char *)malloc(SDP_REQ_BUFFER_SIZE);	rspbuf = (char *)malloc(SDP_RSP_BUFFER_SIZE);	if (!reqbuf || !rspbuf) {		errno = ENOMEM;		status = -1;		goto end;	}	reqhdr = (sdp_pdu_hdr_t *)reqbuf;	reqhdr->pdu_id = SDP_SVC_REMOVE_REQ;	reqhdr->tid    = htons(sdp_gen_tid(session));	p = reqbuf + sizeof(sdp_pdu_hdr_t);	reqsize = sizeof(sdp_pdu_hdr_t);	sdp_put_unaligned(htonl(handle), (uint32_t *)p);	reqsize += sizeof(uint32_t);	reqhdr->plen = htons(reqsize - sizeof(sdp_pdu_hdr_t));	status = sdp_send_req_w4_rsp(session, reqbuf, rspbuf, reqsize, &rspsize);	if (status == 0) {		rsphdr = (sdp_pdu_hdr_t *)rspbuf;		p = rspbuf + sizeof(sdp_pdu_hdr_t);		status = sdp_get_unaligned((uint16_t *)p);		if (status == 0 && rsphdr->pdu_id == SDP_SVC_REMOVE_RSP) {			SDPDBG("Removing local copy\n");			sdp_record_free(rec);		}	}  end:	if (reqbuf)		free(reqbuf);	if (rspbuf)		free(rspbuf);	return status;}/* * modify an existing service record */int sdp_record_update(sdp_session_t *session, const sdp_record_t *rec){	char *p;	int status = 0;	char *reqbuf, *rspbuf;	int reqsize, rspsize;	sdp_pdu_hdr_t *reqhdr, *rsphdr;	uint32_t handle;	sdp_buf_t pdu;	SDPDBG("");	handle = rec->handle;	if (handle == SDP_SERVER_RECORD_HANDLE) {		errno = EINVAL;		return -1;	}	if (!session->local) {		errno = EREMOTE;		return -1;	}	reqbuf = (char *)malloc(SDP_REQ_BUFFER_SIZE);	rspbuf = (char *)malloc(SDP_RSP_BUFFER_SIZE);	if (!reqbuf || !rspbuf) {		errno = ENOMEM;		status = -1;		goto end;	}	reqhdr = (sdp_pdu_hdr_t *)reqbuf;	reqhdr->pdu_id = SDP_SVC_UPDATE_REQ;	reqhdr->tid    = htons(sdp_gen_tid(session));	p = (char *)(reqbuf + sizeof(sdp_pdu_hdr_t));	reqsize = sizeof(sdp_pdu_hdr_t);	sdp_put_unaligned(htonl(handle), (uint32_t *)p);	reqsize += sizeof(uint32_t);	p += sizeof(uint32_t);	if (0 > sdp_gen_record_pdu(rec, &pdu)) {		errno = ENOMEM;		status = -1;		goto end;	}	memcpy(p, pdu.data, pdu.data_size);	reqsize += pdu.data_size;	reqhdr->plen = htons(reqsize - sizeof(sdp_pdu_hdr_t));	status = sdp_send_req_w4_rsp(session, reqbuf, rspbuf, reqsize, &rspsize);	SDPDBG("Send req status : %d\n", status);	if (status == 0) {		rsphdr = (sdp_pdu_hdr_t *)rspbuf;		p = rspbuf + sizeof(sdp_pdu_hdr_t);		status = sdp_get_unaligned((uint16_t *)p);	}end:	if (reqbuf)		free(reqbuf);	if (rspbuf)		free(rspbuf);	return status;}sdp_record_t *sdp_record_alloc(){	sdp_record_t *rec = (sdp_record_t *)malloc(sizeof(sdp_record_t));	memset((void *)rec, 0, sizeof(sdp_record_t));	rec->handle = 0xffffffff;	return rec;}/* * Free the contents of a service record */void sdp_record_free(sdp_record_t *rec){	sdp_list_free(rec->attrlist, (sdp_free_func_t)sdp_data_free);	sdp_list_free(rec->pattern, free);	free(rec);}void sdp_pattern_add_uuid(sdp_record_t *rec, uuid_t *uuid){	uuid_t *uuid128 = sdp_uuid_to_uuid128(uuid);	SDPDBG("SvcRec : 0x%lx\n", (unsigned long)rec);	SDPDBG("Elements in target pattern : %d\n", sdp_list_len(rec->pattern));	SDPDBG("Trying to add : 0x%lx\n", (unsigned long)uuid128);	if (sdp_list_find(rec->pattern, uuid128, sdp_uuid128_cmp) == NULL)		rec->pattern = sdp_list_insert_sorted(rec->pattern, uuid128, sdp_uuid128_cmp);	else		free(uuid128);	SDPDBG("Elements in target pattern : %d\n", sdp_list_len(rec->pattern));}void sdp_pattern_add_uuidseq(sdp_record_t *rec, sdp_list_t *seq){	for (; seq; seq = seq->next) {		uuid_t *uuid = (uuid_t *)seq->data;		sdp_pattern_add_uuid(rec, uuid);	}}

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -