日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 综合教程 >内容正文

综合教程

Linux下robust互斥锁实现

發布時間:2023/12/15 综合教程 42 生活家
生活随笔 收集整理的這篇文章主要介紹了 Linux下robust互斥锁实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、robust互斥鎖
這種類型的鎖可能不是POSIX標準中規定的鎖,但是也有可能是,這個不太確定,暫時不管。這種類型的鎖主要是解決當一個持有互斥鎖的線程退出之后這個鎖成為不可用狀態的一個問題來的??梢韵胂?,一個線程可能持有很多的鎖,也可能沒有,如果此時有一個外部(被其它任務kill)或者內部(出現訪問問題或者直接pthread_exit)原因而推出線程,此時雖然這個線程退出是一了百了了,但是其它的線程還是希望能夠堅強的運行下去,此時就需要有一些機制來保證這個線程持有的那些希望被自動釋放的鎖有一種方法能夠被釋放,而這個工作就責無旁貸的落在了內核的身上。
從具體實現上來看,它打破了我們常規的“用戶態VS內核態”的模式,模糊了用戶和內核的概念,因為內核會遍歷用戶態提供的鏈表,這個是一個危險的操作,因為這個鏈表對內核來說是可能出現環路的,內存訪問錯誤倒是小事。在魔獸中,獸族的斧頭兵在沖鋒陷陣的時候喊得口號是“為了部落”,而內核的程序員在寫程序的時候喊的口號一定是“為了效率”。
二、信號類型的聲明
這些鎖的類型一般中間有一個ROBUST關鍵字,如果同學們有glibc的代碼,看一下glibc-2.7
ptlpthreadP.h文件中那些ROBUST類型的類型聲明就可以知道它們的家族了,和普通的鎖類型相同,也有一些ERROR_CHECK類型的互斥鎖,當然可能不是POSIX標準,如果對跨平臺要求比較嚴格,請慎用。
這個robust屬性的設置需要使用專門的接口pthread_mutexattr_setrobust_np函數來設置,對于這些NP后綴的,我一直懷疑他們是NonPosix的縮寫,未經證實,但是也有可能是POSIX的某個版本之后追加的一些性能也不好說。
三、向內核注冊鏈表首地址
內核為了實現這種鎖,專門提供了兩個系統調用,分別是sys_set_robust_list和sys_get_robust_list,由于或者對于我們這次分析沒有什么影響,所以我們只看一下注冊的接口:
asmlinkage long
sys_set_robust_list(struct robust_list_head __user *head,
size_t len)
{
/*
* The kernel knows only one size for now:
*/
if (unlikely(len != sizeof(*head)))
return -EINVAL;

current->robust_list = head;內核還專門為每個線程的控制結構中添加了一個robust_list成員來記錄用戶態注冊的鏈表頭,事實上他是一個robust_list_head類型的結構

return 0;
}
四、用戶態注冊
1、相關結構的分配與初始化
glibc-2.7
ptlallocatestack.c
allocate_stack (const struct pthread_attr *attr, struct pthread **pdp, ALLOCATE_STACK_PARMS)
/* The robust mutex lists also need to be initialized
unconditionally because the cleanup for the previous stack owner
might have happened in the kernel. */
pd->robust_head.futex_offset= (offsetof (pthread_mutex_t, __data.__lock)
- offsetof (pthread_mutex_t,
__data.__list.__next));這個偏移量是編譯時確定的,它的值是pthread_mutex_t結構中__lock成員和__list成員之間的相對字節偏移處,之前說過,內核是需要遍歷用戶態鏈表的,根據最為原始的鏈表(就是我們上任何一個數據結構中都會提到的)就是一個 struct node {struct node *next; type var;}類型的結構,但是內核說為了給用戶態任務更大的自由度,內核不能假設這個__lock就是這么正正經經的緊鄰著鏈表成員,所以提供了一個offset,這樣兩者之間可以有更多的控制結構,事實上C庫也就是這么實現的,它們的確不是連續的。有人問,問什么這么巧呢?因為C庫中相關功能的開發是和內核同步的,可以說是C庫的需求促使了內核該功能的添加,是一個訂制功能
pd->robust_head.list_op_pending = NULL;
#ifdef __PTHREAD_MUTEX_HAVE_PREV
pd->robust_prev = &pd->robust_head;
#endif
pd->robust_head.list = &pd->robust_head;初始情況下下,鏈表自回環,為空
2、向內核注冊
glibc-2.7
ptlpthread_create.c
start_thread (void *arg)
#ifdef __NR_set_robust_list
# ifndef __ASSUME_SET_ROBUST_LIST
if (__set_robust_list_avail >= 0)
# endif
{
INTERNAL_SYSCALL_DECL (err);
/* This call should never fail because the initial call in init.c
succeeded. */
INTERNAL_SYSCALL (set_robust_list, err, 2, &pd->robust_head,這個接口沒什么好說的,和內核接口直接對應,用戶態和內核態共享結構
sizeof (struct robust_list_head));
}
#endif
五、用戶態如何獲得ROBUST鎖
1、robust鎖的獲取操作
對于robust鎖,內核和用戶態約定了這個__lock的意義,它的低30bits用來記錄當前鎖持有者的線程id號,剩余高2bits記錄FUTEX_WAITERS和FUTEX_OWNER_DIED標志bit。
glibc-2.7
ptlpthread_mutex_lock.c中__pthread_mutex_lock (mutex)函數

THREAD_SETMEM (THREAD_SELF,robust_head.list_op_pending,首先設置內核和用戶態共享的list_op_pending結構,注意的是,這是一個指針,而不是鏈表,它只有一個元素,這和前面說的 robust_list list成員的意義不同,至于為什么有這個成員,我們之后再解釋
&mutex->__data.__list.__next);

