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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? hci_usb.c

?? 嵌入式Linux的藍牙模塊驅動
?? C
?? 第 1 頁 / 共 2 頁
字號:
/*    HCI USB driver for Linux Bluetooth protocol stack (BlueZ)   Copyright (C) 2000-2001 Qualcomm Incorporated   Written 2000,2001 by Maxim Krasnyansky <maxk@qualcomm.com>   Copyright (C) 2003 Maxim Krasnyansky <maxk@qualcomm.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.*//* * Bluetooth HCI USB driver. * Based on original USB Bluetooth driver for Linux kernel *    Copyright (c) 2000 Greg Kroah-Hartman        <greg@kroah.com> *    Copyright (c) 2000 Mark Douglas Corner       <mcorner@umich.edu> * */#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/sched.h>#include <linux/unistd.h>#include <linux/types.h>#include <linux/interrupt.h>#include <linux/slab.h>#include <linux/errno.h>#include <linux/string.h>#include <linux/skbuff.h>#include <linux/usb.h>#include <net/bluetooth/bluetooth.h>#include <net/bluetooth/hci_core.h>#include "hci_usb.h"#ifndef CONFIG_BT_HCIUSB_DEBUG#undef  BT_DBG#define BT_DBG(D...)#undef  BT_DMP#define BT_DMP(D...)#endif#ifndef CONFIG_BT_HCIUSB_ZERO_PACKET#undef  URB_ZERO_PACKET#define URB_ZERO_PACKET 0#endif#define VERSION "2.7"static struct usb_driver hci_usb_driver; static struct usb_device_id bluetooth_ids[] = {	/* Generic Bluetooth USB device */	{ USB_DEVICE_INFO(HCI_DEV_CLASS, HCI_DEV_SUBCLASS, HCI_DEV_PROTOCOL) },	/* AVM BlueFRITZ! USB v2.0 */	{ USB_DEVICE(0x057c, 0x3800) },	/* Bluetooth Ultraport Module from IBM */	{ USB_DEVICE(0x04bf, 0x030a) },	/* ALPS Modules with non-standard id */	{ USB_DEVICE(0x044e, 0x3001) },	{ USB_DEVICE(0x044e, 0x3002) },	/* Ericsson with non-standard id */	{ USB_DEVICE(0x0bdb, 0x1002) },	{ }	/* Terminating entry */};MODULE_DEVICE_TABLE (usb, bluetooth_ids);static struct usb_device_id blacklist_ids[] = {	/* Broadcom BCM2033 without firmware */	{ USB_DEVICE(0x0a5c, 0x2033), .driver_info = HCI_IGNORE },	/* Broadcom BCM2035 */	{ USB_DEVICE(0x0a5c, 0x200a), .driver_info = HCI_RESET },	/* ISSC Bluetooth Adapter v3.1 */	{ USB_DEVICE(0x1131, 0x1001), .driver_info = HCI_RESET },	/* Digianswer device */	{ USB_DEVICE(0x08fd, 0x0001), .driver_info = HCI_DIGIANSWER },	/* RTX Telecom based adapter with buggy SCO support */	{ USB_DEVICE(0x0400, 0x0807), .driver_info = HCI_BROKEN_ISOC },	{ }	/* Terminating entry */};struct _urb *_urb_alloc(int isoc, int gfp){	struct _urb *_urb = kmalloc(sizeof(struct _urb) +				sizeof(struct usb_iso_packet_descriptor) * isoc, gfp);	if (_urb) {		memset(_urb, 0, sizeof(*_urb));		usb_init_urb(&_urb->urb);	}	return _urb;}struct _urb *_urb_dequeue(struct _urb_queue *q){	struct _urb *_urb = NULL;	unsigned long flags;	spin_lock_irqsave(&q->lock, flags);	{		struct list_head *head = &q->head;		struct list_head *next = head->next;		if (next != head) {			_urb = list_entry(next, struct _urb, list);			list_del(next); _urb->queue = NULL;		}	}	spin_unlock_irqrestore(&q->lock, flags);	return _urb;}static void hci_usb_rx_complete(struct urb *urb, struct pt_regs *regs);static void hci_usb_tx_complete(struct urb *urb, struct pt_regs *regs);#define __pending_tx(husb, type)  (&husb->pending_tx[type-1])#define __pending_q(husb, type)   (&husb->pending_q[type-1])#define __completed_q(husb, type) (&husb->completed_q[type-1])#define __transmit_q(husb, type)  (&husb->transmit_q[type-1])#define __reassembly(husb, type)  (husb->reassembly[type-1])static inline struct _urb *__get_completed(struct hci_usb *husb, int type){	return _urb_dequeue(__completed_q(husb, type)); }#ifdef CONFIG_BT_HCIUSB_SCOstatic void __fill_isoc_desc(struct urb *urb, int len, int mtu){	int offset = 0, i;	BT_DBG("len %d mtu %d", len, mtu);	for (i=0; i < HCI_MAX_ISOC_FRAMES && len >= mtu; i++, offset += mtu, len -= mtu) {		urb->iso_frame_desc[i].offset = offset;		urb->iso_frame_desc[i].length = mtu;		BT_DBG("desc %d offset %d len %d", i, offset, mtu);	}	if (len && i < HCI_MAX_ISOC_FRAMES) {		urb->iso_frame_desc[i].offset = offset;		urb->iso_frame_desc[i].length = len;		BT_DBG("desc %d offset %d len %d", i, offset, len);		i++;	}	urb->number_of_packets = i;}#endifstatic int hci_usb_intr_rx_submit(struct hci_usb *husb){	struct _urb *_urb;	struct urb *urb;	int err, pipe, interval, size;	void *buf;	BT_DBG("%s", husb->hdev->name);	size = husb->intr_in_ep->desc.wMaxPacketSize;	buf = kmalloc(size, GFP_ATOMIC);	if (!buf)		return -ENOMEM;	_urb = _urb_alloc(0, GFP_ATOMIC);	if (!_urb) {		kfree(buf);		return -ENOMEM;	}	_urb->type = HCI_EVENT_PKT;	_urb_queue_tail(__pending_q(husb, _urb->type), _urb);	urb = &_urb->urb;	pipe     = usb_rcvintpipe(husb->udev, husb->intr_in_ep->desc.bEndpointAddress);	interval = husb->intr_in_ep->desc.bInterval;	usb_fill_int_urb(urb, husb->udev, pipe, buf, size, hci_usb_rx_complete, husb, interval);		err = usb_submit_urb(urb, GFP_ATOMIC);	if (err) {		BT_ERR("%s intr rx submit failed urb %p err %d",				husb->hdev->name, urb, err);		_urb_unlink(_urb);		_urb_free(_urb);		kfree(buf);	}	return err;}static int hci_usb_bulk_rx_submit(struct hci_usb *husb){	struct _urb *_urb;	struct urb *urb;	int err, pipe, size = HCI_MAX_FRAME_SIZE;	void *buf;	buf = kmalloc(size, GFP_ATOMIC);	if (!buf)		return -ENOMEM;	_urb = _urb_alloc(0, GFP_ATOMIC);	if (!_urb) {		kfree(buf);		return -ENOMEM;	}	_urb->type = HCI_ACLDATA_PKT;	_urb_queue_tail(__pending_q(husb, _urb->type), _urb);	urb  = &_urb->urb;	pipe = usb_rcvbulkpipe(husb->udev, husb->bulk_in_ep->desc.bEndpointAddress);	usb_fill_bulk_urb(urb, husb->udev, pipe, buf, size, hci_usb_rx_complete, husb);	urb->transfer_flags = 0;	BT_DBG("%s urb %p", husb->hdev->name, urb);	err = usb_submit_urb(urb, GFP_ATOMIC);	if (err) {		BT_ERR("%s bulk rx submit failed urb %p err %d",				husb->hdev->name, urb, err);		_urb_unlink(_urb);		_urb_free(_urb);		kfree(buf);	}	return err;}#ifdef CONFIG_BT_HCIUSB_SCOstatic int hci_usb_isoc_rx_submit(struct hci_usb *husb){	struct _urb *_urb;	struct urb *urb;	int err, mtu, size;	void *buf;	mtu  = husb->isoc_in_ep->desc.wMaxPacketSize;	size = mtu * HCI_MAX_ISOC_FRAMES;	buf = kmalloc(size, GFP_ATOMIC);	if (!buf)		return -ENOMEM;	_urb = _urb_alloc(HCI_MAX_ISOC_FRAMES, GFP_ATOMIC);	if (!_urb) {		kfree(buf);		return -ENOMEM;	}	_urb->type = HCI_SCODATA_PKT;	_urb_queue_tail(__pending_q(husb, _urb->type), _urb);	urb = &_urb->urb;	urb->context  = husb;	urb->dev      = husb->udev;	urb->pipe     = usb_rcvisocpipe(husb->udev, husb->isoc_in_ep->desc.bEndpointAddress);	urb->complete = hci_usb_rx_complete;	urb->interval = husb->isoc_in_ep->desc.bInterval;	urb->transfer_buffer_length = size;	urb->transfer_buffer = buf;	urb->transfer_flags  = URB_ISO_ASAP;	__fill_isoc_desc(urb, size, mtu);	BT_DBG("%s urb %p", husb->hdev->name, urb);	err = usb_submit_urb(urb, GFP_ATOMIC);	if (err) {		BT_ERR("%s isoc rx submit failed urb %p err %d",				husb->hdev->name, urb, err);		_urb_unlink(_urb);		_urb_free(_urb);		kfree(buf);	}	return err;}#endif/* Initialize device */static int hci_usb_open(struct hci_dev *hdev){	struct hci_usb *husb = (struct hci_usb *) hdev->driver_data;	int i, err;	unsigned long flags;	BT_DBG("%s", hdev->name);	if (test_and_set_bit(HCI_RUNNING, &hdev->flags))		return 0;	write_lock_irqsave(&husb->completion_lock, flags);	err = hci_usb_intr_rx_submit(husb);	if (!err) {		for (i = 0; i < HCI_MAX_BULK_RX; i++)			hci_usb_bulk_rx_submit(husb);#ifdef CONFIG_BT_HCIUSB_SCO		if (husb->isoc_iface)			for (i = 0; i < HCI_MAX_ISOC_RX; i++)				hci_usb_isoc_rx_submit(husb);#endif	} else {		clear_bit(HCI_RUNNING, &hdev->flags);	}	write_unlock_irqrestore(&husb->completion_lock, flags);	return err;}/* Reset device */static int hci_usb_flush(struct hci_dev *hdev){	struct hci_usb *husb = (struct hci_usb *) hdev->driver_data;	int i;	BT_DBG("%s", hdev->name);	for (i = 0; i < 4; i++)		skb_queue_purge(&husb->transmit_q[i]);	return 0;}static void hci_usb_unlink_urbs(struct hci_usb *husb){	int i;	BT_DBG("%s", husb->hdev->name);	for (i = 0; i < 4; i++) {		struct _urb *_urb;		struct urb *urb;		/* Kill pending requests */		while ((_urb = _urb_dequeue(&husb->pending_q[i]))) {			urb = &_urb->urb;			BT_DBG("%s unlinking _urb %p type %d urb %p", 					husb->hdev->name, _urb, _urb->type, urb);			usb_kill_urb(urb);			_urb_queue_tail(__completed_q(husb, _urb->type), _urb);		}		/* Release completed requests */		while ((_urb = _urb_dequeue(&husb->completed_q[i]))) {			urb = &_urb->urb;			BT_DBG("%s freeing _urb %p type %d urb %p",					husb->hdev->name, _urb, _urb->type, urb);			if (urb->setup_packet)				kfree(urb->setup_packet);			if (urb->transfer_buffer)				kfree(urb->transfer_buffer);			_urb_free(_urb);		}		/* Release reassembly buffers */		if (husb->reassembly[i]) {			kfree_skb(husb->reassembly[i]);			husb->reassembly[i] = NULL;		}	}}/* Close device */static int hci_usb_close(struct hci_dev *hdev){	struct hci_usb *husb = (struct hci_usb *) hdev->driver_data;	unsigned long flags;	if (!test_and_clear_bit(HCI_RUNNING, &hdev->flags))		return 0;	BT_DBG("%s", hdev->name);	/* Synchronize with completion handlers */	write_lock_irqsave(&husb->completion_lock, flags);	write_unlock_irqrestore(&husb->completion_lock, flags);	hci_usb_unlink_urbs(husb);	hci_usb_flush(hdev);	return 0;}static int __tx_submit(struct hci_usb *husb, struct _urb *_urb){	struct urb *urb = &_urb->urb;	int err;	BT_DBG("%s urb %p type %d", husb->hdev->name, urb, _urb->type);	_urb_queue_tail(__pending_q(husb, _urb->type), _urb);	err = usb_submit_urb(urb, GFP_ATOMIC);	if (err) {		BT_ERR("%s tx submit failed urb %p type %d err %d",				husb->hdev->name, urb, _urb->type, err);		_urb_unlink(_urb);		_urb_queue_tail(__completed_q(husb, _urb->type), _urb);	} else		atomic_inc(__pending_tx(husb, _urb->type));	return err;}static inline int hci_usb_send_ctrl(struct hci_usb *husb, struct sk_buff *skb){	struct _urb *_urb = __get_completed(husb, skb->pkt_type);	struct usb_ctrlrequest *dr;	struct urb *urb;	if (!_urb) {		_urb = _urb_alloc(0, GFP_ATOMIC);		if (!_urb)			return -ENOMEM;		_urb->type = skb->pkt_type;		dr = kmalloc(sizeof(*dr), GFP_ATOMIC);		if (!dr) {			_urb_free(_urb);			return -ENOMEM;		}	} else		dr = (void *) _urb->urb.setup_packet;	dr->bRequestType = husb->ctrl_req;	dr->bRequest = 0;	dr->wIndex   = 0;	dr->wValue   = 0;	dr->wLength  = __cpu_to_le16(skb->len);	urb = &_urb->urb;	usb_fill_control_urb(urb, husb->udev, usb_sndctrlpipe(husb->udev, 0),		(void *) dr, skb->data, skb->len, hci_usb_tx_complete, husb);	BT_DBG("%s skb %p len %d", husb->hdev->name, skb, skb->len);		_urb->priv = skb;	return __tx_submit(husb, _urb);}static inline int hci_usb_send_bulk(struct hci_usb *husb, struct sk_buff *skb){	struct _urb *_urb = __get_completed(husb, skb->pkt_type);	struct urb *urb;	int pipe;	if (!_urb) {		_urb = _urb_alloc(0, GFP_ATOMIC);		if (!_urb)			return -ENOMEM;		_urb->type = skb->pkt_type;	}	urb  = &_urb->urb;	pipe = usb_sndbulkpipe(husb->udev, husb->bulk_out_ep->desc.bEndpointAddress);	usb_fill_bulk_urb(urb, husb->udev, pipe, skb->data, skb->len, 			hci_usb_tx_complete, husb);	urb->transfer_flags = URB_ZERO_PACKET;	BT_DBG("%s skb %p len %d", husb->hdev->name, skb, skb->len);	_urb->priv = skb;	return __tx_submit(husb, _urb);}#ifdef CONFIG_BT_HCIUSB_SCOstatic inline int hci_usb_send_isoc(struct hci_usb *husb, struct sk_buff *skb){	struct _urb *_urb = __get_completed(husb, skb->pkt_type);	struct urb *urb;	if (!_urb) {		_urb = _urb_alloc(HCI_MAX_ISOC_FRAMES, GFP_ATOMIC);		if (!_urb)			return -ENOMEM;		_urb->type = skb->pkt_type;	}	BT_DBG("%s skb %p len %d", husb->hdev->name, skb, skb->len);	urb = &_urb->urb;	urb->context  = husb;	urb->dev      = husb->udev;	urb->pipe     = usb_sndisocpipe(husb->udev, husb->isoc_out_ep->desc.bEndpointAddress);	urb->complete = hci_usb_tx_complete;	urb->transfer_flags = URB_ISO_ASAP;	urb->interval = husb->isoc_out_ep->desc.bInterval;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
2020国产精品| 琪琪久久久久日韩精品| 午夜视频在线观看一区| 九九九精品视频| 欧美综合天天夜夜久久| 亚洲国产成人在线| 久久精品国产在热久久| 欧美色图免费看| 中文字幕一区二区三区不卡| 日本91福利区| 欧美久久一区二区| 亚洲日本va在线观看| 国产一区二区三区不卡在线观看| 欧美日韩一区国产| 一卡二卡欧美日韩| av在线一区二区| 中文字幕欧美激情一区| 国内一区二区视频| 精品国产a毛片| 蜜臀av性久久久久蜜臀av麻豆| 欧美网站大全在线观看| 亚洲特黄一级片| 99re热这里只有精品免费视频| 久久女同精品一区二区| 精品一区二区国语对白| 日韩亚洲欧美高清| 捆绑变态av一区二区三区| 91麻豆精品国产自产在线观看一区 | 99视频有精品| 日韩一区中文字幕| 成人开心网精品视频| 国产精品麻豆久久久| 国产凹凸在线观看一区二区| 久久久久久一二三区| 国产精品一二三四| 亚洲国产激情av| 91性感美女视频| 一区二区三区蜜桃网| 欧美日韩亚洲综合在线 欧美亚洲特黄一级| 中文字幕一区二| 色婷婷国产精品综合在线观看| 最新热久久免费视频| 色94色欧美sute亚洲线路一久| 亚洲乱码国产乱码精品精可以看| 91久久精品午夜一区二区| 亚洲综合成人在线视频| 欧美日韩一区国产| 狠狠色综合播放一区二区| 久久精品人人做| 91麻豆免费看片| 污片在线观看一区二区| 精品99久久久久久| www.欧美.com| 亚洲成精国产精品女| 日韩一级二级三级精品视频| 极品美女销魂一区二区三区免费| 久久久久久免费网| 91丨porny丨蝌蚪视频| 亚洲福中文字幕伊人影院| 日韩欧美国产精品| 成人免费毛片片v| 亚洲福利一区二区| 久久久国产精品不卡| 91色porny蝌蚪| 久久精品国内一区二区三区| 国产精品美女久久福利网站| 欧美日韩中文精品| 国产精品一区在线观看你懂的| 亚洲欧洲av色图| 日韩三区在线观看| 99久久精品情趣| 精品午夜一区二区三区在线观看| 《视频一区视频二区| 欧美一区二区三区系列电影| 成人综合在线观看| 奇米色777欧美一区二区| 国产精品欧美久久久久一区二区| 欧美剧在线免费观看网站| 成人少妇影院yyyy| 麻豆成人久久精品二区三区小说| 亚洲天堂精品视频| 久久精品人人做人人综合| 欧美日韩亚洲另类| 99国产欧美久久久精品| 激情伊人五月天久久综合| 亚洲成人精品一区二区| 国产精品久久久久四虎| 精品国产乱码久久| 欧美剧情片在线观看| 日本丶国产丶欧美色综合| 国产一区二三区| 蜜臀a∨国产成人精品| 亚洲成人免费视频| 亚洲精品视频观看| 中文字幕一区二区三区蜜月| 久久综合狠狠综合| 欧美变态口味重另类| 欧美高清hd18日本| 欧美三级日韩在线| 欧洲亚洲国产日韩| 91美女在线观看| 99国产一区二区三精品乱码| 国产一二精品视频| 精品一二三四区| 麻豆精品视频在线观看免费| 日本在线播放一区二区三区| 亚洲高清视频的网址| 亚洲二区在线视频| 亚洲成人福利片| 午夜精品久久久久久久99樱桃| 一区二区三区精品视频| 亚洲免费观看视频| 亚洲精品老司机| 亚洲综合在线电影| 一区二区在线看| 亚洲一区二区三区三| 亚洲在线视频网站| 亚洲成人一区二区在线观看| 肉色丝袜一区二区| 欧美aa在线视频| 国产一区二区三区最好精华液| 国模无码大尺度一区二区三区| 韩国精品主播一区二区在线观看| 狠狠久久亚洲欧美| 国产成a人无v码亚洲福利| 成人午夜电影网站| 色呦呦网站一区| 欧美少妇性性性| 91精品国产综合久久精品 | 激情av综合网| 亚洲电影一级片| 天天综合天天综合色| 香蕉久久一区二区不卡无毒影院| 五月天国产精品| 免费观看30秒视频久久| 韩国精品久久久| 99国产精品久久久久| 色94色欧美sute亚洲线路一ni| 欧美三级中文字幕在线观看| 在线成人av网站| 久久久欧美精品sm网站| 国产精品成人网| 亚洲电影一区二区三区| 久久国产三级精品| 成a人片亚洲日本久久| 欧美日韩成人一区| 国产欧美一区二区三区沐欲 | 成人黄色大片在线观看| 在线观看欧美精品| 精品国产一区二区精华| 国产精品成人一区二区三区夜夜夜| 亚洲成av人片在线观看无码| 国产一区欧美一区| 欧美日韩一区三区四区| 久久九九久久九九| 亚洲风情在线资源站| 高清不卡在线观看| 欧美精品日韩精品| 国产精品久久网站| 美国三级日本三级久久99| av不卡一区二区三区| 日韩三级在线观看| 一区二区日韩av| 福利一区二区在线| 欧美乱熟臀69xxxxxx| 国产精品久久久久永久免费观看 | 2022国产精品视频| 一区二区三区在线免费观看| 国产综合色视频| 欧美肥妇bbw| 亚洲色图欧美在线| 国产高清亚洲一区| 日韩丝袜美女视频| 亚洲小说春色综合另类电影| 成人免费三级在线| 久久久久国产精品人| 日本欧洲一区二区| 欧美亚洲综合色| 亚洲人成网站影音先锋播放| 国内外成人在线| 欧美一区二区黄色| 五月婷婷久久丁香| 色999日韩国产欧美一区二区| 中文字幕av资源一区| 精品一二三四区| 久久青草国产手机看片福利盒子| 日本最新不卡在线| 欧美日韩夫妻久久| 亚洲国产wwwccc36天堂| 日本高清无吗v一区| 亚洲丝袜制服诱惑| 波多野洁衣一区| 国产精品久久看| a级高清视频欧美日韩| 中文字幕av一区二区三区免费看 | 91麻豆免费在线观看| 中文字幕成人av| 丁香一区二区三区| 国产精品欧美综合在线| proumb性欧美在线观看|