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

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

?? core.c

?? 優龍2410linux2.6.8內核源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
	struct sock *intr_sk = session->intr_sock->sk;	struct sk_buff *skb;	int vendor = 0x0000, product = 0x0000;	wait_queue_t ctrl_wait, intr_wait;	unsigned long timeo = HZ;	BT_DBG("session %p", session);	if (session->input) {		vendor  = session->input->id.vendor;		product = session->input->id.product;	}	daemonize("khidpd_%04x%04x", vendor, product);	set_user_nice(current, -15);	current->flags |= PF_NOFREEZE;	init_waitqueue_entry(&ctrl_wait, current);	init_waitqueue_entry(&intr_wait, current);	add_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);	add_wait_queue(intr_sk->sk_sleep, &intr_wait);	while (!atomic_read(&session->terminate)) {		set_current_state(TASK_INTERRUPTIBLE);		if (ctrl_sk->sk_state != BT_CONNECTED || intr_sk->sk_state != BT_CONNECTED)			break;		while ((skb = skb_dequeue(&ctrl_sk->sk_receive_queue))) {			skb_orphan(skb);			hidp_recv_frame(session, skb);		}		while ((skb = skb_dequeue(&intr_sk->sk_receive_queue))) {			skb_orphan(skb);			hidp_recv_frame(session, skb);		}		hidp_process_transmit(session);		schedule();	}	set_current_state(TASK_RUNNING);	remove_wait_queue(intr_sk->sk_sleep, &intr_wait);	remove_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);	down_write(&hidp_session_sem);	hidp_del_timer(session);	if (intr_sk->sk_state != BT_CONNECTED) {		init_waitqueue_entry(&ctrl_wait, current);		add_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);		while (timeo && ctrl_sk->sk_state != BT_CLOSED) {			set_current_state(TASK_INTERRUPTIBLE);			timeo = schedule_timeout(timeo);		}		set_current_state(TASK_RUNNING);		remove_wait_queue(ctrl_sk->sk_sleep, &ctrl_wait);		timeo = HZ;	}	fput(session->ctrl_sock->file);	init_waitqueue_entry(&intr_wait, current);	add_wait_queue(intr_sk->sk_sleep, &intr_wait);	while (timeo && intr_sk->sk_state != BT_CLOSED) {		set_current_state(TASK_INTERRUPTIBLE);		timeo = schedule_timeout(timeo);	}	set_current_state(TASK_RUNNING);	remove_wait_queue(intr_sk->sk_sleep, &intr_wait);	fput(session->intr_sock->file);	__hidp_unlink_session(session);	if (session->input) {		input_unregister_device(session->input);		kfree(session->input);	}	up_write(&hidp_session_sem);	kfree(session);	return 0;}static inline void hidp_setup_input(struct hidp_session *session, struct hidp_connadd_req *req){	struct input_dev *input = session->input;	int i;	input->private = session;	input->id.bustype = BUS_BLUETOOTH;	input->id.vendor  = req->vendor;	input->id.product = req->product;	input->id.version = req->version;	if (req->subclass & 0x40) {		set_bit(EV_KEY, input->evbit);		set_bit(EV_LED, input->evbit);		set_bit(EV_REP, input->evbit);		set_bit(LED_NUML,    input->ledbit);		set_bit(LED_CAPSL,   input->ledbit);		set_bit(LED_SCROLLL, input->ledbit);		set_bit(LED_COMPOSE, input->ledbit);		set_bit(LED_KANA,    input->ledbit);		for (i = 0; i < sizeof(hidp_keycode); i++)			set_bit(hidp_keycode[i], input->keybit);		clear_bit(0, input->keybit);	}	if (req->subclass & 0x80) {		input->evbit[0] = BIT(EV_KEY) | BIT(EV_REL);		input->keybit[LONG(BTN_MOUSE)] = BIT(BTN_LEFT) | BIT(BTN_RIGHT) | BIT(BTN_MIDDLE);		input->relbit[0] = BIT(REL_X) | BIT(REL_Y);		input->keybit[LONG(BTN_MOUSE)] |= BIT(BTN_SIDE) | BIT(BTN_EXTRA);		input->relbit[0] |= BIT(REL_WHEEL);	}	input->event = hidp_input_event;	input_register_device(input);}int hidp_add_connection(struct hidp_connadd_req *req, struct socket *ctrl_sock, struct socket *intr_sock){	struct hidp_session *session, *s;	int err;	BT_DBG("");	if (bacmp(&bt_sk(ctrl_sock->sk)->src, &bt_sk(intr_sock->sk)->src) ||			bacmp(&bt_sk(ctrl_sock->sk)->dst, &bt_sk(intr_sock->sk)->dst))		return -ENOTUNIQ;	session = kmalloc(sizeof(struct hidp_session), GFP_KERNEL);	if (!session) 		return -ENOMEM;	memset(session, 0, sizeof(struct hidp_session));	session->input = kmalloc(sizeof(struct input_dev), GFP_KERNEL);	if (!session->input) {		kfree(session);		return -ENOMEM;	}	memset(session->input, 0, sizeof(struct input_dev));	down_write(&hidp_session_sem);	s = __hidp_get_session(&bt_sk(ctrl_sock->sk)->dst);	if (s && s->state == BT_CONNECTED) {		err = -EEXIST;		goto failed;	}	bacpy(&session->bdaddr, &bt_sk(ctrl_sock->sk)->dst);	session->ctrl_mtu = min_t(uint, l2cap_pi(ctrl_sock->sk)->omtu, l2cap_pi(ctrl_sock->sk)->imtu);	session->intr_mtu = min_t(uint, l2cap_pi(intr_sock->sk)->omtu, l2cap_pi(intr_sock->sk)->imtu);	BT_DBG("ctrl mtu %d intr mtu %d", session->ctrl_mtu, session->intr_mtu);	session->ctrl_sock = ctrl_sock;	session->intr_sock = intr_sock;	session->state     = BT_CONNECTED;	init_timer(&session->timer);	session->timer.function = hidp_idle_timeout;	session->timer.data     = (unsigned long) session;	skb_queue_head_init(&session->ctrl_transmit);	skb_queue_head_init(&session->intr_transmit);	session->flags   = req->flags & (1 << HIDP_BLUETOOTH_VENDOR_ID);	session->idle_to = req->idle_to;	if (session->input)		hidp_setup_input(session, req);	__hidp_link_session(session);	hidp_set_timer(session);	err = kernel_thread(hidp_session, session, CLONE_KERNEL);	if (err < 0)		goto unlink;	if (session->input) {		hidp_send_message(session, 0x70);		session->flags |= (1 << HIDP_BOOT_PROTOCOL_MODE);		session->leds = 0xff;		hidp_input_event(session->input, EV_LED, 0, 0);	}	up_write(&hidp_session_sem);	return 0;unlink:	hidp_del_timer(session);	__hidp_unlink_session(session);	if (session->input)		input_unregister_device(session->input);failed:	up_write(&hidp_session_sem);	if (session->input)		kfree(session->input);	kfree(session);	return err;}int hidp_del_connection(struct hidp_conndel_req *req){	struct hidp_session *session;	int err = 0;	BT_DBG("");	down_read(&hidp_session_sem);	session = __hidp_get_session(&req->bdaddr);	if (session) {		if (req->flags & (1 << HIDP_VIRTUAL_CABLE_UNPLUG)) {			hidp_send_message(session, 0x15);		} else {			/* Flush the transmit queues */			skb_queue_purge(&session->ctrl_transmit);			skb_queue_purge(&session->intr_transmit);			/* Kill session thread */			atomic_inc(&session->terminate);			hidp_schedule(session);		}	} else		err = -ENOENT;	up_read(&hidp_session_sem);	return err;}int hidp_get_connlist(struct hidp_connlist_req *req){	struct list_head *p;	int err = 0, n = 0;	BT_DBG("");	down_read(&hidp_session_sem);	list_for_each(p, &hidp_session_list) {		struct hidp_session *session;		struct hidp_conninfo ci;		session = list_entry(p, struct hidp_session, list);		__hidp_copy_session(session, &ci);		if (copy_to_user(req->ci, &ci, sizeof(ci))) {			err = -EFAULT;			break;		}		if (++n >= req->cnum)			break;		req->ci++;	}	req->cnum = n;	up_read(&hidp_session_sem);	return err;}int hidp_get_conninfo(struct hidp_conninfo *ci){	struct hidp_session *session;	int err = 0;	down_read(&hidp_session_sem);	session = __hidp_get_session(&ci->bdaddr);	if (session)		__hidp_copy_session(session, ci);	else		err = -ENOENT;	up_read(&hidp_session_sem);	return err;}static int __init hidp_init(void){	l2cap_load();	BT_INFO("HIDP (Human Interface Emulation) ver %s", VERSION);	return hidp_init_sockets();}static void __exit hidp_exit(void){	hidp_cleanup_sockets();}module_init(hidp_init);module_exit(hidp_exit);MODULE_AUTHOR("Marcel Holtmann <marcel@holtmann.org>");MODULE_DESCRIPTION("Bluetooth HIDP ver " VERSION);MODULE_VERSION(VERSION);MODULE_LICENSE("GPL");MODULE_ALIAS("bt-proto-6");

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
99久久免费精品| 日韩中文字幕一区二区三区| 国产精品一二三四| 久久久久久久久久美女| 成人高清视频在线观看| 国产精品成人午夜| 91激情在线视频| 五月综合激情日本mⅴ| 欧美大片在线观看一区二区| 国产真实乱子伦精品视频| 国产亚洲精品精华液| 91在线看国产| 日本三级韩国三级欧美三级| 日韩精品最新网址| 不卡免费追剧大全电视剧网站| 亚洲精品乱码久久久久久久久| 在线免费亚洲电影| 日本欧美加勒比视频| 日本一二三不卡| 欧美午夜片在线观看| 精品一区二区在线看| 国产精品久久看| 欧美一区二区三区小说| 成人午夜激情片| 亚洲高清三级视频| 国产欧美一二三区| 在线观看一区二区视频| 国产自产高清不卡| 一个色综合网站| 欧美精品一区二区三区四区 | 久久一二三国产| 99这里只有久久精品视频| 一区二区三区国产精华| 日韩欧美一二三| 91在线观看成人| 蜜桃视频在线一区| 国产精品久久久久久户外露出| 欧美视频日韩视频| 成人性生交大片免费看中文网站| 一区二区三区在线观看动漫| 欧美精品一区男女天堂| 欧美日韩免费在线视频| 成人av电影在线| 美美哒免费高清在线观看视频一区二区 | 五月天国产精品| 欧美经典三级视频一区二区三区| 欧美剧在线免费观看网站| 成人高清av在线| 国产一二三精品| 日韩国产欧美视频| 又紧又大又爽精品一区二区| 国产日韩成人精品| 精品少妇一区二区三区日产乱码 | 亚洲一区影音先锋| 中文字幕乱码日本亚洲一区二区| 欧美夫妻性生活| 欧美亚洲国产怡红院影院| 国产成人aaa| 久久成人久久鬼色| 亚洲成人福利片| 亚洲一区二区三区中文字幕在线 | 国产精品久久久久天堂| 欧美电影免费观看高清完整版在 | 久久综合国产精品| 日韩欧美自拍偷拍| 丝袜亚洲精品中文字幕一区| 欧美日韩精品一区二区在线播放| 国产91精品一区二区| 麻豆精品一区二区av白丝在线| 亚洲国产一区二区a毛片| 国产精品免费av| 中文幕一区二区三区久久蜜桃| 2017欧美狠狠色| 精品国产伦一区二区三区免费| 51精品国自产在线| 日韩一级黄色大片| 日韩欧美视频在线| 精品日韩99亚洲| 日韩免费高清视频| 精品成人一区二区三区四区| 久久亚洲综合色一区二区三区| 精品欧美一区二区三区精品久久| 日韩欧美亚洲国产精品字幕久久久| 这里只有精品视频在线观看| 日韩一二三四区| 欧美岛国在线观看| 久久久.com| 国产精品乱子久久久久| 亚洲人成精品久久久久久| 夜夜嗨av一区二区三区中文字幕 | 国产精品麻豆久久久| 最新久久zyz资源站| 亚洲天堂久久久久久久| 一区二区三区四区视频精品免费| 亚洲黄色av一区| 爽好久久久欧美精品| 久久成人久久爱| 成人精品国产一区二区4080| 91蜜桃婷婷狠狠久久综合9色| 91福利精品第一导航| 欧美系列一区二区| 欧美α欧美αv大片| 国产精品乱码妇女bbbb| 亚洲一区免费视频| 免费久久99精品国产| 国产精品香蕉一区二区三区| 一本久久综合亚洲鲁鲁五月天| 欧美日韩亚洲综合一区 | 日本一区二区三区在线观看| 亚洲人午夜精品天堂一二香蕉| 亚洲一级片在线观看| 美洲天堂一区二卡三卡四卡视频| 国产伦精品一区二区三区免费| 91视视频在线观看入口直接观看www | 蜜桃av一区二区在线观看| 国产精品亚洲一区二区三区在线| 99久久精品一区| 欧美日本在线一区| 中文字幕国产一区二区| 午夜精品久久久久久久久久久 | 日韩精品亚洲专区| 成人精品在线视频观看| 欧美日韩国产综合一区二区| 久久夜色精品国产噜噜av| 一区二区成人在线视频| 国产主播一区二区| 欧美女孩性生活视频| 国产精品久久久久aaaa樱花| 日日噜噜夜夜狠狠视频欧美人| 高清成人免费视频| 51精品国自产在线| 中文字幕综合网| 国产美女精品人人做人人爽| 欧美视频中文一区二区三区在线观看 | 亚洲精品一区二区精华| 亚洲永久精品大片| 成人av影视在线观看| 欧美成人伊人久久综合网| 亚洲综合丝袜美腿| 懂色av噜噜一区二区三区av| 欧美一级夜夜爽| 亚洲福利视频导航| 97久久精品人人做人人爽| 久久精品免费在线观看| 久久精品久久综合| 欧美日韩精品欧美日韩精品一 | 欧美电影影音先锋| 亚洲精品中文字幕在线观看| 成人三级伦理片| 精品国内片67194| 日韩电影在线观看一区| 欧美视频三区在线播放| 一区二区三区在线看| 不卡一二三区首页| 久久精品亚洲麻豆av一区二区| 日本va欧美va瓶| 91精品国产免费久久综合| 亚洲电影一区二区三区| 欧美综合天天夜夜久久| 亚洲免费观看视频| 色一区在线观看| 亚洲欧美电影院| 色一情一乱一乱一91av| 一区二区三区国产豹纹内裤在线| 91网站视频在线观看| 亚洲人成在线播放网站岛国| 99久久精品99国产精品 | 亚洲一区二区黄色| 日本韩国精品在线| 亚洲一区视频在线| 欧美人动与zoxxxx乱| 日韩影视精彩在线| 日韩你懂的在线播放| 精品一区二区三区在线观看 | 国产人伦精品一区二区| 国产精品夜夜爽| 国产精品久久久久久久岛一牛影视| 成人免费毛片app| 最新欧美精品一区二区三区| 色婷婷精品大在线视频| 亚洲一区二区精品视频| 91麻豆精品91久久久久同性| 日本不卡的三区四区五区| 精品国产在天天线2019| 国产精品18久久久久久久久| 亚洲国产成人一区二区三区| 成人aaaa免费全部观看| 亚洲精品日韩综合观看成人91| 欧美在线一区二区三区| 日韩va欧美va亚洲va久久| 26uuu久久综合| 成人激情小说乱人伦| 亚洲综合色婷婷| 日韩午夜在线观看| 国产成人免费在线视频| 亚洲影院久久精品| 欧美成人激情免费网| 成人h版在线观看| 亚洲午夜久久久久中文字幕久| 欧美一区二区视频在线观看2020 |