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

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

?? btuart.c

?? 藍牙傳輸源程序,基于ARM處理器,在S3C2410實驗箱上運行成功
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * *  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++;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃视频一区二区三区| 91亚洲精华国产精华精华液| 国产成人免费视频一区| 欧美自拍丝袜亚洲| 中文字幕不卡在线观看| 精品一区中文字幕| 欧美日韩国产高清一区二区 | 欧美精品成人一区二区三区四区| 欧美成人精品1314www| 亚洲欧美色一区| 成人国产精品免费观看视频| 欧美成人一区二区三区在线观看| 一区二区三区毛片| 99久久久久久| 国产精品色噜噜| 成人高清免费在线播放| 久久精品一二三| 国产麻豆一精品一av一免费 | 久久久久久久综合| 蜜臂av日日欢夜夜爽一区| 欧美性极品少妇| 一区二区在线观看免费视频播放| 成人爱爱电影网址| 国产精品超碰97尤物18| 成人免费看视频| 国产精品色哟哟| 成人av手机在线观看| 欧美国产日韩亚洲一区| 国产精品 欧美精品| 久久综合av免费| 国产一区久久久| 国产欧美精品区一区二区三区 | 免费观看久久久4p| 67194成人在线观看| 日韩电影免费一区| 日韩一区二区在线播放| 久久99国产精品尤物| 欧美成人aa大片| 国产999精品久久久久久| 国产精品视频线看| 91一区二区在线| 亚洲h在线观看| 欧美高清激情brazzers| 蜜桃视频一区二区三区在线观看| 欧美一级xxx| 国产一区91精品张津瑜| 久久精品72免费观看| 日韩精品一区二区三区四区| 激情偷乱视频一区二区三区| 国产婷婷色一区二区三区在线| 成人免费视频播放| 亚洲免费观看高清完整版在线观看熊| av网站免费线看精品| 一区二区在线观看免费视频播放| 欧美日韩在线三区| 久久精品二区亚洲w码| 精品国产乱码久久久久久夜甘婷婷| 国产精品一二二区| 亚洲欧洲综合另类| 欧美一区二区三区在线观看| 国产综合久久久久久久久久久久| 中文字幕av不卡| 欧美在线看片a免费观看| 青青草原综合久久大伊人精品| 26uuu欧美| 欧美日韩一区在线观看| 久久成人久久鬼色| 亚洲色图一区二区三区| 欧美精品在线一区二区三区| 国产精品99久| 日韩中文字幕一区二区三区| 国产日韩欧美一区二区三区乱码 | 亚洲444eee在线观看| 国产日韩av一区二区| 欧美性猛片xxxx免费看久爱| 久草在线在线精品观看| 成人白浆超碰人人人人| 日产国产高清一区二区三区 | 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 日韩免费电影一区| 色综合久久中文字幕| 久久国产精品72免费观看| 亚洲区小说区图片区qvod| 久久久久久久久久看片| 欧美日韩电影一区| 色综合久久天天| 国产露脸91国语对白| 青青国产91久久久久久| 一区二区三区在线视频播放| 中文字幕成人网| 久久久久久99久久久精品网站| 欧美日韩不卡在线| 91久久精品一区二区| 成人毛片老司机大片| 精品写真视频在线观看| 日韩精品福利网| 亚洲一卡二卡三卡四卡无卡久久| 国产精品情趣视频| 亚洲一区视频在线| 91麻豆精品国产自产在线观看一区| 国产精品伦理一区二区| 国产99久久久精品| 奇米888四色在线精品| 亚洲美女一区二区三区| 欧美国产精品专区| 国产日韩视频一区二区三区| 日韩欧美一区在线| 日韩一级大片在线观看| 日韩一级黄色大片| 日韩免费视频一区| 精品少妇一区二区三区免费观看| 欧美一级艳片视频免费观看| 日韩一区二区三区免费观看| 欧美肥妇毛茸茸| 欧美一区二区久久| 日韩一区二区三| 精品久久久久久亚洲综合网| 精品国产一区二区三区av性色| 日韩美女在线视频| 国产三级三级三级精品8ⅰ区| 久久综合99re88久久爱| 中文字幕精品一区二区精品绿巨人 | 1024成人网| 一区二区三区四区av| 亚洲一区中文日韩| 麻豆视频观看网址久久| 久久99精品久久久久婷婷| 国产成人啪午夜精品网站男同| 成人动漫中文字幕| 欧美性极品少妇| 日韩欧美成人一区| 国产午夜亚洲精品理论片色戒| 国产精品系列在线| 亚洲男女毛片无遮挡| 亚洲二区视频在线| 国产在线麻豆精品观看| 成人av在线影院| 欧美日韩午夜在线视频| 精品国产伦理网| 亚洲三级小视频| 图片区小说区区亚洲影院| 黄色资源网久久资源365| 99久久久精品免费观看国产蜜| 欧洲国内综合视频| 欧美一区三区四区| 欧美国产在线观看| 日韩精品91亚洲二区在线观看 | 久久久亚洲精品石原莉奈| 中文一区二区在线观看| 亚洲一区二区三区美女| 国产原创一区二区| 欧美视频完全免费看| 久久一留热品黄| 亚洲韩国精品一区| 国产麻豆精品久久一二三| 精品视频在线免费观看| 久久―日本道色综合久久| 一区二区激情视频| 国产成人免费av在线| 欧美午夜电影网| 欧美激情综合五月色丁香小说| 日韩国产精品久久久| 成人性生交大片免费看中文| 在线电影一区二区三区| 成人免费一区二区三区视频| 美女视频一区二区三区| 在线观看91精品国产入口| 国产欧美久久久精品影院| 视频一区二区三区入口| 91在线视频网址| 国产免费观看久久| 黑人巨大精品欧美一区| 欧美三级韩国三级日本三斤| 国产日韩欧美高清在线| 麻豆精品在线看| 欧美日韩国产小视频在线观看| 国产精品视频一二三区| 国产一区在线观看视频| 欧美一区二区三区不卡| 玉米视频成人免费看| 99精品久久99久久久久| 国产精品久久一卡二卡| 国产精品综合在线视频| 欧美一级专区免费大片| 亚洲成人黄色小说| 欧美视频在线播放| 亚洲精品国产精华液| 91捆绑美女网站| 亚洲精品视频在线观看免费| 成人av在线影院| 国产精品日产欧美久久久久| 东方欧美亚洲色图在线| 久久久久亚洲综合| 国产美女视频91| 国产三级精品三级| 99久久婷婷国产综合精品电影| 国产精品高清亚洲| 欧美中文一区二区三区| 国产盗摄精品一区二区三区在线 | 国产福利一区二区三区视频|