亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? unix.c

?? 基于LINUX內(nèi)核驅(qū)動的開發(fā)
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * *  BlueZ - Bluetooth protocol stack for Linux * *  Copyright (C) 2006-2007  Nokia Corporation *  Copyright (C) 2004-2008  Marcel Holtmann <marcel@holtmann.org> * * *  This program is free software; you can redistribute it and/or modify *  it under the terms of the GNU General Public License as published by *  the Free Software Foundation; either version 2 of the License, or *  (at your option) any later version. * *  This program is distributed in the hope that it will be useful, *  but WITHOUT ANY WARRANTY; without even the implied warranty of *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the *  GNU General Public License for more details. * *  You should have received a copy of the GNU General Public License *  along with this program; if not, write to the Free Software *  Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA * */#ifdef HAVE_CONFIG_H#include <config.h>#endif#include <stdio.h>#include <sys/socket.h>#include <sys/un.h>#include <stdlib.h>#include <errno.h>#include <unistd.h>#include <stdint.h>#include <bluetooth/bluetooth.h>#include <bluetooth/sdp.h>#include <dbus/dbus.h>#include <glib.h>#include "logging.h"#include "dbus.h"#include "ipc.h"#include "device.h"#include "manager.h"#include "avdtp.h"#include "a2dp.h"#include "headset.h"#include "sink.h"#include "unix.h"typedef enum {	TYPE_NONE,	TYPE_HEADSET,	TYPE_SINK,	TYPE_SOURCE} service_type_t;typedef void (*notify_cb_t) (struct device *dev, void *data);struct a2dp_data {	struct avdtp *session;	struct avdtp_stream *stream;	struct a2dp_sep *sep;};struct headset_data {	headset_lock_t lock;};struct unix_client {	struct device *dev;	GSList *caps;	service_type_t type;	char *interface;	union {		struct a2dp_data a2dp;		struct headset_data hs;	} d;	int sock;	int access_mode;	int data_fd; /* To be deleted once two phase configuration is fully implemented */	unsigned int req_id;	unsigned int cb_id;	gboolean (*cancel) (struct device *dev, unsigned int id);};static GSList *clients = NULL;static int unix_sock = -1;static void client_free(struct unix_client *client){	struct a2dp_data *a2dp;	switch (client->type) {	case TYPE_SINK:	case TYPE_SOURCE:		a2dp = &client->d.a2dp;		if (client->cb_id > 0)			avdtp_stream_remove_cb(a2dp->session, a2dp->stream,								client->cb_id);		if (a2dp->sep)			a2dp_sep_unlock(a2dp->sep, a2dp->session);		if (a2dp->session)			avdtp_unref(a2dp->session);		break;	default:		break;	}	if (client->sock >= 0)		close(client->sock);	if (client->caps) {		g_slist_foreach(client->caps, (GFunc) g_free, NULL);		g_slist_free(client->caps);	}	g_free(client->interface);	g_free(client);}/* Pass file descriptor through local domain sockets (AF_LOCAL, formerly * AF_UNIX) and the sendmsg() system call with the cmsg_type field of a "struct * cmsghdr" set to SCM_RIGHTS and the data being an integer value equal to the * handle of the file descriptor to be passed. */static int unix_sendmsg_fd(int sock, int fd){	char cmsg_b[CMSG_SPACE(sizeof(int))], m = 'm';	struct cmsghdr *cmsg;	struct iovec iov = { &m, sizeof(m) };	struct msghdr msgh;	memset(&msgh, 0, sizeof(msgh));	msgh.msg_iov = &iov;	msgh.msg_iovlen = 1;	msgh.msg_control = &cmsg_b;	msgh.msg_controllen = CMSG_LEN(sizeof(int));	cmsg = CMSG_FIRSTHDR(&msgh);	cmsg->cmsg_level = SOL_SOCKET;	cmsg->cmsg_type = SCM_RIGHTS;	cmsg->cmsg_len = CMSG_LEN(sizeof(int));	/* Initialize the payload */	(*(int *) CMSG_DATA(cmsg)) = fd;	return sendmsg(sock, &msgh, MSG_NOSIGNAL);}static void unix_ipc_sendmsg(struct unix_client *client,					const bt_audio_msg_header_t *msg){	info("Audio API: sending %s", bt_audio_strmsg(msg->msg_type));	if (send(client->sock, msg, BT_AUDIO_IPC_PACKET_SIZE, 0) < 0)		error("Error %s(%d)", strerror(errno), errno);}static void unix_ipc_error(struct unix_client *client, int type, int err){	char buf[BT_AUDIO_IPC_PACKET_SIZE];	bt_audio_rsp_msg_header_t *rsp_hdr = (void *) buf;	memset(buf, 0, sizeof(buf));	rsp_hdr->msg_h.msg_type = type;	rsp_hdr->posix_errno = err;	unix_ipc_sendmsg(client, &rsp_hdr->msg_h);}static service_type_t select_service(struct device *dev, const char *interface){	if (!interface) {		if (dev->sink && avdtp_is_connected(&dev->src, &dev->dst))			return TYPE_SINK;		else if (dev->headset && headset_is_active(dev))			return TYPE_HEADSET;		else if (dev->sink)			return TYPE_SINK;		else if (dev->headset)			return TYPE_HEADSET;	} else if (!strcmp(interface, AUDIO_SINK_INTERFACE) && dev->sink)		return TYPE_SINK;	else if (!strcmp(interface, AUDIO_HEADSET_INTERFACE) && dev->headset)		return TYPE_HEADSET;	return TYPE_NONE;}static void stream_state_changed(struct avdtp_stream *stream,					avdtp_state_t old_state,					avdtp_state_t new_state,					struct avdtp_error *err,					void *user_data){	struct unix_client *client = user_data;	struct a2dp_data *a2dp = &client->d.a2dp;	switch (new_state) {	case AVDTP_STATE_IDLE:		if (a2dp->sep) {			a2dp_sep_unlock(a2dp->sep, a2dp->session);			a2dp->sep = NULL;		}		client->dev = NULL;		if (a2dp->session) {			avdtp_unref(a2dp->session);			a2dp->session = NULL;		}		a2dp->stream = NULL;		client->cb_id = 0;		break;	default:		break;	}}static void headset_discovery_complete(struct device *dev, void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_getcapabilities_rsp *rsp = (void *) buf;	client->req_id = 0;	if (!dev)		goto failed;	memset(buf, 0, sizeof(buf));	rsp->rsp_h.msg_h.msg_type = BT_GETCAPABILITIES_RSP;	rsp->transport  = BT_CAPABILITIES_TRANSPORT_SCO;	rsp->sampling_rate = 8000;	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	return;failed:	error("discovery failed");	unix_ipc_error(client, BT_SETCONFIGURATION_RSP, EIO);	client->dev = NULL;}static void headset_setup_complete(struct device *dev, void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_setconfiguration_rsp *rsp = (void *) buf;	struct headset_data *hs = &client->d.hs;	client->req_id = 0;	if (!dev)		goto failed;	switch (client->access_mode) {	case BT_CAPABILITIES_ACCESS_MODE_READ:		hs->lock = HEADSET_LOCK_READ;		break;	case BT_CAPABILITIES_ACCESS_MODE_WRITE:		hs->lock = HEADSET_LOCK_WRITE;		break;	case BT_CAPABILITIES_ACCESS_MODE_READWRITE:		hs->lock = HEADSET_LOCK_READ | HEADSET_LOCK_WRITE;		break;	default:		hs->lock = 0;		break;	}	if (!headset_lock(dev, hs->lock)) {		error("Unable to lock headset");		goto failed;	}	memset(buf, 0, sizeof(buf));	rsp->rsp_h.msg_h.msg_type = BT_SETCONFIGURATION_RSP;	rsp->transport  = BT_CAPABILITIES_TRANSPORT_SCO;	rsp->access_mode = client->access_mode;	rsp->link_mtu = 48;	client->data_fd = headset_get_sco_fd(dev);	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	return;failed:	error("config failed");	unix_ipc_error(client, BT_SETCONFIGURATION_RSP, EIO);	client->dev = NULL;}static void headset_resume_complete(struct device *dev, void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_streamstart_rsp *rsp = (void *) buf;	struct bt_streamfd_ind *ind = (void *) buf;	client->req_id = 0;	if (!dev)		goto failed;	memset(buf, 0, sizeof(buf));	rsp->rsp_h.msg_h.msg_type = BT_STREAMSTART_RSP;	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	memset(buf, 0, sizeof(buf));	ind->h.msg_type = BT_STREAMFD_IND;	unix_ipc_sendmsg(client, &ind->h);	client->data_fd = headset_get_sco_fd(dev);	if (unix_sendmsg_fd(client->sock, client->data_fd) < 0) {		error("unix_sendmsg_fd: %s(%d)", strerror(errno), errno);		goto failed;	}	return;failed:	error("resume failed");	unix_ipc_error(client, BT_STREAMSTART_RSP, EIO);	client->dev = NULL;}static void a2dp_discovery_complete(struct avdtp *session, GSList *seps,					struct avdtp_error *err,					void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_getcapabilities_rsp *rsp = (void *) buf;	struct a2dp_data *a2dp = &client->d.a2dp;	struct sbc_codec_cap *sbc_cap = NULL;	struct mpeg_codec_cap *mpeg_cap = NULL;	GSList *l;	if (!g_slist_find(clients, client)) {		debug("Client disconnected during discovery");		return;	}	if (err)		goto failed;	memset(buf, 0, sizeof(buf));	client->req_id = 0;	rsp->rsp_h.msg_h.msg_type = BT_GETCAPABILITIES_RSP;	rsp->transport = BT_CAPABILITIES_TRANSPORT_A2DP;	for (l = seps; l; l = g_slist_next(l)) {		struct avdtp_remote_sep *rsep = l->data;		struct avdtp_service_capability *cap;		struct avdtp_media_codec_capability *codec_cap;		cap = avdtp_get_codec(rsep);		if (cap->category != AVDTP_MEDIA_CODEC)			continue;		codec_cap = (void *) cap->data;		if (codec_cap->media_codec_type == A2DP_CODEC_SBC && !sbc_cap)			sbc_cap = (void *) codec_cap;		if (codec_cap->media_codec_type == A2DP_CODEC_MPEG12 && !mpeg_cap)			mpeg_cap = (void *) codec_cap;	}	/* endianess prevent direct cast */	if (sbc_cap) {		rsp->sbc_capabilities.channel_mode = sbc_cap->channel_mode;		rsp->sbc_capabilities.frequency = sbc_cap->frequency;		rsp->sbc_capabilities.allocation_method = sbc_cap->allocation_method;		rsp->sbc_capabilities.subbands = sbc_cap->subbands;		rsp->sbc_capabilities.block_length = sbc_cap->block_length;		rsp->sbc_capabilities.min_bitpool = sbc_cap->min_bitpool;		rsp->sbc_capabilities.max_bitpool = sbc_cap->max_bitpool;	}	if (mpeg_cap) {		rsp->mpeg_capabilities.channel_mode = mpeg_cap->channel_mode;		rsp->mpeg_capabilities.crc = mpeg_cap->crc;		rsp->mpeg_capabilities.layer = mpeg_cap->layer;		rsp->mpeg_capabilities.frequency = mpeg_cap->frequency;		rsp->mpeg_capabilities.mpf = mpeg_cap->mpf;		rsp->mpeg_capabilities.bitrate = mpeg_cap->bitrate;	}	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	return;failed:	error("discovery failed");	unix_ipc_error(client, BT_GETCAPABILITIES_RSP, EIO);	avdtp_unref(a2dp->session);	a2dp->session = NULL;	a2dp->stream = NULL;}static void a2dp_config_complete(struct avdtp *session, struct a2dp_sep *sep,					struct avdtp_stream *stream,					struct avdtp_error *err,					void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_setconfiguration_rsp *rsp = (void *) buf;	struct a2dp_data *a2dp = &client->d.a2dp;	uint16_t imtu, omtu;	GSList *caps;	if (err)		goto failed;	memset(buf, 0, sizeof(buf));	client->req_id = 0;	if (!stream)		goto failed;	if (!a2dp_sep_lock(sep, session)) {		error("Unable to lock A2DP source SEP");		goto failed;	}	a2dp->sep = sep;	a2dp->stream = stream;	if (!avdtp_stream_get_transport(stream, &client->data_fd, &imtu, &omtu,					&caps)) {		error("Unable to get stream transport");		goto failed;	}	rsp->rsp_h.msg_h.msg_type = BT_SETCONFIGURATION_RSP;	rsp->transport = BT_CAPABILITIES_TRANSPORT_A2DP;	client->access_mode = BT_CAPABILITIES_ACCESS_MODE_WRITE;	rsp->access_mode = client->access_mode;	/* FIXME: Use imtu when fd_opt is CFG_FD_OPT_READ */	rsp->link_mtu = omtu;	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	client->cb_id = avdtp_stream_add_cb(session, stream,						stream_state_changed, client);	return;failed:	error("config failed");	if (a2dp->sep) {		a2dp_sep_unlock(a2dp->sep, a2dp->session);		a2dp->sep = NULL;	}	unix_ipc_error(client, BT_SETCONFIGURATION_RSP, EIO);	avdtp_unref(a2dp->session);	a2dp->session = NULL;	a2dp->stream = NULL;}static void a2dp_resume_complete(struct avdtp *session,				struct avdtp_error *err, void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_streamstart_rsp *rsp = (void *) buf;	struct bt_streamfd_ind *ind = (void *) buf;	struct a2dp_data *a2dp = &client->d.a2dp;	if (err)		goto failed;	memset(buf, 0, sizeof(buf));	rsp->rsp_h.msg_h.msg_type = BT_STREAMSTART_RSP;	rsp->rsp_h.posix_errno = 0;	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	memset(buf, 0, sizeof(buf));	ind->h.msg_type = BT_STREAMFD_IND;	unix_ipc_sendmsg(client, &ind->h);	if (unix_sendmsg_fd(client->sock, client->data_fd) < 0) {		error("unix_sendmsg_fd: %s(%d)", strerror(errno), errno);		goto failed;	}	return;failed:	error("resume failed");	if (a2dp->sep) {		a2dp_sep_unlock(a2dp->sep, a2dp->session);		a2dp->sep = NULL;	}	unix_ipc_error(client, BT_STREAMSTART_RSP, EIO);	avdtp_unref(a2dp->session);	a2dp->session = NULL;	a2dp->stream = NULL;}static void a2dp_suspend_complete(struct avdtp *session,				struct avdtp_error *err, void *user_data){	struct unix_client *client = user_data;	char buf[BT_AUDIO_IPC_PACKET_SIZE];	struct bt_streamstart_rsp *rsp = (void *) buf;	struct a2dp_data *a2dp = &client->d.a2dp;	if (err)		goto failed;	memset(buf, 0, sizeof(buf));	rsp->rsp_h.msg_h.msg_type = BT_STREAMSTOP_RSP;	rsp->rsp_h.posix_errno = 0;	unix_ipc_sendmsg(client, &rsp->rsp_h.msg_h);	return;failed:	error("suspend failed");	if (a2dp->sep) {		a2dp_sep_unlock(a2dp->sep, a2dp->session);		a2dp->sep = NULL;	}	unix_ipc_error(client, BT_STREAMSTOP_RSP, EIO);	avdtp_unref(a2dp->session);	a2dp->session = NULL;	a2dp->stream = NULL;}static void start_discovery(struct device *dev, struct unix_client *client){	struct a2dp_data *a2dp;	int err = 0;	client->type = select_service(dev, client->interface);	switch (client->type) {	case TYPE_SINK:		a2dp = &client->d.a2dp;		if (!a2dp->session)			a2dp->session = avdtp_get(&dev->src, &dev->dst);		if (!a2dp->session) {			error("Unable to get a session");			goto failed;		}		err = avdtp_discover(a2dp->session, a2dp_discovery_complete,					client);		if (err)			goto failed;		break;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品羞羞答答xxdd| 青青草97国产精品免费观看| 亚洲线精品一区二区三区八戒| 亚洲人成7777| 婷婷成人综合网| 另类调教123区| 国产精品影视网| 国产乱子伦一区二区三区国色天香| 日韩 欧美一区二区三区| 亚洲一区二区三区四区在线免费观看| 亚洲欧洲日韩综合一区二区| 亚洲国产日韩一区二区| 日本午夜一区二区| 99精品热视频| 欧美日韩国产大片| 国产欧美精品一区二区三区四区 | 久久久亚洲综合| 日日噜噜夜夜狠狠视频欧美人| 国产一区999| 色综合色狠狠综合色| 精品蜜桃在线看| 天天影视色香欲综合网老头| 成人性生交大片| 26uuu另类欧美亚洲曰本| 天堂蜜桃一区二区三区| 北条麻妃国产九九精品视频| 日韩欧美一二三区| 中文字幕av在线一区二区三区| 中文字幕亚洲不卡| 国产成人夜色高潮福利影视| 欧美电影免费观看高清完整版在线 | 亚洲一区在线视频| 97se亚洲国产综合自在线不卡| 精品av综合导航| 亚洲r级在线视频| 日本高清不卡视频| 综合在线观看色| 国产综合成人久久大片91| 欧美在线免费视屏| 三级久久三级久久久| 日韩一区二区免费高清| 久久99国产精品久久| 欧美精品一区二区久久久| 久久99久久久久久久久久久| 欧美日韩午夜在线视频| 一级精品视频在线观看宜春院| 成人激情综合网站| 国产精品麻豆欧美日韩ww| 国产电影精品久久禁18| 中文字幕欧美国产| 欧美在线观看你懂的| 国产欧美精品一区| 亚洲v中文字幕| 欧美日韩精品系列| 国产麻豆精品在线| 一区二区视频在线看| 91精品国产一区二区三区蜜臀| 日韩国产在线一| 日韩一级片网址| 成人一级片在线观看| 性欧美疯狂xxxxbbbb| 国产香蕉久久精品综合网| 在线中文字幕不卡| 精品一区二区成人精品| 国产精品久久久久久久久果冻传媒| 美国十次综合导航| 亚洲视频中文字幕| 久久久久久久精| 91精品国产手机| 色综合久久久网| 国产精品一区免费视频| 午夜免费久久看| 国产精品毛片高清在线完整版| 欧美午夜电影在线播放| 国产在线日韩欧美| 韩国欧美一区二区| 日韩av一区二区在线影视| 一区二区三区四区中文字幕| 777亚洲妇女| 高清日韩电视剧大全免费| 日韩国产欧美视频| 日韩精品一卡二卡三卡四卡无卡| 国产欧美日韩另类视频免费观看| 久久影院视频免费| 久久日一线二线三线suv| 欧美sm极限捆绑bd| 久久综合精品国产一区二区三区| 精品久久五月天| 日韩一级高清毛片| 日韩女优电影在线观看| 欧美不卡视频一区| 久久综合九色欧美综合狠狠| 国产ts人妖一区二区| 国产不卡视频在线播放| 成人黄色av网站在线| 成人av在线播放网站| 在线观看av一区二区| 精品日韩av一区二区| 久久综合九色综合欧美98| 欧美第一区第二区| 国产丝袜欧美中文另类| 国产亚洲成年网址在线观看| 精品成人一区二区| 国产精品全国免费观看高清| 中文字幕在线不卡国产视频| 久久综合狠狠综合久久激情| 欧美日韩国产高清一区二区三区| 欧美日韩国产a| 欧美日韩www| 欧美群妇大交群中文字幕| 日韩一级二级三级精品视频| 欧美日韩国产免费一区二区| 91精品国产欧美一区二区18| 免费看日韩精品| 亚洲精品视频在线看| 亚洲成人免费看| 久久国产三级精品| va亚洲va日韩不卡在线观看| 欧美精品久久一区| 欧美变态口味重另类| 精品欧美一区二区在线观看| 国产精品久久久久婷婷| 亚洲成人av电影在线| av电影天堂一区二区在线| 在线观看91精品国产入口| 91在线国产福利| 精品久久国产字幕高潮| 亚洲香肠在线观看| 丁香啪啪综合成人亚洲小说 | 免费成人你懂的| 99久久综合国产精品| 久久久av毛片精品| 日韩精品乱码av一区二区| 在线看一区二区| 亚洲激情网站免费观看| 96av麻豆蜜桃一区二区| 国产欧美日韩卡一| 久久成人免费电影| www国产精品av| 国产精品国产精品国产专区不蜜| 成人欧美一区二区三区在线播放| 精品一区二区在线免费观看| 国产精品久久久久毛片软件| 亚洲宅男天堂在线观看无病毒| 日本vs亚洲vs韩国一区三区| 欧美日韩在线观看一区二区 | 一区二区成人在线视频| 成人avav在线| 亚洲精品高清在线| 日韩精品中文字幕在线不卡尤物| 国产精品国产自产拍高清av王其| 成人午夜伦理影院| 亚洲柠檬福利资源导航| 日韩欧美国产三级电影视频| 国产电影一区在线| 国产精品久久久久永久免费观看| 99re66热这里只有精品3直播 | 欧洲精品视频在线观看| 日韩影院免费视频| 国产精品久久久久影视| 91视频在线看| 美美哒免费高清在线观看视频一区二区 | 色婷婷综合久久久久中文一区二区 | 久久爱www久久做| 亚洲综合免费观看高清完整版在线 | 国产乱一区二区| 丝袜亚洲另类欧美| 亚洲最大的成人av| 91麻豆精品国产自产在线| 男女男精品视频网| 亚洲成人福利片| 欧美精品一区视频| 91久久免费观看| 日本在线不卡一区| 亚洲成av人片在www色猫咪| 日韩理论片在线| 久久久久久9999| 日韩三级视频中文字幕| 欧美日韩国产精品成人| 欧美一区二区三区视频在线| 在线观看国产日韩| 在线观看免费一区| 欧美午夜精品一区| 色婷婷国产精品综合在线观看| 国产大陆a不卡| 国产成人精品免费| 91免费视频网址| 一本久久综合亚洲鲁鲁五月天| 欧洲一区二区三区免费视频| 日韩精品专区在线| 欧美人与禽zozo性伦| 亚洲精品在线电影| 日韩美女天天操| 精品入口麻豆88视频| 欧美日韩亚洲综合一区二区三区| 欧美剧情电影在线观看完整版免费励志电影| aaa欧美大片| 日韩一区二区在线看片| 日韩一区二区免费电影| 日韩一区中文字幕|