亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
色婷婷av一区二区三区大白胸 | 国产三级精品三级在线专区| 国产欧美一区二区精品忘忧草| 一区二区久久久| 蜜臀av一区二区三区| 91在线免费看| 国产欧美日韩视频在线观看| 天天色天天爱天天射综合| av在线不卡观看免费观看| 欧美精品一区二区蜜臀亚洲| 亚洲综合色婷婷| 岛国精品在线播放| 亚洲精品一区二区三区蜜桃下载| 亚洲图片欧美一区| 色噜噜狠狠成人网p站| 久久精品亚洲一区二区三区浴池 | 美女视频黄 久久| 色美美综合视频| 中文字幕五月欧美| 不卡一卡二卡三乱码免费网站| 日韩小视频在线观看专区| 亚洲福利一二三区| 欧美羞羞免费网站| 一区二区不卡在线播放 | 国产一区二区三区精品视频| 欧美精品国产精品| 亚洲无人区一区| 欧美在线不卡一区| 亚洲一区二区三区在线播放| av午夜一区麻豆| 国产精品久久夜| 99久久精品免费观看| 中文字幕 久热精品 视频在线 | 日韩黄色免费网站| 欧美精品久久天天躁| 婷婷久久综合九色综合绿巨人| 欧美色中文字幕| 五月天国产精品| 欧美老年两性高潮| 日韩va欧美va亚洲va久久| 欧美一区二区三区在线看| 蜜臀久久久久久久| 精品乱码亚洲一区二区不卡| 狠狠色狠狠色综合系列| www欧美成人18+| 国产乱色国产精品免费视频| 国产精品久久久久aaaa| 91美女片黄在线| 婷婷开心久久网| 国产女主播在线一区二区| 91麻豆免费观看| 日韩va亚洲va欧美va久久| 亚洲精品在线电影| 91视频国产观看| 日韩av中文字幕一区二区| 久久精品一区蜜桃臀影院| 91浏览器在线视频| 肉色丝袜一区二区| 国产精品丝袜一区| 在线观看日韩电影| 久久电影网站中文字幕| 亚洲欧洲精品一区二区三区| 在线播放视频一区| 国产91精品一区二区麻豆亚洲| 亚洲精品少妇30p| 日韩一区二区三免费高清| 不卡免费追剧大全电视剧网站| 亚洲成人免费看| 国产欧美精品一区aⅴ影院| 欧美日韩激情一区| 风间由美中文字幕在线看视频国产欧美| 亚洲特黄一级片| 欧美成人国产一区二区| 91久久精品一区二区三区| 精品一区免费av| 亚洲一二三四久久| 国产亚洲精品中文字幕| 欧美日本在线一区| 97精品电影院| 韩国三级电影一区二区| 亚洲第四色夜色| 最新日韩av在线| 久久久久久久电影| 日韩午夜精品电影| 欧美在线观看一区二区| 成人污视频在线观看| 欧美aⅴ一区二区三区视频| 亚洲视频精选在线| 国产农村妇女精品| 精品成人在线观看| 欧美一区二区在线免费播放| 色综合久久综合中文综合网| 国产麻豆精品视频| 蜜桃精品视频在线观看| 亚洲高清视频在线| 亚洲黄色av一区| 国产精品视频观看| 久久久久久免费| 精品日产卡一卡二卡麻豆| 欧美色网一区二区| 欧美性大战久久久| 色一情一乱一乱一91av| 不卡av在线免费观看| 国产精品一区二区三区网站| 久久av资源网| 麻豆高清免费国产一区| 免费成人在线视频观看| 日本亚洲免费观看| 免费观看日韩av| 老司机免费视频一区二区| 蜜桃91丨九色丨蝌蚪91桃色| 日本vs亚洲vs韩国一区三区 | 一区二区三区在线视频免费| 国产精品传媒视频| 亚洲乱码一区二区三区在线观看| 中文字幕在线观看不卡| 亚洲欧洲性图库| 成人欧美一区二区三区1314| 国产精品久久久久久久久免费樱桃 | 17c精品麻豆一区二区免费| 国产日韩欧美精品综合| 国产精品乱码久久久久久| 亚洲国产精品精华液2区45| 中文字幕国产一区二区| 国产精品欧美综合在线| 亚洲欧美一区二区视频| 一区二区三区在线影院| 日韩电影免费在线看| 久久99精品国产麻豆婷婷洗澡| 国内精品国产三级国产a久久| 国产一区二区三区国产| 成人av网址在线观看| 色婷婷av一区二区三区软件 | 中文av字幕一区| 自拍偷在线精品自拍偷无码专区| 亚洲激情图片小说视频| 香蕉av福利精品导航| 久久69国产一区二区蜜臀| 国产91精品精华液一区二区三区 | 精品91自产拍在线观看一区| 国产日韩欧美精品综合| 一区二区三区中文在线观看| 日韩电影在线一区二区| 成人性视频免费网站| 欧美亚洲国产一区二区三区va| 日韩欧美一二三区| 国产精品国产自产拍高清av| 亚洲一区二区视频在线观看| 美女在线视频一区| 91在线小视频| 亚洲精品一线二线三线| 亚洲少妇30p| 久久疯狂做爰流白浆xx| 色综合中文字幕国产 | 欧美军同video69gay| 久久众筹精品私拍模特| 亚洲夂夂婷婷色拍ww47| 老鸭窝一区二区久久精品| 色一情一乱一乱一91av| 久久久久亚洲综合| 亚洲成人免费电影| www.欧美精品一二区| 欧美va天堂va视频va在线| 亚洲精品视频在线看| 国产不卡在线一区| 欧美一区二区视频在线观看2022 | 欧美激情在线免费观看| 日本欧美在线观看| 在线视频中文字幕一区二区| 久久久蜜桃精品| 日韩电影在线免费观看| 色中色一区二区| 国产精品久久久久毛片软件| 九九国产精品视频| 91精品国产91久久久久久一区二区| 国产欧美日韩卡一| 国产综合色视频| 日韩一级视频免费观看在线| 一区二区三区日韩欧美| 成人福利电影精品一区二区在线观看| 精品久久人人做人人爱| 青青国产91久久久久久 | 日韩影院在线观看| 色综合久久88色综合天天| 国产欧美精品一区| 国产精品一二三区| 精品国产免费人成电影在线观看四季| 亚洲v日本v欧美v久久精品| 一本色道亚洲精品aⅴ| 国产精品对白交换视频| 成人一区二区三区视频在线观看 | 香蕉成人啪国产精品视频综合网| av一区二区三区黑人| 欧美激情一区在线观看| 成人亚洲精品久久久久软件| 中文字幕国产一区二区| www.在线欧美| 亚洲素人一区二区| 日本伦理一区二区| 亚洲一区二区欧美|