oldval = mutex->__data.__lock;
do
{
again:
if ((oldval &FUTEX_OWNER_DIED) != 0)首先判斷是不是持有者已經在沒有釋放鎖的情況下掛掉了。
{
/* The previous owner died. Try locking the mutex. */
int newval = id;
#ifdef NO_INCR
newval |= FUTEX_WAITERS;
#else
newval |= (oldval & FUTEX_WAITERS);
#endif

newval
= atomic_compare_and_exchange_val_acq (&mutex->__data.__lock,
newval,oldval);嘗試原子性修改鎖值,這個值內核和用戶態共享各個bit的意義。

if (newval != oldval)
{
oldval = newval;
goto again;原子操作失敗,重試。
}

/* We got the mutex. */
mutex->__data.__count = 1;
/* But it is inconsistent unless marked otherwise. */
mutex->__data.__owner =PTHREAD_MUTEX_INCONSISTENT;持有者設置為不一致,因為這是從死亡者里拿到的東西,相當于是“腐尸”。

ENQUEUE_MUTEX (mutex);這個操作比較重要,它會把這個鎖太添加到 robust_list list鏈表的開始,表明自己已經獲得了這個鎖,實現比較簡單,這里省略。
THREAD_SETMEM (THREAD_SELF, robust_head.list_op_pending, NULL);清空op_pending列表,這個列表在執行鎖操作之前初始化。

/* Note that we deliberately exit here. If we fall
through to the end of the function __nusers would be
incremented which is not correct because the old
owner has to be discounted. If we are not supposed
to increment __nusers we actually have to decrement
it here. */
#ifdef NO_INCR
--mutex->__data.__nusers;
#endif

return EOWNERDEAD;這里雖然獲得了鎖,但是低調的返回EOWNERDEAD,反過來說,雖然返回值為EOWNERDEAD,但是鎖還是已經獲得了。
}
………………
oldval =LLL_ROBUST_MUTEX_LOCK(mutex, id);這個操作本質上也是來修改__lock結構為當前線程的tid(其中的id就是線程的tid),只是它做了更多的功能,那就是判斷當獲得鎖失敗的時候貼心的將線程掛起。反過來說,當一個線程因為OWNERDEAD被喚醒之后,它同樣會從這里返回,并執行這個while大循環,判斷出ownerdead標志位。

if (__builtin_expect (mutex->__data.__owner
==PTHREAD_MUTEX_NOTRECOVERABLE, 0))如果pthread_mutex_lock返回EOWNERDEAD而調用者沒有執行pthread_mutex_consistent_np函數,那么將會滿足該條件,這下可能真的是完蛋去了
{
/* This mutex is now not recoverable. */
mutex->__data.__count = 0;
lll_unlock (mutex->__data.__lock,
PTHREAD_ROBUST_MUTEX_PSHARED (mutex));
THREAD_SETMEM (THREAD_SELF, robust_head.list_op_pending, NULL);
return ENOTRECOVERABLE;
}
}
while ((oldval & FUTEX_OWNER_DIED) != 0);

mutex->__data.__count = 1;
ENQUEUE_MUTEX (mutex);
THREAD_SETMEM (THREAD_SELF, robust_head.list_op_pending, NULL);
break;
2、list_op_pending的意義
前面說過,這個不是鏈表,而只是一個簡單的指針,它一次只指向一個元素。為什么要這個結構呢?因為這個操作是極為特殊的,特殊之處在于它獲得一個鎖需要執行兩個操作:
1、一個是設置好__lock為自己的tid
2、將這個mutex結構添加到內核識別的robust_list鏈表中去。
這兩個操作明顯不是原子性的,假設在第一步執行結束之后,任務被殺死,那么線程退出的時候這個鎖是沒有辦法被喚醒的,雖然它事實上已經獲得了這個鎖,但是由于沒有注冊到內核識別的鏈表中而無法被喚醒,這樣就有可能出現悲劇。通常解決原子性操作的方法就是加鎖,但是這里是鎖本身,所以沒有辦法依賴鎖,只能添加一個可能會競爭的op_pending鏈表,從而讓內核這個可以關中斷并處理鎖的機制來完成這個原子性。這和我們解決問題的模式是一樣的,如果這層沒有辦法做,那么就向下推一層。
六、內核態喚醒
1、喚醒時機
do_exit--->>>exit_robust_list
if (pending)如果pending鏈表非空,那么表示“可能”存在一個鎖,所以嘗試進行喚醒。
handle_futex_death((void __user *)pending + futex_offset, curr, pip);

while (entry != &head->list) {這個循環是真正變臉head結構鏈表,其中的每一項都是貨真價實的等待被喚醒的robust鎖,當然里面還有一個比較特殊的entry!=pending判斷,著同樣是用戶態院子操作的保證,有興趣的同學可以分析一下在用戶態哪個位置切換會出現entry==pending的情況(請大家不要懷疑我是不是知道)。
/*
* A pending lock might already be on the list, so
* don't process it twice:
*/
if (entry != pending)
if (handle_futex_death((void __user *)entry + futex_offset,
curr, pi))
return;
/*
* Fetch the next entry in the list:
*/
if (fetch_robust_entry(&entry, &entry->next, &pi))
return;
/*
* Avoid excessively long or circular lists:
*/
if (!--limit)這里最為高效的防止出現循環鏈表的方法,就是假設鏈表最多為 ROBUST_LIST_LIMIT 2048項。
break;

cond_resched();
}
2、喚醒函數

