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

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

?? core.c

?? 優龍2410linux2.6.8內核源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
/*    RFCOMM implementation for Linux Bluetooth stack (BlueZ).   Copyright (C) 2002 Maxim Krasnyansky <maxk@qualcomm.com>   Copyright (C) 2002 Marcel Holtmann <marcel@holtmann.org>   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.*//*    RPN support    -    Dirk Husemann <hud@zurich.ibm.com>*//* * Bluetooth RFCOMM core. * * $Id: core.c,v 1.42 2002/10/01 23:26:25 maxk Exp $ */#include <linux/config.h>#include <linux/module.h>#include <linux/errno.h>#include <linux/kernel.h>#include <linux/sched.h>#include <linux/signal.h>#include <linux/init.h>#include <linux/wait.h>#include <linux/net.h>#include <linux/proc_fs.h>#include <linux/seq_file.h>#include <net/sock.h>#include <asm/uaccess.h>#include <asm/unaligned.h>#include <net/bluetooth/bluetooth.h>#include <net/bluetooth/l2cap.h>#include <net/bluetooth/rfcomm.h>#define VERSION "1.3"#ifndef CONFIG_BT_RFCOMM_DEBUG#undef  BT_DBG#define BT_DBG(D...)#endif#ifdef CONFIG_PROC_FSstruct proc_dir_entry *proc_bt_rfcomm;#endifstruct task_struct *rfcomm_thread;DECLARE_MUTEX(rfcomm_sem);unsigned long rfcomm_event;static LIST_HEAD(session_list);static atomic_t terminate, running;static int rfcomm_send_frame(struct rfcomm_session *s, u8 *data, int len);static int rfcomm_send_sabm(struct rfcomm_session *s, u8 dlci);static int rfcomm_send_disc(struct rfcomm_session *s, u8 dlci);static int rfcomm_queue_disc(struct rfcomm_dlc *d);static int rfcomm_send_nsc(struct rfcomm_session *s, int cr, u8 type);static int rfcomm_send_pn(struct rfcomm_session *s, int cr, struct rfcomm_dlc *d);static int rfcomm_send_msc(struct rfcomm_session *s, int cr, u8 dlci, u8 v24_sig);static int rfcomm_send_test(struct rfcomm_session *s, int cr, u8 *pattern, int len);static int rfcomm_send_credits(struct rfcomm_session *s, u8 addr, u8 credits);static void rfcomm_make_uih(struct sk_buff *skb, u8 addr);static void rfcomm_process_connect(struct rfcomm_session *s);/* ---- RFCOMM frame parsing macros ---- */#define __get_dlci(b)     ((b & 0xfc) >> 2)#define __get_channel(b)  ((b & 0xf8) >> 3)#define __get_dir(b)      ((b & 0x04) >> 2)#define __get_type(b)     ((b & 0xef))#define __test_ea(b)      ((b & 0x01))#define __test_cr(b)      ((b & 0x02))#define __test_pf(b)      ((b & 0x10))#define __addr(cr, dlci)       (((dlci & 0x3f) << 2) | (cr << 1) | 0x01)#define __ctrl(type, pf)       (((type & 0xef) | (pf << 4)))#define __dlci(dir, chn)       (((chn & 0x1f) << 1) | dir)#define __srv_channel(dlci)    (dlci >> 1)#define __dir(dlci)            (dlci & 0x01)#define __len8(len)       (((len) << 1) | 1)#define __len16(len)      ((len) << 1)/* MCC macros */#define __mcc_type(cr, type)   (((type << 2) | (cr << 1) | 0x01))#define __get_mcc_type(b) ((b & 0xfc) >> 2)#define __get_mcc_len(b)  ((b & 0xfe) >> 1)/* RPN macros */#define __rpn_line_settings(data, stop, parity)  ((data & 0x3) | ((stop & 0x1) << 2) | ((parity & 0x3) << 3))#define __get_rpn_data_bits(line) ((line) & 0x3)#define __get_rpn_stop_bits(line) (((line) >> 2) & 0x1)#define __get_rpn_parity(line)    (((line) >> 3) & 0x3)/* ---- RFCOMM FCS computation ---- *//* CRC on 2 bytes */#define __crc(data) (rfcomm_crc_table[rfcomm_crc_table[0xff ^ data[0]] ^ data[1]])/* FCS on 2 bytes */ static inline u8 __fcs(u8 *data){	return (0xff - __crc(data));}/* FCS on 3 bytes */ static inline u8 __fcs2(u8 *data){	return (0xff - rfcomm_crc_table[__crc(data) ^ data[2]]);}/* Check FCS */static inline int __check_fcs(u8 *data, int type, u8 fcs){	u8 f = __crc(data);	if (type != RFCOMM_UIH)		f = rfcomm_crc_table[f ^ data[2]];	return rfcomm_crc_table[f ^ fcs] != 0xcf;}/* ---- L2CAP callbacks ---- */static void rfcomm_l2state_change(struct sock *sk){	BT_DBG("%p state %d", sk, sk->sk_state);	rfcomm_schedule(RFCOMM_SCHED_STATE);}static void rfcomm_l2data_ready(struct sock *sk, int bytes){	BT_DBG("%p bytes %d", sk, bytes);	rfcomm_schedule(RFCOMM_SCHED_RX);}static int rfcomm_l2sock_create(struct socket **sock){	int err;	BT_DBG("");	err = sock_create_kern(PF_BLUETOOTH, SOCK_SEQPACKET, BTPROTO_L2CAP, sock);	if (!err) {		struct sock *sk = (*sock)->sk;		sk->sk_data_ready   = rfcomm_l2data_ready;		sk->sk_state_change = rfcomm_l2state_change;	}	return err;}/* ---- RFCOMM DLCs ---- */static void rfcomm_dlc_timeout(unsigned long arg){	struct rfcomm_dlc *d = (void *) arg;	BT_DBG("dlc %p state %ld", d, d->state);	set_bit(RFCOMM_TIMED_OUT, &d->flags);	rfcomm_dlc_put(d);	rfcomm_schedule(RFCOMM_SCHED_TIMEO);}static void rfcomm_dlc_set_timer(struct rfcomm_dlc *d, long timeout){	BT_DBG("dlc %p state %ld timeout %ld", d, d->state, timeout);	if (!mod_timer(&d->timer, jiffies + timeout))		rfcomm_dlc_hold(d);}static void rfcomm_dlc_clear_timer(struct rfcomm_dlc *d){	BT_DBG("dlc %p state %ld", d, d->state);	if (timer_pending(&d->timer) && del_timer(&d->timer))		rfcomm_dlc_put(d);}static void rfcomm_dlc_clear_state(struct rfcomm_dlc *d){	BT_DBG("%p", d);	d->state      = BT_OPEN;	d->flags      = 0;	d->mscex      = 0;	d->mtu        = RFCOMM_DEFAULT_MTU;	d->v24_sig    = RFCOMM_V24_RTC | RFCOMM_V24_RTR | RFCOMM_V24_DV;	d->cfc        = RFCOMM_CFC_DISABLED;	d->rx_credits = RFCOMM_DEFAULT_CREDITS;}struct rfcomm_dlc *rfcomm_dlc_alloc(int prio){	struct rfcomm_dlc *d = kmalloc(sizeof(*d), prio);	if (!d)		return NULL;	memset(d, 0, sizeof(*d));	init_timer(&d->timer);	d->timer.function = rfcomm_dlc_timeout;	d->timer.data = (unsigned long) d;	skb_queue_head_init(&d->tx_queue);	spin_lock_init(&d->lock);	atomic_set(&d->refcnt, 1);	rfcomm_dlc_clear_state(d);		BT_DBG("%p", d);	return d;}void rfcomm_dlc_free(struct rfcomm_dlc *d){	BT_DBG("%p", d);	skb_queue_purge(&d->tx_queue);	kfree(d);}static void rfcomm_dlc_link(struct rfcomm_session *s, struct rfcomm_dlc *d){	BT_DBG("dlc %p session %p", d, s);	rfcomm_session_hold(s);	rfcomm_dlc_hold(d);	list_add(&d->list, &s->dlcs);	d->session = s;}static void rfcomm_dlc_unlink(struct rfcomm_dlc *d){	struct rfcomm_session *s = d->session;	BT_DBG("dlc %p refcnt %d session %p", d, atomic_read(&d->refcnt), s);	list_del(&d->list);	d->session = NULL;	rfcomm_dlc_put(d);	rfcomm_session_put(s);}static struct rfcomm_dlc *rfcomm_dlc_get(struct rfcomm_session *s, u8 dlci){	struct rfcomm_dlc *d;	struct list_head *p;	list_for_each(p, &s->dlcs) {		d = list_entry(p, struct rfcomm_dlc, list);		if (d->dlci == dlci)			return d;	}	return NULL;}static int __rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst, u8 channel){	struct rfcomm_session *s;	int err = 0;	u8 dlci;	BT_DBG("dlc %p state %ld %s %s channel %d", 			d, d->state, batostr(src), batostr(dst), channel);	if (channel < 1 || channel > 30)		return -EINVAL;	if (d->state != BT_OPEN && d->state != BT_CLOSED)		return 0;	s = rfcomm_session_get(src, dst);	if (!s) {		s = rfcomm_session_create(src, dst, &err);		if (!s)			return err;	}	dlci = __dlci(!s->initiator, channel);	/* Check if DLCI already exists */	if (rfcomm_dlc_get(s, dlci))		return -EBUSY;	rfcomm_dlc_clear_state(d);	d->dlci     = dlci;	d->addr     = __addr(s->initiator, dlci);	d->priority = 7;	d->state    = BT_CONFIG;	rfcomm_dlc_link(s, d);	d->mtu = s->mtu;	d->cfc = (s->cfc == RFCOMM_CFC_UNKNOWN) ? 0 : s->cfc;	if (s->state == BT_CONNECTED)		rfcomm_send_pn(s, 1, d);	rfcomm_dlc_set_timer(d, RFCOMM_CONN_TIMEOUT);	return 0;}int rfcomm_dlc_open(struct rfcomm_dlc *d, bdaddr_t *src, bdaddr_t *dst, u8 channel){	int r;	rfcomm_lock();	r = __rfcomm_dlc_open(d, src, dst, channel);	rfcomm_unlock();	return r;}static int __rfcomm_dlc_close(struct rfcomm_dlc *d, int err){	struct rfcomm_session *s = d->session;	if (!s)		return 0;	BT_DBG("dlc %p state %ld dlci %d err %d session %p",			d, d->state, d->dlci, err, s);	switch (d->state) {	case BT_CONNECTED:	case BT_CONFIG:	case BT_CONNECT:		d->state = BT_DISCONN;		if (skb_queue_empty(&d->tx_queue)) {			rfcomm_send_disc(s, d->dlci);			rfcomm_dlc_set_timer(d, RFCOMM_DISC_TIMEOUT);		} else {			rfcomm_queue_disc(d);			rfcomm_dlc_set_timer(d, RFCOMM_DISC_TIMEOUT * 2);		}		break;	default:		rfcomm_dlc_clear_timer(d);		rfcomm_dlc_lock(d);		d->state = BT_CLOSED;		d->state_change(d, err);		rfcomm_dlc_unlock(d);		skb_queue_purge(&d->tx_queue);		rfcomm_dlc_unlink(d);	}	return 0;}int rfcomm_dlc_close(struct rfcomm_dlc *d, int err){	int r;	rfcomm_lock();	r = __rfcomm_dlc_close(d, err);	rfcomm_unlock();	return r;}int rfcomm_dlc_send(struct rfcomm_dlc *d, struct sk_buff *skb){	int len = skb->len;	if (d->state != BT_CONNECTED)		return -ENOTCONN;	BT_DBG("dlc %p mtu %d len %d", d, d->mtu, len);	if (len > d->mtu)		return -EINVAL;	rfcomm_make_uih(skb, d->addr);	skb_queue_tail(&d->tx_queue, skb);	if (!test_bit(RFCOMM_TX_THROTTLED, &d->flags))		rfcomm_schedule(RFCOMM_SCHED_TX);	return len;}void fastcall __rfcomm_dlc_throttle(struct rfcomm_dlc *d){	BT_DBG("dlc %p state %ld", d, d->state);	if (!d->cfc) {		d->v24_sig |= RFCOMM_V24_FC;		set_bit(RFCOMM_MSC_PENDING, &d->flags);	}	rfcomm_schedule(RFCOMM_SCHED_TX);}void fastcall __rfcomm_dlc_unthrottle(struct rfcomm_dlc *d){	BT_DBG("dlc %p state %ld", d, d->state);	if (!d->cfc) {		d->v24_sig &= ~RFCOMM_V24_FC;		set_bit(RFCOMM_MSC_PENDING, &d->flags);	}	rfcomm_schedule(RFCOMM_SCHED_TX);}/*    Set/get modem status functions use _local_ status i.e. what we report   to the other side.   Remote status is provided by dlc->modem_status() callback. */int rfcomm_dlc_set_modem_status(struct rfcomm_dlc *d, u8 v24_sig){	BT_DBG("dlc %p state %ld v24_sig 0x%x", 			d, d->state, v24_sig);	if (test_bit(RFCOMM_RX_THROTTLED, &d->flags))		v24_sig |= RFCOMM_V24_FC;	else		v24_sig &= ~RFCOMM_V24_FC;		d->v24_sig = v24_sig;	if (!test_and_set_bit(RFCOMM_MSC_PENDING, &d->flags))		rfcomm_schedule(RFCOMM_SCHED_TX);	return 0;}int rfcomm_dlc_get_modem_status(struct rfcomm_dlc *d, u8 *v24_sig){	BT_DBG("dlc %p state %ld v24_sig 0x%x", 			d, d->state, d->v24_sig);	*v24_sig = d->v24_sig;	return 0;}/* ---- RFCOMM sessions ---- */struct rfcomm_session *rfcomm_session_add(struct socket *sock, int state){	struct rfcomm_session *s = kmalloc(sizeof(*s), GFP_KERNEL);	if (!s)		return NULL;	memset(s, 0, sizeof(*s));	BT_DBG("session %p sock %p", s, sock);	INIT_LIST_HEAD(&s->dlcs);	s->state = state;	s->sock  = sock;	s->mtu = RFCOMM_DEFAULT_MTU;	s->cfc = RFCOMM_CFC_UNKNOWN;	/* Do not increment module usage count for listening sessions.	 * Otherwise we won't be able to unload the module. */	if (state != BT_LISTEN)		if (!try_module_get(THIS_MODULE)) {			kfree(s);			return NULL;		}	list_add(&s->list, &session_list);	return s;}void rfcomm_session_del(struct rfcomm_session *s){	int state = s->state;	BT_DBG("session %p state %ld", s, s->state);	list_del(&s->list);	if (state == BT_CONNECTED)		rfcomm_send_disc(s, 0);	sock_release(s->sock);	kfree(s);	if (state != BT_LISTEN)		module_put(THIS_MODULE);}struct rfcomm_session *rfcomm_session_get(bdaddr_t *src, bdaddr_t *dst){	struct rfcomm_session *s;	struct list_head *p, *n;	struct bt_sock *sk;	list_for_each_safe(p, n, &session_list) {		s = list_entry(p, struct rfcomm_session, list);		sk = bt_sk(s->sock->sk); 		if ((!bacmp(src, BDADDR_ANY) || !bacmp(&sk->src, src)) &&				!bacmp(&sk->dst, dst))			return s;	}	return NULL;}void rfcomm_session_close(struct rfcomm_session *s, int err){	struct rfcomm_dlc *d;	struct list_head *p, *n;	BT_DBG("session %p state %ld err %d", s, s->state, err);	rfcomm_session_hold(s);	s->state = BT_CLOSED;	/* Close all dlcs */	list_for_each_safe(p, n, &s->dlcs) {		d = list_entry(p, struct rfcomm_dlc, list);		d->state = BT_CLOSED;		__rfcomm_dlc_close(d, err);	}	rfcomm_session_put(s);}struct rfcomm_session *rfcomm_session_create(bdaddr_t *src, bdaddr_t *dst, int *err){	struct rfcomm_session *s = NULL;	struct sockaddr_l2 addr;	struct socket *sock;	struct sock *sk;	BT_DBG("%s %s", batostr(src), batostr(dst));	*err = rfcomm_l2sock_create(&sock);	if (*err < 0)		return NULL;	bacpy(&addr.l2_bdaddr, src);	addr.l2_family = AF_BLUETOOTH;	addr.l2_psm    = 0;	*err = sock->ops->bind(sock, (struct sockaddr *) &addr, sizeof(addr));	if (*err < 0)		goto failed;	/* Set L2CAP options */	sk = sock->sk;	lock_sock(sk);	l2cap_pi(sk)->imtu = RFCOMM_MAX_L2CAP_MTU;	release_sock(sk);	s = rfcomm_session_add(sock, BT_BOUND);	if (!s) {		*err = -ENOMEM;		goto failed;	}	s->initiator = 1;	bacpy(&addr.l2_bdaddr, dst);	addr.l2_family = AF_BLUETOOTH;	addr.l2_psm    = htobs(RFCOMM_PSM);	*err = sock->ops->connect(sock, (struct sockaddr *) &addr, sizeof(addr), O_NONBLOCK);	if (*err == 0 || *err == -EAGAIN)		return s;	rfcomm_session_del(s);	return NULL;failed:	sock_release(sock);	return NULL;}void rfcomm_session_getaddr(struct rfcomm_session *s, bdaddr_t *src, bdaddr_t *dst){	struct sock *sk = s->sock->sk;	if (src)		bacpy(src, &bt_sk(sk)->src);	if (dst)		bacpy(dst, &bt_sk(sk)->dst);}/* ---- RFCOMM frame sending ---- */static int rfcomm_send_frame(struct rfcomm_session *s, u8 *data, int len){	struct socket *sock = s->sock;	struct kvec iv = { data, len };	struct msghdr msg;	BT_DBG("session %p len %d", s, len);	memset(&msg, 0, sizeof(msg));	return kernel_sendmsg(sock, &msg, &iv, 1, len);}static int rfcomm_send_sabm(struct rfcomm_session *s, u8 dlci){	struct rfcomm_cmd cmd;	BT_DBG("%p dlci %d", s, dlci);	cmd.addr = __addr(s->initiator, dlci);	cmd.ctrl = __ctrl(RFCOMM_SABM, 1);	cmd.len  = __len8(0);	cmd.fcs  = __fcs2((u8 *) &cmd);	return rfcomm_send_frame(s, (void *) &cmd, sizeof(cmd));}static int rfcomm_send_ua(struct rfcomm_session *s, u8 dlci){	struct rfcomm_cmd cmd;	BT_DBG("%p dlci %d", s, dlci);	cmd.addr = __addr(!s->initiator, dlci);	cmd.ctrl = __ctrl(RFCOMM_UA, 1);	cmd.len  = __len8(0);	cmd.fcs  = __fcs2((u8 *) &cmd);	return rfcomm_send_frame(s, (void *) &cmd, sizeof(cmd));}static int rfcomm_send_disc(struct rfcomm_session *s, u8 dlci){	struct rfcomm_cmd cmd;	BT_DBG("%p dlci %d", s, dlci);	cmd.addr = __addr(s->initiator, dlci);	cmd.ctrl = __ctrl(RFCOMM_DISC, 1);	cmd.len  = __len8(0);	cmd.fcs  = __fcs2((u8 *) &cmd);	return rfcomm_send_frame(s, (void *) &cmd, sizeof(cmd));}static int rfcomm_queue_disc(struct rfcomm_dlc *d){	struct rfcomm_cmd *cmd;

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品传媒入口麻豆| 处破女av一区二区| 粉嫩av亚洲一区二区图片| 在线观看一区日韩| 久久久综合精品| 日韩av午夜在线观看| 日韩中文字幕区一区有砖一区| 香蕉av福利精品导航| 国产精品一区二区三区99| 欧美性猛交xxxx黑人交| 国产日韩精品一区二区三区在线| 亚洲国产你懂的| 99v久久综合狠狠综合久久| 精品免费国产一区二区三区四区| 亚洲一二三级电影| 99综合电影在线视频| 国产女人aaa级久久久级| 九色porny丨国产精品| 欧美日韩国产高清一区二区| 成人免费在线播放视频| 国产91清纯白嫩初高中在线观看| 欧美一区二区啪啪| 同产精品九九九| 亚洲成人一区在线| 91麻豆精品秘密| 国产精品理论在线观看| 成人一区二区三区中文字幕| 国产婷婷色一区二区三区| 激情六月婷婷综合| 久久蜜桃一区二区| 国产高清无密码一区二区三区| 欧美mv日韩mv国产网站| 国内久久精品视频| 久久综合色之久久综合| 国产一区二区在线观看免费| 久久理论电影网| 国产成a人亚洲精| 国产精品萝li| 91高清在线观看| 丝袜美腿亚洲色图| 精品美女一区二区三区| 国产麻豆9l精品三级站| 国产精品美日韩| 91国偷自产一区二区三区观看| 亚洲网友自拍偷拍| 91麻豆精品国产91久久久久久久久 | 亚洲国产精品自拍| 欧美精品乱码久久久久久| 免费的成人av| 中文字幕精品三区| 欧美主播一区二区三区| 蜜臀av性久久久久蜜臀aⅴ流畅| 欧美tickling网站挠脚心| 东方aⅴ免费观看久久av| 亚洲男人天堂av| 欧美一区二区观看视频| 成人免费福利片| 偷拍一区二区三区| 国产亚洲欧美在线| 色综合久久久久| 美腿丝袜亚洲一区| 中文字幕一区二区三| 91精品一区二区三区久久久久久| 国产高清亚洲一区| 亚洲成av人影院| 欧美激情综合五月色丁香| 欧美日韩精品一区二区三区四区| 激情都市一区二区| 亚洲综合视频网| 久久久久国产精品人| 欧美性欧美巨大黑白大战| 国产在线播放一区二区三区| 亚洲黄色免费网站| 亚洲精品在线免费播放| 欧美丝袜丝nylons| 丁香天五香天堂综合| 日本欧美一区二区| 成人欧美一区二区三区白人| 日韩精品一区二区三区在线 | 国产精品一区一区| 亚洲专区一二三| 国产精品第四页| 久久综合狠狠综合| 欧美日韩一区在线| 成人aa视频在线观看| 日本三级亚洲精品| 亚洲综合在线电影| 国产精品美女视频| 久久这里只有精品首页| 在线成人免费视频| 99精品黄色片免费大全| 国产精品资源在线观看| 久久精品久久综合| 午夜视频在线观看一区二区三区| 国产精品国产自产拍在线| 26uuu欧美日本| 日韩欧美精品在线视频| 7777精品伊人久久久大香线蕉经典版下载 | 午夜在线成人av| 亚洲免费在线视频一区 二区| 欧美国产精品久久| 国产亚洲欧美日韩日本| 久久久亚洲精品石原莉奈| 欧美成va人片在线观看| 51精品国自产在线| 欧美另类z0zxhd电影| 欧美三级电影一区| 欧美精品xxxxbbbb| 91麻豆精品91久久久久久清纯| 欧美视频你懂的| 欧美日韩午夜在线视频| 欧美久久久久久蜜桃| 欧美日韩一二三| 欧美日韩成人综合天天影院 | 在线视频欧美区| 在线免费视频一区二区| 欧美影视一区在线| 欧美日韩大陆在线| 日韩欧美激情一区| www日韩大片| 日本一区二区电影| 亚洲欧美电影院| 亚洲专区一二三| 日本最新不卡在线| 国内外成人在线| 北岛玲一区二区三区四区| 成人av免费在线| 色一情一伦一子一伦一区| 欧洲色大大久久| 日韩美女在线视频| 亚洲国产成人午夜在线一区 | 欧美精品vⅰdeose4hd| 日韩欧美久久久| 国产日韩欧美精品电影三级在线| 国产精品丝袜91| 悠悠色在线精品| 麻豆91小视频| 成人国产精品免费观看| 一本久久综合亚洲鲁鲁五月天 | 日韩一区二区在线观看| 久久综合成人精品亚洲另类欧美| 亚洲国产电影在线观看| 一区二区成人在线观看| 日韩成人精品在线| 国产精品一色哟哟哟| 在线视频一区二区免费| 精品久久久久久久久久久久久久久久久| 精品国产伦一区二区三区免费 | 国产亚洲精品7777| 亚洲精品国产一区二区精华液 | 亚洲成人一区二区在线观看| 久久成人免费日本黄色| 成人黄色av电影| 91精品国产入口在线| 中文字幕中文乱码欧美一区二区| 午夜不卡av在线| 成人免费观看av| 日韩精品中文字幕在线一区| 亚洲欧洲日韩在线| 精品一区二区三区在线视频| 色系网站成人免费| 久久精品人人做人人综合| 亚洲成va人在线观看| 成人精品亚洲人成在线| 精品欧美久久久| 亚州成人在线电影| 成人激情综合网站| 欧美一区二区三区四区久久| 一区二区三区美女视频| 国产精品一品二品| 日韩一区二区三区视频在线观看| 日韩毛片视频在线看| 国产一区 二区| 日韩欧美的一区| 日日噜噜夜夜狠狠视频欧美人| 99精品视频在线观看免费| 久久精品夜夜夜夜久久| 精品综合久久久久久8888| 欧美精品日韩一区| 亚洲电影第三页| 色猫猫国产区一区二在线视频| 国产精品水嫩水嫩| 国产成人av电影在线| 精品久久人人做人人爰| 青青青伊人色综合久久| 91精品欧美一区二区三区综合在| 亚洲一区二区在线观看视频| 91视频你懂的| 亚洲视频图片小说| 91浏览器入口在线观看| 成人欧美一区二区三区黑人麻豆| 成人精品免费看| 中文一区二区在线观看| 国产aⅴ综合色| 欧美国产日产图区| av在线不卡免费看| 一区二区三区在线免费观看| 欧美在线短视频| 婷婷开心激情综合| 欧美一区二区三区免费大片|