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

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

?? btuart.c

?? 基于arm的藍(lán)牙通訊協(xié)議的設(shè)計(jì)
?? C
?? 第 1 頁(yè) / 共 2 頁(yè)
字號(hào):
/* * *  Driver for Bluetooth PCMCIA cards with HCI UART interface * * */#include <linux/config.h>#include <linux/module.h>#include <linux/kernel.h>#include <linux/init.h>#include <linux/slab.h>#include <linux/types.h>#include <linux/sched.h>#include <linux/timer.h>#include <linux/errno.h>#include <linux/ptrace.h>#include <linux/ioport.h>#include <linux/spinlock.h>#include <linux/skbuff.h>#include <linux/string.h>#include <linux/serial.h>#include <linux/serial_reg.h>#include <asm/system.h>#include <asm/bitops.h>#include <asm/io.h>#include <pcmcia/version.h>#include <pcmcia/cs_types.h>#include <pcmcia/cs.h>#include <pcmcia/cistpl.h>#include <pcmcia/ciscode.h>#include <pcmcia/ds.h>#include <pcmcia/cisreg.h>#include <net/bluetooth/bluetooth.h>#include <net/bluetooth/hci_core.h>/* ======================== Module parameters ======================== *//* Bit map of interrupts to choose from */static u_int irq_mask = 0xffff;static int irq_list[4] = { -1 };MODULE_PARM(irq_mask, "i");MODULE_PARM(irq_list, "1-4i");MODULE_AUTHOR("Marcel Holtmann <marcel@holtmann.org>");MODULE_DESCRIPTION("BlueZ driver for Bluetooth PCMCIA cards with HCI UART interface");MODULE_LICENSE("GPL");/* ======================== Local structures ======================== */typedef struct btuart_info_t {	dev_link_t link;	dev_node_t node;	struct hci_dev hdev;	spinlock_t lock;	/* For serializing operations */	struct sk_buff_head txq;	unsigned long tx_state;	unsigned long rx_state;	unsigned long rx_count;	struct sk_buff *rx_skb;} btuart_info_t;void btuart_config(dev_link_t *link);void btuart_release(u_long arg);int btuart_event(event_t event, int priority, event_callback_args_t *args);static dev_info_t dev_info = "btuart_cs";dev_link_t *btuart_attach(void);void btuart_detach(dev_link_t *);static dev_link_t *dev_list = NULL;/* Maximum baud rate */#define SPEED_MAX  115200/* Default baud rate: 57600, 115200, 230400 or 460800 */#define DEFAULT_BAUD_RATE  115200/* Transmit states  */#define XMIT_SENDING	1#define XMIT_WAKEUP	2#define XMIT_WAITING	8/* Receiver states */#define RECV_WAIT_PACKET_TYPE	0#define RECV_WAIT_EVENT_HEADER	1#define RECV_WAIT_ACL_HEADER	2#define RECV_WAIT_SCO_HEADER	3#define RECV_WAIT_DATA		4/* ======================== Interrupt handling ======================== */static int btuart_write(unsigned int iobase, int fifo_size, __u8 *buf, int len){	int actual = 0;	/* Tx FIFO should be empty */	if (!(inb(iobase + UART_LSR) & UART_LSR_THRE))		return 0;	/* Fill FIFO with current frame */	while ((fifo_size-- > 0) && (actual < len)) {		/* Transmit next byte */		outb(buf[actual], iobase + UART_TX);		actual++;	}	return actual;}static void btuart_write_wakeup(btuart_info_t *info){	if (!info) {		printk(KERN_WARNING "btuart_cs: Call of write_wakeup for unknown device.\n");		return;	}	if (test_and_set_bit(XMIT_SENDING, &(info->tx_state))) {		set_bit(XMIT_WAKEUP, &(info->tx_state));		return;	}	do {		register unsigned int iobase = info->link.io.BasePort1;		register struct sk_buff *skb;		register int len;		clear_bit(XMIT_WAKEUP, &(info->tx_state));		if (!(info->link.state & DEV_PRESENT))			return;		if (!(skb = skb_dequeue(&(info->txq))))			break;		/* Send frame */		len = btuart_write(iobase, 16, skb->data, skb->len);		set_bit(XMIT_WAKEUP, &(info->tx_state));		if (len == skb->len) {			kfree_skb(skb);		} else {			skb_pull(skb, len);			skb_queue_head(&(info->txq), skb);		}		info->hdev.stat.byte_tx += len;	} while (test_bit(XMIT_WAKEUP, &(info->tx_state)));	clear_bit(XMIT_SENDING, &(info->tx_state));}static void btuart_receive(btuart_info_t *info){	unsigned int iobase;	int boguscount = 0;	if (!info) {		printk(KERN_WARNING "btuart_cs: Call of receive for unknown device.\n");		return;	}	iobase = info->link.io.BasePort1;	do {		info->hdev.stat.byte_rx++;		/* Allocate packet */		if (info->rx_skb == NULL) {			info->rx_state = RECV_WAIT_PACKET_TYPE;			info->rx_count = 0;			if (!(info->rx_skb = bluez_skb_alloc(HCI_MAX_FRAME_SIZE, GFP_ATOMIC))) {				printk(KERN_WARNING "btuart_cs: Can't allocate mem for new packet.\n");				return;			}		}		if (info->rx_state == RECV_WAIT_PACKET_TYPE) {			info->rx_skb->dev = (void *)&(info->hdev);			info->rx_skb->pkt_type = inb(iobase + UART_RX);			switch (info->rx_skb->pkt_type) {			case HCI_EVENT_PKT:				info->rx_state = RECV_WAIT_EVENT_HEADER;				info->rx_count = HCI_EVENT_HDR_SIZE;				break;			case HCI_ACLDATA_PKT:				info->rx_state = RECV_WAIT_ACL_HEADER;				info->rx_count = HCI_ACL_HDR_SIZE;				break;			case HCI_SCODATA_PKT:				info->rx_state = RECV_WAIT_SCO_HEADER;				info->rx_count = HCI_SCO_HDR_SIZE;				break;			default:				/* Unknown packet */				printk(KERN_WARNING "btuart_cs: Unknown HCI packet with type 0x%02x received.\n", info->rx_skb->pkt_type);				info->hdev.stat.err_rx++;				clear_bit(HCI_RUNNING, &(info->hdev.flags));				kfree_skb(info->rx_skb);				info->rx_skb = NULL;				break;			}		} else {			*skb_put(info->rx_skb, 1) = inb(iobase + UART_RX);			info->rx_count--;			if (info->rx_count == 0) {				int dlen;				hci_event_hdr *eh;				hci_acl_hdr *ah;				hci_sco_hdr *sh;				switch (info->rx_state) {				case RECV_WAIT_EVENT_HEADER:					eh = (hci_event_hdr *)(info->rx_skb->data);					info->rx_state = RECV_WAIT_DATA;					info->rx_count = eh->plen;					break;				case RECV_WAIT_ACL_HEADER:					ah = (hci_acl_hdr *)(info->rx_skb->data);					dlen = __le16_to_cpu(ah->dlen);					info->rx_state = RECV_WAIT_DATA;					info->rx_count = dlen;					break;				case RECV_WAIT_SCO_HEADER:					sh = (hci_sco_hdr *)(info->rx_skb->data);					info->rx_state = RECV_WAIT_DATA;					info->rx_count = sh->dlen;					break;				case RECV_WAIT_DATA:					hci_recv_frame(info->rx_skb);					info->rx_skb = NULL;					break;				}			}		}		/* Make sure we don't stay here to long */		if (boguscount++ > 16)			break;	} while (inb(iobase + UART_LSR) & UART_LSR_DR);}void btuart_interrupt(int irq, void *dev_inst, struct pt_regs *regs){	btuart_info_t *info = dev_inst;	unsigned int iobase;	int boguscount = 0;	int iir, lsr;	if (!info) {		printk(KERN_WARNING "btuart_cs: Call of irq %d for unknown device.\n", irq);		return;	}	iobase = info->link.io.BasePort1;	spin_lock(&(info->lock));	iir = inb(iobase + UART_IIR) & UART_IIR_ID;	while (iir) {		/* Clear interrupt */		lsr = inb(iobase + UART_LSR);		switch (iir) {		case UART_IIR_RLSI:			printk(KERN_NOTICE "btuart_cs: RLSI\n");			break;		case UART_IIR_RDI:			/* Receive interrupt */			btuart_receive(info);			break;		case UART_IIR_THRI:			if (lsr & UART_LSR_THRE) {				/* Transmitter ready for data */				btuart_write_wakeup(info);			}			break;		default:			printk(KERN_NOTICE "btuart_cs: Unhandled IIR=%#x\n", iir);			break;		}		/* Make sure we don't stay here to long */		if (boguscount++ > 100)			break;		iir = inb(iobase + UART_IIR) & UART_IIR_ID;	}	spin_unlock(&(info->lock));}static void btuart_change_speed(btuart_info_t *info, unsigned int speed){	unsigned long flags;	unsigned int iobase;	int fcr;		/* FIFO control reg */	int lcr;		/* Line control reg */	int divisor;	if (!info) {		printk(KERN_WARNING "btuart_cs: Call of change speed for unknown device.\n");		return;	}	iobase = info->link.io.BasePort1;	spin_lock_irqsave(&(info->lock), flags);	/* Turn off interrupts */	outb(0, iobase + UART_IER);	divisor = SPEED_MAX / speed;	fcr = UART_FCR_ENABLE_FIFO | UART_FCR_CLEAR_RCVR | UART_FCR_CLEAR_XMIT;	/* 	 * Use trigger level 1 to avoid 3 ms. timeout delay at 9600 bps, and	 * almost 1,7 ms at 19200 bps. At speeds above that we can just forget	 * about this timeout since it will always be fast enough. 	 */	if (speed < 38400)		fcr |= UART_FCR_TRIGGER_1;	else		fcr |= UART_FCR_TRIGGER_14;	/* Bluetooth cards use 8N1 */	lcr = UART_LCR_WLEN8;	outb(UART_LCR_DLAB | lcr, iobase + UART_LCR);	/* Set DLAB */	outb(divisor & 0xff, iobase + UART_DLL);	/* Set speed */	outb(divisor >> 8, iobase + UART_DLM);	outb(lcr, iobase + UART_LCR);	/* Set 8N1  */	outb(fcr, iobase + UART_FCR);	/* Enable FIFO's */	/* Turn on interrups */	outb(UART_IER_RLSI | UART_IER_RDI | UART_IER_THRI, iobase + UART_IER);	spin_unlock_irqrestore(&(info->lock), flags);}/* ======================== HCI interface ======================== */static int btuart_hci_flush(struct hci_dev *hdev){	btuart_info_t *info = (btuart_info_t *)(hdev->driver_data);	/* Drop TX queue */	skb_queue_purge(&(info->txq));	return 0;}static int btuart_hci_open(struct hci_dev *hdev){	set_bit(HCI_RUNNING, &(hdev->flags));	return 0;}static int btuart_hci_close(struct hci_dev *hdev){	if (!test_and_clear_bit(HCI_RUNNING, &(hdev->flags)))		return 0;	btuart_hci_flush(hdev);	return 0;}static int btuart_hci_send_frame(struct sk_buff *skb){	btuart_info_t *info;	struct hci_dev *hdev = (struct hci_dev *)(skb->dev);	if (!hdev) {		printk(KERN_WARNING "btuart_cs: Frame for unknown HCI device (hdev=NULL).");		return -ENODEV;	}	info = (btuart_info_t *)(hdev->driver_data);	switch (skb->pkt_type) {	case HCI_COMMAND_PKT:		hdev->stat.cmd_tx++;		break;	case HCI_ACLDATA_PKT:		hdev->stat.acl_tx++;		break;	case HCI_SCODATA_PKT:		hdev->stat.sco_tx++;

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品夜夜夜夜久久| 欧美一区二区三区视频在线| 视频一区二区三区入口| 久久久91精品国产一区二区精品| 在线视频你懂得一区二区三区| 欧美精品免费视频| av一区二区三区| 国模一区二区三区白浆| 水野朝阳av一区二区三区| 国产精品看片你懂得| 精品国产sm最大网站免费看| 欧美午夜精品一区二区蜜桃| 成人自拍视频在线观看| 九色porny丨国产精品| 亚洲成人7777| 亚洲猫色日本管| 亚洲国产精华液网站w| 久久这里都是精品| 欧美一区2区视频在线观看| 一本一道综合狠狠老| 成人av在线一区二区| 久久99精品久久久久久国产越南| 香蕉加勒比综合久久| 一区二区三区不卡视频在线观看 | 性欧美大战久久久久久久久| 国产精品久久久久久久久果冻传媒| 欧美成va人片在线观看| 91精品国产综合久久久蜜臀图片| 日本高清不卡视频| 色婷婷精品久久二区二区蜜臂av| 国产成人av电影在线| 国产精品18久久久久久久久久久久 | 老鸭窝一区二区久久精品| 午夜精品福利久久久| 亚洲成a人v欧美综合天堂| 亚洲最新在线观看| 亚洲宅男天堂在线观看无病毒| 亚洲人精品一区| 亚洲私人黄色宅男| 亚洲精品乱码久久久久久| 亚洲欧洲中文日韩久久av乱码| 国产精品免费看片| 1区2区3区欧美| 一区二区三区免费网站| 亚洲激情图片小说视频| 亚洲午夜免费电影| 亚洲成va人在线观看| 日韩va欧美va亚洲va久久| 免费xxxx性欧美18vr| 久久99久久99| 国产**成人网毛片九色 | 欧洲精品在线观看| 欧美日韩久久不卡| 91精品国产免费| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 蜜臀av一区二区在线免费观看| 在线播放亚洲一区| 欧美一级在线视频| 欧美精品一区二区三区高清aⅴ| 久久色在线观看| 中文字幕精品在线不卡| 亚洲美女精品一区| 视频一区欧美精品| 国产一区在线视频| 99在线视频精品| 欧美日韩国产欧美日美国产精品| 日韩欧美国产一二三区| 国产喂奶挤奶一区二区三区| 日韩一区在线看| 丝瓜av网站精品一区二区| 国产一区不卡在线| 在线亚洲一区二区| 日韩精品影音先锋| 中文字幕色av一区二区三区| 午夜久久久久久久久久一区二区| 国产在线精品一区二区不卡了| 色综合中文字幕国产 | 91麻豆精品91久久久久久清纯 | 99精品久久只有精品| 欧美日韩精品一区二区三区蜜桃 | 久久精品国产秦先生| 豆国产96在线|亚洲| 欧美午夜在线观看| 精品国产91乱码一区二区三区| 综合久久给合久久狠狠狠97色| 亚洲第一主播视频| 国产成人精品亚洲777人妖| 欧美日韩久久久一区| 中文字幕国产一区| 蜜臀av性久久久久蜜臀av麻豆| 成人18视频日本| 欧美一区二区三区影视| 亚洲人快播电影网| 国产成人aaa| 91精品国产综合久久久久久| 综合激情成人伊人| 国产精品一区二区久久不卡| 欧美人与z0zoxxxx视频| 中文字幕中文字幕一区二区| 裸体歌舞表演一区二区| 色88888久久久久久影院按摩 | 亚洲少妇最新在线视频| 国精品**一区二区三区在线蜜桃| 欧洲日韩一区二区三区| 国产目拍亚洲精品99久久精品| 日韩va欧美va亚洲va久久| 色丁香久综合在线久综合在线观看| 久久久久国产精品厨房| 蜜桃视频第一区免费观看| 在线观看免费成人| 亚洲视频中文字幕| 成人深夜在线观看| 久久久综合网站| 久久精品国产澳门| 亚洲地区一二三色| 91麻豆成人久久精品二区三区| 久久综合久久综合九色| 日本成人在线看| 91麻豆精品国产自产在线| 亚洲高清免费观看 | 国产美女久久久久| 精品少妇一区二区| 日韩电影免费在线观看网站| 欧美在线观看视频一区二区| 亚洲色图视频免费播放| 成人app在线| 国产精品第五页| 不卡欧美aaaaa| 国产精品不卡在线| 白白色 亚洲乱淫| 中文字幕亚洲视频| 99久久久久久| 亚洲美女淫视频| 在线观看视频一区二区欧美日韩| 亚洲欧美二区三区| 91一区二区三区在线播放| 自拍视频在线观看一区二区| 99精品热视频| 亚洲免费在线看| 欧美体内she精高潮| 亚洲一区在线电影| 欧美日韩亚洲综合| 偷拍一区二区三区四区| 欧美一级专区免费大片| 激情成人综合网| 国产日本欧洲亚洲| 97久久精品人人澡人人爽| 亚洲美女屁股眼交| 欧美人牲a欧美精品| 免费成人在线影院| 国产欧美日韩三区| 一本高清dvd不卡在线观看| 一区二区三区久久| 欧美一区二区三区在线视频| 黄色资源网久久资源365| 国产日韩精品久久久| 91美女片黄在线观看91美女| 亚洲国产日韩在线一区模特 | 欧美午夜精品电影| 日本在线不卡一区| 国产夜色精品一区二区av| 99视频一区二区| 五月天一区二区三区| 欧美mv日韩mv| 99久久国产免费看| 日韩激情av在线| 久久久久久久久久电影| 色综合久久中文综合久久97| 视频一区视频二区中文| 久久蜜桃av一区精品变态类天堂| 99久久婷婷国产综合精品电影 | 精品视频一区二区不卡| 激情小说欧美图片| 亚洲欧美一区二区三区国产精品| 欧美精品日韩精品| 成人性生交大片| 亚洲国产欧美日韩另类综合| 亚洲精品在线免费播放| 91一区二区三区在线观看| 久久精品国产免费| 亚洲免费观看高清完整| 精品国产乱码久久久久久浪潮 | 91小视频在线观看| 日韩高清在线观看| 国产精品国产三级国产三级人妇 | 91麻豆福利精品推荐| 狂野欧美性猛交blacked| 亚洲欧洲精品一区二区三区| 91精品国产欧美一区二区| 99久免费精品视频在线观看| 日韩1区2区3区| 亚洲乱码一区二区三区在线观看| 欧美成人猛片aaaaaaa| 色婷婷久久久久swag精品| 国产伦理精品不卡| 日本欧美大码aⅴ在线播放| 国产精品对白交换视频 | 26uuu另类欧美亚洲曰本| 欧美日韩精品三区| 91丨九色porny丨蝌蚪|