/*
* Process a futex-list entry, check whether it's owned by the
* dying task, and do notification if so:
*/
int handle_futex_death(u32 __user *uaddr, struct task_struct *curr, int pi)
{
u32 uval, nval, mval;

retry:
if (get_user(uval, uaddr))
return -1;

if ((uval & FUTEX_TID_MASK) == curr->pid) {如果退出線程持有該鎖。
/*
* Ok, this dying thread is truly holding a futex
* of interest. Set the OWNER_DIED bit atomically
* via cmpxchg, and if the value had FUTEX_WAITERS
* set, wake up a waiter (if any). (We have to do a
* futex_wake() even if OWNER_DIED is already set -
* to handle the rare but possible case of recursive
* thread-death.) The rest of the cleanup is done in
* userspace.
*/
mval = (uval & FUTEX_WAITERS) |FUTEX_OWNER_DIED;設置用戶態最為關心的OWNER_DIED標志。
nval = futex_atomic_cmpxchg_inatomic(uaddr, uval, mval);

if (nval == -EFAULT)
return -1;

if (nval != uval)
goto retry;

/*
* Wake robust non-PI futexes here. The wakeup of
* PI futexes happens in exit_pi_state():
*/
if (!pi) {
if (uval &FUTEX_WAITERS)如果該鎖上有等待者。
futex_wake(uaddr, 1);這里注意的是此處只會喚醒一個,因為喚醒多個只會讓用戶態更亂,沒有意義。
}
}
return 0;
}
七、pthread_mutex_consistent_np函數的意義
int
pthread_mutex_consistent_np (mutex)
pthread_mutex_t *mutex;
{
/* Test whether this is a robust mutex with a dead owner. */
if ((mutex->__data.__kind & PTHREAD_MUTEX_ROBUST_NORMAL_NP) == 0
|| mutex->__data.__owner != PTHREAD_MUTEX_INCONSISTENT)
return EINVAL;

mutex->__data.__owner = THREAD_GETMEM (THREAD_SELF, tid);

return 0;
}
如果不執行,在__pthread_mutex_lock函數返回EOWNERDEAD之后,鎖的__owner將被設置為PTHREAD_MUTEX_INCONSISTENT
mutex->__data.__owner = PTHREAD_MUTEX_INCONSISTENT;
然后在持有者執行pthread_mutex_unlock的時候
/* If the previous owner died and the caller did not succeed in
making the state consistent, mark the mutex as unrecoverable
and make all waiters. */
if (__builtin_expect (mutex->__data.__owner
== PTHREAD_MUTEX_INCONSISTENT, 0))
notrecoverable:
newowner =PTHREAD_MUTEX_NOTRECOVERABLE;
而其它線程再次執行pthread_mutex_lock的時候,
if (__builtin_expect (mutex->__data.__owner
==PTHREAD_MUTEX_NOTRECOVERABLE, 0))
{
/* This mutex is now not recoverable. */
mutex->__data.__count = 0;
lll_unlock (mutex->__data.__lock,
PTHREAD_ROBUST_MUTEX_PSHARED (mutex));
THREAD_SETMEM (THREAD_SELF, robust_head.list_op_pending, NULL);
returnENOTRECOVERABLE;
}
可見,從原始的INCONSISTENT轉換為NOTRECOVERABLE還是一個比較嚴重的問題,開始只是“不一致”,最后就“無可挽回”了。




總結

以上是生活随笔為你收集整理的Linux下robust互斥锁实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

啪啪午夜免费 | 国产精品一区二区精品视频免费看 | 国产综合福利在线 | 五月天综合婷婷 | 一区二区三区四区五区在线 | 在线免费观看国产视频 | 日韩av一卡二卡三卡 | 国产伦精品一区二区三区… | 国产日韩在线一区 | 成人av午夜 | 91网在线观看 | 日韩二区精品 | 日日干日日 | 一区二区三区四区精品 | 91av在线视频免费观看 | av资源免费观看 | 国产手机在线播放 | 一区在线观看 | 国产99久久九九精品免费 | 中中文字幕av在线 | 制服丝袜一区二区 | 人人干免费| 国语对白少妇爽91 | 亚洲第一区精品 | 色老板在线 | 国产视频在线观看一区 | 亚洲天堂网视频在线观看 | 中文字幕久久精品亚洲乱码 | 精品亚洲免费视频 | 亚洲五月综合 | 欧美一级日韩三级 | 久久久久久久久影视 | 91av社区| 综合色天天 | 亚洲综合导航 | 亚洲国产综合在线 | 97精品视频在线播放 | 亚洲精品资源在线观看 | 免费人成网ww44kk44 | 国产高清一 | 中文字幕精品三级久久久 | 国产不卡在线播放 | 五月婷婷精品 | 婷香五月| 精品国内自产拍在线观看视频 | 97视频在线观看网址 | 69绿帽绿奴3pvideos | 国产精品久久电影观看 | 99精品国产亚洲 | 免费看污在线观看 | 国产电影一区二区三区四区 | 六月激情 | 免费麻豆视频 | 人人藻人人澡人人爽 | 性色av香蕉一区二区 | 成人影视片 | 99精品99 | 国产精品久久久久一区二区三区 | 欧美性性网 | av在线电影网站 | 国产视频亚洲视频 | 黄网站色欧美视频 | 8090yy亚洲精品久久 | 欧美在线aa| 看毛片网站| www免费视频com━ | 深爱开心激情 | 午夜私人影院久久久久 | 一区二区视频在线播放 | 热久久国产精品 | 国产精品一区二区久久国产 | 色五丁香 | 欧美精品一区二区在线观看 | 日韩中文字幕免费在线观看 | 久久乱码卡一卡2卡三卡四 五月婷婷久 | 天天躁日日躁狠狠躁 | 夜添久久精品亚洲国产精品 | 91福利社区在线观看 | 色婷婷亚洲婷婷 | 免费视频久久久久久久 | 天天舔天天射天天操 | 国产精品a久久久久 | 国产在线一线 | 久久99深爱久久99精品 | 中文视频在线 | 日日操夜夜操狠狠操 | 日本黄色大片免费看 | 日本xxxxav | 在线不卡视频 | www.夜色.com| 在线国产视频一区 | av中文在线影视 | 国产一线二线三线在线观看 | 91色偷偷| 操久 | 一本一道久久a久久精品蜜桃 | 国产精品剧情 | 日韩黄色av网站 | 色婷婷精品大在线视频 | 精品国产一区二区三区久久久久久 | adn—256中文在线观看 | 精品国产一二三 | 久久不见久久见免费影院 | 91九色蝌蚪在线 | 东方av在 | 欧美肥妇free| 亚洲欧美日韩精品久久奇米一区 | 亚洲无吗天堂 | 精品欧美一区二区在线观看 | 美女黄网站视频免费 | 亚洲精品视频国产 | 国产精品久久久久久高潮 | 亚洲欧洲精品久久 | 久久精品综合视频 | 天天射天天添 | 日日干美女 | 天天色天天色天天色 | 国产精品福利久久久 | 狠狠操夜夜 | 国产精品毛片一区视频播不卡 | 国产无遮挡又黄又爽在线观看 | 久久免费国产电影 | 91精品久久久久久 | 天天干天天操人体 | 亚洲黄色在线播放 | 免费视频资源 | www色婷婷com | 成年免费在线视频 | 99热超碰 | 在线国产中文字幕 | 亚洲综合激情小说 | 久久综合久久久 | 色婷婷啪啪免费在线电影观看 | 国产精品大片免费观看 | 色在线网| 亚洲黄色免费电影 | 性色av一区二区三区在线观看 | 天天色天天搞 | 日韩最新在线视频 | 中文字幕亚洲精品在线观看 | 日本在线观看一区二区三区 | 精品国产91亚洲一区二区三区www | 国产精品专区在线观看 | 国产亚洲午夜高清国产拍精品 | 成人手机在线视频 | 爱av在线网 | 成人一级电影在线观看 | 中文字幕在线观看日本 | 17videosex性欧美 | 91系列在线观看 | 久久国产精品久久国产精品 | 天天操操操操操操 | 最新av在线播放 | 国产精品中文字幕在线观看 | 国产精品视频专区 | 91成人精品一区在线播放69 | 在线色亚洲 | 日韩中文字幕在线观看 | 在线观看中文字幕亚洲 | 日韩字幕在线观看 | 日韩成人精品一区二区 | 久久欧洲视频 | 午夜久操 | 久久成电影 | 91 在线视频| 国产91精品一区二区麻豆网站 | 成年人电影免费在线观看 | www.久久久久 | 亚洲精品成人av在线 | 国产中文字幕在线观看 | 久久人人添人人爽添人人88v | 日韩精品不卡 | www.99av | 亚洲va天堂va欧美ⅴa在线 | av电影不卡在线 | 成人蜜桃| 免费视频黄色 | 国产精品免费久久久久久久久久中文 | 久久久久久99精品 | 天天亚洲综合 | 狠狠干在线 | 欧美国产精品一区二区 | 在线视频福利 | 全久久久久久久久久久电影 | a特级毛片| 中文资源在线播放 | 免费下载高清毛片 | 国产精品ssss在线亚洲 | 国产一级特黄电影 | www激情久久 | 久久综合毛片 | 一本一道久久a久久精品 | 欧美激情综合五月色丁香 | 国产香蕉视频在线观看 | 黄色一级性片 | 免费av网站观看 | 国产精品视频地址 | 国产在线观看av | 在线视频 亚洲 | 日韩激情视频在线观看 | 欧美精品免费一区二区 | 久久观看免费视频 | www.五月婷婷.com | 国产精品久久久久国产a级 激情综合中文娱乐网 | 中文字幕日本特黄aa毛片 | 激情综合久久 | 日韩久久精品 | 97国产精品亚洲精品 | 成人黄色影片在线 | 国产精品成人久久久 | 国内视频在线观看 | 麻豆国产网站入口 | www.夜夜 | 最近2019年日本中文免费字幕 | 亚洲精品麻豆视频 | 99免费精品 | 美女视频黄频大全免费 | 日日夜夜噜噜噜 | 久久久福利 | 国产无吗一区二区三区在线欢 | 日韩网站一区二区 | 国产日韩欧美在线播放 | 日韩精品不卡在线观看 | 精品国产伦一区二区三区观看说明 | 91.精品高清在线观看 | 午夜精品一区二区三区在线观看 | 性色av免费看 | av天天澡天天爽天天av | 日本久久高清视频 | 欧美精品久久人人躁人人爽 | 欧美一二三区在线播放 | 久久久久久网址 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 国产99在线免费 | 国产小视频在线观看 | 国产成人精品日本亚洲999 | 91成年人视频 | 国产精品久久片 | 久久草视频| 欧美乱码精品一区二区 | 五月激情丁香图片 | 成人av在线播放网站 | 成人毛片100免费观看 | 香蕉视频免费在线播放 | 亚洲激情综合网 | 欧美性大战 | 国产操在线 | 久久免费的精品国产v∧ | 中文字幕资源站 | 国产精品欧美久久久久无广告 | 99久久夜色精品国产亚洲 | 午夜久草 | 日韩电影在线一区二区 | 黄网站免费大全入口 | 91av福利视频| 丁香激情综合久久伊人久久 | 五月激情五月激情 | www.色婷婷.com | 亚洲爽爽网| 欧美性久久久 | 九九九九精品 | 天天干亚洲 | 手机av资源 | 久久久久久国产一区二区三区 | 国产美女精品视频免费观看 | 91激情 | 四虎5151久久欧美毛片 | 我爱av激情网 | 国产精品www | 日韩特黄一级欧美毛片特黄 | 国产精品亚洲片夜色在线 | 波多野结衣精品在线 | 日韩电影在线视频 | 激情网在线视频 | 一区二区三区四区精品视频 | 国产一级视屏 | 国产69久久久欧美一级 | 色综合天天综合在线视频 | 成人久久影院 | 日本视频不卡 | 国产区精品视频 | 成人av在线影视 | 麻花豆传媒mv在线观看网站 | 97国产超碰在线 | 成人黄色在线观看视频 | 国产精品欧美久久久久三级 | av久久在线 | 狠狠操精品 | 日韩精品一区二区免费视频 | 91精品日韩 | 国产午夜精品福利视频 | 激情小说网站亚洲综合网 | 日韩成人av在线 | 美女黄色网在线播放 | 久久精品免视看 | 狠狠88综合久久久久综合网 | 97视频免费看| 中文字幕一区二区三区四区在线视频 | 视频成人永久免费视频 | 国产精品久久久久久久久久99 | 久久综合之合合综合久久 | 91免费高清观看 | 日本中文字幕电影在线免费观看 | 四虎在线观看网址 | 黄色网址国产 | 国产精品18毛片一区二区 | 日韩久久在线 | 国产剧情一区二区 | 久草在线视频中文 | 国产一级黄色免费看 | 六月色丁香 | 精品国产乱码久久久久久浪潮 | 成人av教育| 国产精品va在线观看入 | 中文字幕在线观看的网站 | 午夜精品久久久久久中宇69 | 日韩欧美在线视频一区二区 | 久久久久久久久黄色 | 日韩av片免费在线观看 | 天天干天天干天天 | 久久久亚洲麻豆日韩精品一区三区 | 色五月激情五月 | 黄色免费网站下载 | 国产精品久久99综合免费观看尤物 | 成人中文字幕在线 | 亚洲欧美在线综合 | 国产精品成人免费 | 国产精品欧美 | 九色最新网址 | 免费网站黄 | 国产一区二区久久久久 | 在线播放日韩av | 九色精品免费永久在线 | 精品久久1 | 中文在线免费一区三区 | 西西444www高清大胆 | 人人澡av | 午夜精品一区二区三区免费视频 | 日本三级国产 | 亚洲精品视频在线播放 | 国产精品午夜久久久久久99热 | 天天操天天摸天天射 | 高清视频一区 | 青草视频在线 | 成人99免费视频 | 色资源在线 | 久草精品视频在线看网站免费 | 天堂黄色片 | 91精品国产99久久久久久久 | 91日韩在线专区 | 97av视频| 日韩羞羞| 国产色婷婷在线 | 最新日韩精品 | 国产偷国产偷亚洲清高 | 激情综合亚洲精品 | 国产精品精品久久久久久 | 四虎精品成人免费网站 | 97精品免费视频 | 国产在线观看污片 | 久久免费中文视频 | 成人免费观看视频网站 | 国产黄影院色大全免费 | 亚洲激情网站免费观看 | 国产视频一二三 | 亚洲视频每日更新 | 黄色一集片 | 国产啊v在线观看 | 欧美aaaxxxx做受视频 | 国产精品第二页 | 久久精品超碰 | 国产黄色片免费在线观看 | 免费av黄色 | 国产日韩欧美在线一区 | 国产欧美三级 | 亚洲精品久久久久久久蜜桃 | 久久艹久久| 免费国产ww | 黄网站色视频 | 国产精品嫩草影院9 | 国产 成人 久久 | 日韩免费一级电影 | 国产日韩精品一区二区三区在线 | 亚洲老妇xxxxxx | 国产91精品一区二区麻豆网站 | 免费无遮挡动漫网站 | 国产精品videossex国产高清 | 男女激情免费网站 | 欧美在线free | 黄色av免费看 | 亚洲欧美国产精品久久久久 | 日韩在线观看视频一区二区三区 | 天天色天天爱天天射综合 | 在线免费看黄色 | 欧美日韩国产二区三区 | 亚洲精品一区二区三区高潮 | 天天色天天射综合网 | 日韩午夜av电影 | 天天干,天天草 | 在线性视频日韩欧美 | 91精品国产一区二区三区 | 999视频在线播放 | 成人a级网站 | 一级片视频在线 | 欧美亚洲免费在线一区 | 免费麻豆视频 | 97精品在线观看 | 国产综合在线观看视频 | 免费欧美| 粉嫩av一区二区三区四区在线观看 | 麻豆国产网站入口 | 亚洲精品国产综合久久 | 成人黄色资源 | 99亚洲天堂| 91插插影库 | 在线国产能看的 | 久久久香蕉视频 | 欧美激情xxxx性bbbb | 久久福利影视 | 国产亚洲精品久久久久秋 | 中文字幕在线观看一区 | 就要干b | 超碰在线观看av.com | 国产91成人在在线播放 | 久久综合免费视频影院 | 中文字幕国产精品 | av免费在线观看网站 | 永久黄网站色视频免费观看w | 顶级欧美色妇4khd | 永久免费在线 | 麻豆视频国产在线观看 | 日韩在线高清免费视频 | 色www免费视频 | 国产精品免费观看久久 | 欧美国产不卡 | 日韩av视屏 | 亚洲色图美腿丝袜 | 日韩精品中文字幕在线 | 狠狠狠色丁香综合久久天下网 | 久久无码精品一区二区三区 | 色网站在线免费观看 | 精品中文字幕在线播放 | 亚洲2019精品 | 国产精品入口久久 | 天天天天综合 | 99热最新在线 | 欧美精品免费一区二区 | 成全免费观看视频 | 久久久久久在线观看 | 毛片区| 国产成人精品一区二三区 | 欧美激情综合五月色丁香小说 | 欧美精品小视频 | 中文字幕高清有码 | 香蕉成人在线视频 | 狠狠的操你| 在线免费观看黄 | 国产麻豆电影在线观看 | 国产一级在线免费观看 | 日本黄色免费在线观看 | 在线电影 你懂得 | 国产高清在线免费 | 亚洲天堂网在线播放 | 久久全国免费视频 | 亚洲最快最全在线视频 | 精品国产一区二区三区在线 | 精品视频成人 | 久久久免费播放 | 美女免费网站 | 天天操天天射天天操 | www.五月天婷婷.com | 91成人免费在线视频 | 日韩视频图片 | 激情av资源网 | 正在播放 国产精品 | 亚洲国产av精品毛片鲁大师 | 一级黄色片在线 | 欧美日韩视频免费 | 国内久久久久 | 久草精品视频在线观看 | 在线观看精品一区 | 不卡国产视频 | 青草草在线视频 | 日本久久综合视频 | 精油按摩av| 欧美精品国产综合久久 | 激情网五月婷婷 | 91高清不卡 | 国产精品麻豆果冻传媒在线播放 | 在线黄色国产 | 99精品国自产在线 | 国产精品一区二区电影 | 成人免费看电影 | 在线黄色国产电影 | 热re99久久精品国产66热 | 在线观看91网站 | 国内久久看 | 久久国产精品第一页 | 色爱区综合激月婷婷 | 亚洲高清视频在线观看免费 | 不卡的av在线播放 | 国产成人免费精品 | 91中文字幕网 | 久久免费视频播放 | 久久玖 | 国产一区二区精品在线 | 欧美日韩在线看 | 日韩欧美第二页 | 黄色小说视频在线 | 99热这里只有精品国产首页 | 丁香电影小说免费视频观看 | 国产成人精品一区二区在线观看 | 最近2019好看的中文字幕免费 | 国内精品久久久久久久影视麻豆 | 日日干 天天干 | 精品国产乱子伦一区二区 | 伊人狠狠 | 视频在线一区二区三区 | 欧美影院久久 | 黄p在线播放 | 国产成人久久久77777 | 久久精品欧美视频 | 三级免费黄 | 亚洲 欧美 国产 va在线影院 | 色婷婷国产精品一区在线观看 | 成人午夜精品久久久久久久3d | 国产免费嫩草影院 | 天堂av网在线 | 精品国产免费一区二区三区五区 | 中文字幕在线看人 | 中文字幕中文中文字幕 | 日韩 在线 | 五月婷婷网站 | 热久在线 | 丁香花在线视频观看免费 | 成人a视频在线观看 | 久久精品欧美一 | 婷婷 综合 色 | 99精品免费久久久久久久久日本 | 国产精品久久久久永久免费观看 | 国产福利一区二区在线 | 国产精品一区二区免费在线观看 | 亚洲午夜av电影 | 精品久久精品久久 | 国产香蕉97碰碰碰视频在线观看 | 久久一区二区三区四区 | 日韩电影在线观看中文字幕 | 在线观看视频h | 亚洲自拍自偷 | 日韩欧美一区二区三区黑寡妇 | 九九视频这里只有精品 | 色婷婷综合视频在线观看 | 88av视频| 日韩二区三区在线 | 国产97免费| 五月激情姐姐 | 日韩三级av | 国产伦精品一区二区三区在线 | 国产精品久久久毛片 | 国产精品久久久久久久免费观看 | 麻花豆传媒mv在线观看 | 免费在线观看一区二区三区 | 99re8这里有精品热视频免费 | 午夜久久网站 | 精品视频999 | 综合网天天 | 亚洲综合在线播放 | 日韩美一区二区三区 | av在线亚洲天堂 | 午夜久久福利影院 | 久在线观看视频 | 精品国产亚洲在线 | 精品免费一区二区三区 | 日韩在线观看小视频 | 天天爱天天色 | av色综合网 | 在线91播放| 亚洲成人精品影院 | 欧美一级免费 | 久久久久亚洲最大xxxx | 91一区二区三区久久久久国产乱 | 国产亚洲片 | 91精品国产麻豆国产自产影视 | 日韩小视频 | 久久99国产精品 | 97超碰人人干 | 精品免费 | 国产小视频在线免费观看 | 成人黄大片视频在线观看 | 中文字幕日韩一区二区三区不卡 | 草久久久久 | 国产专区免费 | 国产一区二区在线精品 | 色狠狠干 | 国产一区成人 | 日本久久久亚洲精品 | 日韩在线观看视频一区二区三区 | 99久热 | 91电影福利 | 婷婷色网 | 在线观看亚洲精品 | 九九免费在线看完整版 | 久久综合五月婷婷 | 中文字幕色婷婷在线视频 | 中文字幕色在线视频 | 国产午夜精品久久 | 黄色三级在线观看 | 免费av成人在线 | 国产精品乱码久久久久久1区2区 | 狠狠色伊人亚洲综合网站色 | 国产在线成人 | 国产一区二区观看 | 日本 在线 视频 中文 有码 | 免费观看www小视频的软件 | 高清不卡一区二区在线 | 中文av在线免费观看 | 五月婷在线| 97视频在线播放 | 欧美性久久久久久 | 久久久这里有精品 | 97免费 | 国产二区电影 | 99视频+国产日韩欧美 | 日韩色一区二区三区 | 日韩系列在线 | 麻豆国产精品va在线观看不卡 | 最近更新好看的中文字幕 | 99精品偷拍视频一区二区三区 | 国产免费黄视频在线观看 | 在线亚洲小视频 | 日韩在线观看中文 | 久久精品第一页 | 国产免费亚洲高清 | 日韩在线观看你懂得 | 免费黄色一区 | 国内99视频 | 国产精品免费一区二区 | 成人午夜在线电影 | 成 人 黄 色 视频 免费观看 | 日韩视频中文字幕在线观看 | 在线观看av国产 | 91av视频在线观看免费 | 黄色小网站在线观看 | 欧美一级黄大片 | 国产精品久久久久久久av大片 | 69精品视频 | 久久99精品国产99久久 | 精品一区二区久久久久久久网站 | 免费a网 | 亚洲一级理论片 | 在线观看国产一区 | 波多野结衣在线视频免费观看 | 亚洲精品va| 中文字幕精品在线 | 中文字幕人成乱码在线观看 | 久久久久亚洲国产精品 | 色多视频在线观看 | 久久久久久久久久久久99 | 中文字幕亚洲精品在线观看 | 99精品久久久久 | 日日干天天操 | 在线色网站 | 天天干夜夜爽 | 中文字幕精品久久 | 国产精品久久久久久久久蜜臀 | 亚洲国产精品成人精品 | 日日爱av| 91成人在线观看喷潮 | 国产视频二区三区 | 久久国产电影 | 91精品日韩 | 久操97 | 国产福利一区二区三区在线观看 | 网站免费黄色 | 久久草在线视频国产 | 久久久久久久久艹 | 久久久久成人精品 | 片黄色毛片黄色毛片 | 日韩免费一区二区三区 | 精品96久久久久久中文字幕无 | 手机在线看永久av片免费 | 99久久精品国产一区二区三区 | 欧美日韩视频在线 | 97超碰在线久草超碰在线观看 | 国语精品免费视频 | 国产精品99久久久久久小说 | 色综合激情网 | 午夜影院一级 | 日韩一区二区三免费高清在线观看 | 人人插人人费 | 亚洲精品日韩一区二区电影 | 国语久久 | 国产精品久久嫩一区二区免费 | 日p在线观看 | 99久久精品国产欧美主题曲 | 国产成年免费视频 | 少妇资源站 | 亚洲欧美成人综合 | 国产精品18久久久久久久久 | av资源免费观看 | 成人免费视频视频在线观看 免费 | 国内视频1区 | 中文字幕黄网 | 免费的国产精品 | 在线观看国产福利片 | 天堂av影院 | 午夜99| 91亚洲精品国偷拍自产在线观看 | 国内免费的中文字幕 | 国产精品综合久久 | 日本h在线播放 | 精品久久国产精品 | 一区二区三区免费在线观看视频 | 少妇搡bbb| 国产精品中文久久久久久久 | 日韩视频一区二区三区 | 欧美综合色在线图区 | 国产高清免费观看 | 在线视频黄 | 91免费黄视频 | 亚洲视频免费在线看 | 日韩电影中文字幕 | 欧洲一区二区三区精品 | 九九九热精品免费视频观看网站 | 九九九在线 | 天天爽夜夜爽人人爽一区二区 | 欧美成人精品三级在线观看播放 | 黄色三级久久 | 婷婷色网站| 亚洲日日日 | 中文字幕乱码电影 | 国产精品久久久久久吹潮天美传媒 | 日韩精品视频免费在线观看 | 一本一本久久a久久 | 天天射天天搞 | 三上悠亚一区二区在线观看 | 国产69熟| 国产小视频在线观看免费 | 国产一级性生活视频 | 日本中文在线 | 美女av免费 | 最近中文字幕在线播放 | 欧洲激情综合 | 欧美动漫一区二区三区 | 中文字幕你懂的 | 欧美黑人猛交 | 国产视频精选 | 午夜av激情 | 亚洲免费av观看 | 亚洲做受高潮欧美裸体 | 国产免费美女 | 激情综合五月 | 五月天丁香亚洲 | 日韩国产欧美视频 | 亚洲三级黄色 | 国产日韩精品一区二区三区 | 久久综合之合合综合久久 | 黄色www| 国产一区二区成人 | 久草视频2 | 色狠狠久久av五月综合 | 又色又爽又黄高潮的免费视频 | 欧美日韩免费看 | 黄色成年| 免费看三级网站 | 天天色欧美 | 国产在线色 | 蜜桃av观看| 免费欧美 | 成人国产网站 | 国产精品免费视频网站 | 精品视频一区在线观看 | 999在线观看视频 | 国产一级在线看 | 亚洲精品理论片 | 久久成人福利 | 中文字幕高清在线 | 色多多污污在线观看 | 久久国产精品视频免费看 | 久久久精品 | 91精品一区国产高清在线gif | 在线看国产 | 黄色成人免费电影 | 综合av在线 | 久久久久久久久久久久亚洲 | 精品国产不卡 | 欧美最新大片在线看 | 久久久久久久久久久久av | 日本久久精品视频 | 波多野结依在线观看 | 久久视频在线看 | 亚洲精品99久久久久中文字幕 | 免费看一级特黄a大片 | 国产日韩一区在线 | 日韩欧美v | 最近免费中文视频 | 九九热精品视频在线观看 | 国产精品午夜免费福利视频 | 久久久久久不卡 | 久久 精品一区 | 成人三级视频 | 国产精品岛国久久久久久久久红粉 | 精品久久久久久一区二区里番 | 成人免费观看av | 特级黄色电影 | 欧美综合国产 | 日韩欧美在线国产 | 亚洲高清在线观看视频 | 欧美黄色特级片 | 麻豆传媒视频观看 | 亚洲免费在线看 | 欧美另类人妖 | 久草在线视频看看 | 日韩美女黄色片 | 色视频网站免费观看 | 久久国色夜色精品国产 | 伊人五月| 日韩在线视频国产 | 国产91影院| 久久久久免费精品国产小说色大师 | 狠狠躁日日躁狂躁夜夜躁 | 欧美久久久久久久久久久久 | 午夜精品久久久久久久久久久 | 91av原创 | 日韩精品视频在线观看网址 | 亚洲精品456在线播放第一页 | 久久精品小视频 | 久久久综合九色合综国产精品 | 九九在线高清精品视频 | 在线综合 亚洲 欧美在线视频 | 久久久综合九色合综国产精品 | 国产成人精品免费在线观看 | 亚洲精品久久激情国产片 | 在线观看中文字幕 | 狠狠色丁香婷婷综合基地 | 精品久久久久久久久亚洲 | 91视频xxxx| 亚洲精品玖玖玖av在线看 | 视频成人 | 国产又粗又猛又爽又黄的视频先 | 欧美日韩二区在线 | 精品在线观看视频 | 天堂网一区 | 久久精品网站免费观看 | 国语精品久久 | 99精品视频免费观看视频 | 黄色的片子 | 久久免费视频在线观看 | 中文字幕日韩国产 | 亚洲精品国精品久久99热 | av888av.com| 成人sm另类专区 | 亚洲欧美精品一区 | 超碰在线公开 | 国产黄色精品在线 | 久久免费国产电影 | 欧美性生活免费看 | 国产日韩欧美视频在线观看 | 欧美日韩有码 | 免费在线观看黄网站 | 99亚洲国产 | 最近最新最好看中文视频 | 在线性视频日韩欧美 | 亚洲精品乱码久久久久久 | 久久精品79国产精品 | 精品国产一区二区三区在线观看 | 日韩久久视频 | 99热在线精品观看 | 天天干天天干天天 | 日日爱视频 | 国产成人99av超碰超爽 | 最近最新中文字幕视频 | 久久人人爽爽人人爽人人片av | 亚洲另类xxxx | 欧美日韩国产综合一区二区 | 视频一区二区在线 | 一级a毛片高清视频 | 97成人在线视频 | 日本h视频在线观看 | 亚洲精品网页 | 91最新在线观看 | 中文字幕在线观看91 | 欧美日韩亚洲在线 | 视频一区二区在线观看 | 久久久久网址 | 最新影院 | 草樱av | 在线免费av网 | 婷色在线 | 在线免费国产 | 操老逼免费视频 | 国产日韩在线播放 | 免费观看www小视频的软件 | 国产麻豆精品免费视频 | 成人欧美在线 | 国产黄色电影 | 国产超碰在线观看 | 四虎影视精品永久在线观看 | 中国一级片在线观看 | 成人欧美一区二区三区在线观看 | 黄色免费在线视频 | av大全在线播放 | 欧美巨乳网 | 久久国产欧美日韩精品 | 亚洲手机天堂 | 天天骚夜夜操 | 日本99热 | 夜夜夜夜夜夜操 | 91亚洲在线观看 | 午夜精品久久久久久久99 | 精品国产伦一区二区三区免费 | 成人网页在线免费观看 | 国产黄色成人av | 色婷婷狠狠五月综合天色拍 | 亚洲国产av精品毛片鲁大师 | 久久亚洲专区 | 97人人模人人爽人人喊网 | 亚洲黄色在线播放 | 日本久久中文 | 久久理论电影 | 在线欧美中文字幕 | 在线免费试看 | 免费污片| 亚洲精品动漫在线 | av一级片网站 | 91久久影院 | 国产精品一区二区精品视频免费看 | 成人中心免费视频 | 婷婷视频在线观看 | av中文天堂 | 99热999 | 久久av伊人 | 国产韩国日本高清视频 | 伊人久久精品久久亚洲一区 | 2020天天干夜夜爽 | 亚洲国产精品99久久久久久久久 | 免费高清在线视频一区· | 久久艹免费 | 一区二区三区精品在线视频 | 日韩精品久久久久久中文字幕8 | 精品一区二区三区电影 | 国产在线观看你懂的 | 亚洲国产视频a | 香蕉视频日本 | 国产免费大片 | www.eeuss影院av撸 | 国产99在线播放 | 99这里只有久久精品视频 | 色先锋av资源中文字幕 | 五月天婷亚洲天综合网鲁鲁鲁 | 精品国产免费人成在线观看 | 黄色一集片 | 欧美 日韩精品 | 九九欧美视频 | 免费在线观看av网址 | 高清视频一区二区三区 | 国产成年人av| 久草网视频在线观看 | 91最新国产 | 91精品国产九九九久久久亚洲 | 欧美日韩视频在线 | 国产精品激情偷乱一区二区∴ | 日本xxxx裸体xxxx17 | 美女黄网久久 | 一本一本久久aa综合精品 | www视频免费在线观看 | 久久国产精品一二三区 | www99精品| 中文字幕婷婷 | 免费视频99 | 在线观看国产亚洲 | 久久久久久久久免费视频 | 精品国模一区二区三区 | 久久亚洲国产精品 | 国产精品成人国产乱一区 | 精品国偷自产国产一区 | 色福利网站 | 国产成人av片 | 成人一级电影在线观看 | 婷婷视频导航 | 色天天中文 | 久久午夜国产 | 久久久久久久免费观看 | 激情喷水| 国产精品欧美精品 | 久久99热久久99精品 | 婷婷国产v亚洲v欧美久久 | 久久伊人精品天天 | 一区中文字幕在线观看 | 亚洲天天在线日亚洲洲精 | 欧美一二三视频 | 韩日在线一区 | 国产精品 视频 | 色姑娘综合| 天天射网站 | 亚洲v欧美v国产v在线观看 | 欧美成人区 | 五月天中文字幕mv在线 |