精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

Linux 進(jìn)程管理之進(jìn)程的終結(jié)

系統(tǒng) Linux
當(dāng)一個(gè)進(jìn)程終結(jié)時(shí),內(nèi)核必須釋放掉它所占有的資源并把這一終結(jié)事件告知父進(jìn)程。進(jìn)程的終結(jié)大部分都要靠 exit() 來完成的,最終的系統(tǒng)調(diào)用為 do_exit()。

當(dāng)一個(gè)進(jìn)程終結(jié)時(shí),內(nèi)核必須釋放掉它所占有的資源并把這一終結(jié)事件告知父進(jìn)程。

進(jìn)程的終結(jié)大部分都要靠 exit() 來完成的,最終的系統(tǒng)調(diào)用為 do_exit()。

asmlinkage long sys_exit(int error_code)
{
do_exit((error_code&0xff)<<8);
}


/*當(dāng)cpu進(jìn)入到do_exit后,當(dāng)前進(jìn)程就會(huì)在中途壽終正寢,不會(huì)從這個(gè)函數(shù)中返回,當(dāng)然也就不會(huì)從sys_exit
中返回,從而也就不會(huì)從系統(tǒng)調(diào)用exit()中返回*/
fastcall NORET_TYPE void do_exit(long code)
{
...

WARN_ON(atomic_read(&tsk->fs_excl));
/*由于中斷服務(wù)程序根本不應(yīng)該調(diào)用do_exit,不管是直接還是間接,所以首先通過in_interrupt進(jìn)行加以檢查
若發(fā)現(xiàn)是在某個(gè)中斷服務(wù)程序中調(diào)用的,那就一定是出了問題*/
if (unlikely(in_interrupt()))
panic("Aiee, killing interrupt handler!");
...

/*current->flags的PF_EXITING標(biāo)志表示進(jìn)程正在被刪除 */
if (unlikely(tsk->flags & PF_EXITING)) {
printk(KERN_ALERT
"Fixing recursive fault but reboot is needed!\n");
...

tsk->flags |= PF_EXITPIDONE; /* 設(shè)置進(jìn)程標(biāo)識(shí)為PF_EXITPIDONE*/
if (tsk->io_context)
exit_io_context();
/* 設(shè)置進(jìn)程狀態(tài)為不可中斷的等待狀態(tài) */
set_current_state(TASK_UNINTERRUPTIBLE);
/* 調(diào)度其它進(jìn)程 */
schedule();
}

tsk->flags |= PF_EXITING;

/* 內(nèi)存屏障,用于確保在它以后的操做開始執(zhí)行以前,它以前的操做已經(jīng)完成 */
smp_mb();
spin_unlock_wait(&tsk->pi_lock);

...

//清除定時(shí)器
group_dead = atomic_dec_and_test(&tsk->signal->live);//live用來表示線程組中活動(dòng)進(jìn)程的數(shù)量
if (group_dead) { //當(dāng)沒有活動(dòng)的進(jìn)程時(shí)
exit_child_reaper(tsk);
//取消高精度定時(shí)器
hrtimer_cancel(&tsk->signal->real_timer);
//刪除POSIX.1b類型的定時(shí)器
exit_itimers(tsk->signal);
}
//收集進(jìn)程會(huì)計(jì)信息
acct_collect(code, group_dead);

...

//設(shè)置終止代碼
tsk->exit_code = code;
taskstats_exit(tsk, group_dead);
//釋放線性區(qū)描述符和頁表
exit_mm(tsk);

if (group_dead)
acct_process();
//遍歷current->sysvsem.undo_list鏈表,并清除進(jìn)程所涉及的每個(gè)IPC信號(hào)量的操作痕跡
exit_sem(tsk);
//釋放文件對(duì)象相關(guān)資源
__exit_files(tsk);
//釋放struct fs_struct結(jié)構(gòu)體
__exit_fs(tsk);
//檢查有多少未使用的進(jìn)程內(nèi)核棧
check_stack_usage();

exit_thread();
cgroup_exit(tsk, 1);
exit_keys(tsk);

if (group_dead && tsk->signal->leader)
disassociate_ctty(1);

module_put(task_thread_info(tsk)->exec_domain->module);
if (tsk->binfmt)
module_put(tsk->binfmt->module);

proc_exit_connector(tsk);
//給父進(jìn)程發(fā)送信號(hào),讓其知道子進(jìn)程生命已經(jīng)結(jié)束,來料理子進(jìn)程的后事. 同時(shí)把進(jìn)程狀態(tài)exit_state 設(shè)置成 EXIT_ZOMBIE
exit_notify(tsk);

...

tsk->flags |= PF_EXITPIDONE;

...

preempt_disable();
/* causes final put_task_struct in finish_task_switch(). */
tsk->state = TASK_DEAD;


/*do_exit 不返回的真正原因在這里,由于進(jìn)程狀態(tài)設(shè)置成了EXIT_ZOMBIE,使得該進(jìn)程永遠(yuǎn)不會(huì)再被選中進(jìn)行調(diào)度,所以
也就不會(huì)使用schedule()調(diào)度別的進(jìn)程后從schedule中返回。因此只能等父進(jìn)程收到子進(jìn)程發(fā)送的信號(hào)來處理子進(jìn)程,并將
子進(jìn)程的task_struct結(jié)構(gòu)釋放掉,子進(jìn)程最終從系統(tǒng)中消失。而父進(jìn)程在wait4(對(duì)應(yīng)系統(tǒng)函數(shù)sys_wait4)中等待著。
*/
schedule();
BUG();
/* Avoid "noreturn function does return". */
for (;;)
cpu_relax(); /* For when BUG is null */
}

do_exit() 完成工作如下:

  • 對(duì)該調(diào)用進(jìn)行檢查,比如該方法是不能在中斷服務(wù)程序中調(diào)用的。
  • 將 task_struct 中的標(biāo)志成員設(shè)置為 PF_EXITING。
  • 刪除內(nèi)核定時(shí)器,根據(jù)返回的結(jié)果,它確保沒有定時(shí)器在排隊(duì),也沒有定時(shí)器處理程序在運(yùn)行。
  • 把進(jìn)程的退出代碼 exit_code 設(shè)置為由 exit() 提供的退出代碼,或者去完成任何其他由內(nèi)核機(jī)制規(guī)定的退出動(dòng)作。退出代碼存放在這里供父進(jìn)程隨時(shí)檢索。
  • 調(diào)用 exit_mm( )釋放進(jìn)程占用的 mm_struct,若沒有別的進(jìn)程使用它們(也即是這個(gè)地址空間沒有被共享),就徹底釋放它們。
  • 調(diào)用 exit_sem(),清除進(jìn)程所涉及的每個(gè)IPC信號(hào)量的操作痕跡,使得若進(jìn)程排隊(duì)等候IPC信號(hào),則離開隊(duì)列。
  • 調(diào)用 __exit_files、__exit_fs,分別遞減文件描述符、文件系統(tǒng)數(shù)據(jù)的引用計(jì)數(shù)。若其中某個(gè)引用計(jì)數(shù)的數(shù)值降為零,那么就代表沒有進(jìn)程在使用相應(yīng)的資源,此時(shí)就可以釋放。
  • 調(diào)用 exit_notify() 向父進(jìn)程發(fā)送信號(hào),給子進(jìn)程重新找養(yǎng)父,養(yǎng)父為線程組中的其他線程或者init進(jìn)程,并把進(jìn)程狀態(tài)(task_strcut 結(jié)構(gòu)中的exit_state)設(shè)置成 EXIT_ZOMBIE。
  • 調(diào)用 schedule() 切換到新的進(jìn)程。由于處于 EXIT_ZOMBIE 狀態(tài)的進(jìn)程不會(huì)再會(huì)被調(diào)度,所以這是進(jìn)程所執(zhí)行的最后一段代碼。do_exit 永不返回。

到此,與進(jìn)程相關(guān)的所有資源該釋放的都釋放掉了(假設(shè)該進(jìn)程是這些資源的唯一使用者)。進(jìn)程不可運(yùn)行(實(shí)際上它也沒有地址空間可供它運(yùn)行)并處于EXIT_ZOMBIE 退出狀態(tài)。

該進(jìn)程目前所占用的內(nèi)存資源就是內(nèi)核棧、thread_info 結(jié)構(gòu)和 task_struct 結(jié)構(gòu)。此時(shí)進(jìn)程存在的唯一目的就是向它的父進(jìn)程提供信息。父進(jìn)程檢索到信息后,或者通知內(nèi)核它不關(guān)心那些無關(guān)的信息后,子進(jìn)程的這些剩余資源才被釋放歸還給系統(tǒng)。

進(jìn)程描述符的刪除

從上面可以知道,進(jìn)程在調(diào)用 do_exit() 后,進(jìn)程處于僵死狀態(tài)且不能運(yùn)行。但是系統(tǒng)還保留它的進(jìn)程描述符相關(guān)信息。之所以保留這些信息是為了讓系統(tǒng)有辦法在子進(jìn)程終結(jié)后仍能獲得它的信息。

當(dāng)父進(jìn)程獲取已終結(jié)的子進(jìn)程的信息后,或者通知內(nèi)核它不關(guān)心那些無關(guān)的信息后,子進(jìn)程的這些剩余資源才被釋放歸還給系統(tǒng)。

wait() 這一族函數(shù)都是通過唯一的一條系統(tǒng)調(diào)用 wait4() 來實(shí)現(xiàn)的。它的作用就是掛起調(diào)用它的進(jìn)程,直到其中的一個(gè)子進(jìn)程退出,此時(shí)函數(shù)會(huì)返回該子進(jìn)程的 PID。另外,調(diào)用該函數(shù)時(shí)提供的指針會(huì)包含子函數(shù)退出時(shí)的退出代碼。

wait4() 最終會(huì)調(diào)用 sys_wait4()。

asmlinkage long sys_wait4(pid_t pid, int __user *stat_addr,
int options, struct rusage __user *ru)
{
long ret;
if (options & ~(WNOHANG|WUNTRACED|WCONTINUED|
__WNOTHREAD|__WCLONE|__WALL))
return -EINVAL;
ret = do_wait(pid, options | WEXITED, NULL, stat_addr, ru);
/* avoid REGPARM breakage on x86: */
prevent_tail_call(ret);
return ret;
}

當(dāng)父進(jìn)程因子進(jìn)程在 exit() 中向其發(fā)送信號(hào)而被喚醒,父進(jìn)程在將子進(jìn)程在用戶空間運(yùn)行的時(shí)間和系統(tǒng)空間運(yùn)行的時(shí)間兩項(xiàng)統(tǒng)計(jì)數(shù)據(jù)合并入其自身的統(tǒng)計(jì)數(shù)據(jù)中,然后,在典型的條件下,就會(huì)調(diào)用 release_task() 將子進(jìn)程殘存的資源,就是其 task_struct 結(jié)構(gòu)和系統(tǒng)空間堆棧,全部釋放掉。

調(diào)用過程如下:

sys_wait4
--> do_wait
--> wait_task_zombie
--> release_task

release_task() 實(shí)現(xiàn)如下:

void release_task(struct task_struct * p)
{
struct task_struct *leader;
int zap_leader;
repeat:
...
/* 1)該函數(shù)調(diào)用_unhash_process(),后者調(diào)用detach_pid()從pidhash
? 上刪除該進(jìn)程,同時(shí)也要從任務(wù)列表中刪除該進(jìn)程
? 2)釋放目前僵死進(jìn)程所使用的所有剩余資源,并進(jìn)行最終統(tǒng)計(jì)和記錄
*/
__exit_signal(p);
/*
? If we are the last non-leader member of the thread
? group, and the leader is zombie, then notify the
? group leader's parent process. (if it wants notification.)
*/
zap_leader = 0;
leader = p->group_leader;
/*若該進(jìn)程是線程組最后一個(gè)進(jìn)程,并且領(lǐng)頭進(jìn)程已經(jīng)死掉,,則通知僵死的領(lǐng)頭進(jìn)程的父進(jìn)程 /
if (leader != p && thread_group_empty(leader) && leader->exit_state == EXIT_ZOMBIE) {
BUG_ON(leader->exit_signal == -1);
do_notify_parent(leader, leader->exit_signal);
/
? If we were the last child thread and the leader has
? exited already, and the leader's parent ignores SIGCHLD,
? then we are the one who should release the leader.
?
? do_notify_parent() will have marked it self-reaping in
? that case.
*/
zap_leader = (leader->exit_signal == -1);
}
write_unlock_irq(&tasklist_lock);
release_thread(p);
//調(diào)用 put_task_struct 釋放進(jìn)程內(nèi)核棧和thread_info結(jié)構(gòu)所占的頁,并釋放task_struct 所占的slab告訴緩存。
call_rcu(&p->rcu, delayed_put_task_struct);
p = leader;
if (unlikely(zap_leader))
goto repeat;
}

release_task 完成的工作如下:

  • 調(diào)用__exit_signal(),該函數(shù)調(diào)用_unhash_process(),后者調(diào)用detach_pid() 從 pidhash 上刪除該進(jìn)程,同時(shí)也要從任務(wù)列表中刪除該進(jìn)程。
  • __exit_signal() 釋放目前僵死進(jìn)程所使用的所有剩余資源,并進(jìn)行最終統(tǒng)計(jì)和記錄。
  • 若該進(jìn)程是線程組最后一個(gè)進(jìn)程,并且領(lǐng)頭進(jìn)程已經(jīng)死掉,則通知僵死的領(lǐng)頭進(jìn)程的父進(jìn)程 。
  • 調(diào)用 put_task_struct() 釋放進(jìn)程內(nèi)核棧和 thread_info 結(jié)構(gòu)所占的頁,并釋放 task_struct 所占的 slab 告訴緩存。

到此,進(jìn)程描述符和進(jìn)程所有獨(dú)享的資源全部就釋放掉了。

責(zé)任編輯:華軒 來源: 今日頭條
相關(guān)推薦

2023-03-05 16:12:41

Linux進(jìn)程線程

2011-01-11 13:47:27

Linux管理進(jìn)程

2023-03-03 00:03:07

Linux進(jìn)程管理

2021-04-22 07:47:46

Linux進(jìn)程管理

2021-04-15 05:51:25

Linux

2021-06-15 08:02:55

Linux 進(jìn)程管理

2010-02-25 10:28:43

Linux進(jìn)程管理

2023-03-05 15:28:39

CFSLinux進(jìn)程

2021-05-12 07:50:02

CFS調(diào)度器Linux

2021-05-17 18:28:36

Linux CFS負(fù)載均衡

2014-08-01 15:38:37

Linux進(jìn)程管理

2015-08-20 09:03:19

xkillLinux桌面進(jìn)程

2021-03-17 21:34:44

Linux內(nèi)存管理

2009-10-23 17:35:16

linux進(jìn)程管理

2010-06-28 14:52:30

cron進(jìn)程

2021-07-06 21:30:06

Linux進(jìn)程通信

2009-03-05 09:43:32

Linux系統(tǒng)進(jìn)程管理命令

2017-01-15 20:58:04

Linux進(jìn)程作業(yè)管理

2013-10-11 14:51:16

Linux進(jìn)程管理

2022-11-09 08:12:07

點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

网友自拍一区| 性欧美videos高清hd4k| 久久欧美肥婆一二区| 一区二区亚洲精品国产| 亚洲制服中文字幕| 国产白浆在线免费观看| 中文字幕精品三区| 99在线观看| 五月激情丁香网| 欧美精品一卡| 亚洲一品av免费观看| 日日夜夜精品视频免费观看 | 国产精品第13页| 不卡日韩av| 欧美一级黄视频| 韩日在线一区| www.午夜精品| 97人妻精品一区二区免费| 国产va免费精品观看精品| 大桥未久av一区二区三区| 亚洲一区3d动漫同人无遮挡| 手机av免费在线观看| 精品亚洲porn| 国产精品91视频| 日操夜操天天操| 1024精品久久久久久久久| 亚洲美女久久久| 韩国三级在线看| 狂野欧美性猛交xxxx| 大荫蒂欧美视频另类xxxx| 佐佐木明希av| jizz在线观看中文| 久久免费的精品国产v∧| 高清视频一区二区三区| 99精品人妻无码专区在线视频区| 久久激情视频| 欧美性在线观看| 国产精品99精品无码视| 欧美国产另类| 另类专区欧美制服同性| 国产极品视频在线观看| 国产一区不卡| 亚洲香蕉成人av网站在线观看| 影音先锋黄色资源| 在线综合色站| 欧美成人video| 在线成人免费av| 国产情侣一区在线| 88在线观看91蜜桃国自产| www欧美激情| 香蕉视频亚洲一级| 91精品1区2区| 五月婷婷狠狠操| 婷婷午夜社区一区| 欧美午夜精品一区二区三区| 能看的毛片网站| 天堂久久午夜av| 欧美在线你懂得| 人人爽人人av| 久久亚洲人体| 日韩一级黄色片| 91成人在线观看喷潮蘑菇| 99久久香蕉| 亚洲国产精品一区二区久| 中文字幕在线播放一区| 欧美理论电影在线精品| 国产香蕉97碰碰久久人人| 超碰人人人人人人人| 欧美韩国日本在线观看| 久久五月天综合| 欧美黑人一级片| 黄色精品一区| 欧美专区在线视频| 午夜视频网站在线观看| 看片的网站亚洲| 91超碰rencao97精品| 亚洲成a人片77777精品| 99精品视频在线播放观看| 明星裸体视频一区二区| 成年人在线视频免费观看| 国产精品毛片久久久久久久| 欧美日韩一区二区三区电影| 国产乱码在线| 在线日韩av片| 无码人妻丰满熟妇区毛片蜜桃精品| 一区二区三区亚洲变态调教大结局 | 国产精品成人免费在线| 国产成人精品免费看在线播放| 日韩激情av| 色婷婷狠狠综合| 色91精品久久久久久久久| 亚洲综合影院| 国产午夜精品全部视频在线播放| 99成人在线观看| 夜夜嗨av一区二区三区网站四季av| 国产91在线高潮白浆在线观看| 国产精品伊人久久| 91丨九色丨国产丨porny| 午夜精品一区二区在线观看| 成全电影大全在线观看| 欧洲精品在线观看| 国产伦精品一区二区三区88av| 免费久久精品| 欧美高清视频免费观看| 中文字幕第三页| 99久久久久免费精品国产 | 亚洲国产日韩在线| 国产精品美乳在线观看| 亚洲男人天堂久久| 久久久久久久综合| 日韩伦理在线免费观看| 少妇高潮一区二区三区99| 亚洲成av人乱码色午夜| 任你操精品视频| 久久国产精品久久w女人spa| 成人午夜影院在线观看| 免费网站成人| 色天天综合久久久久综合片| 中文字幕人妻一区| 国产精品福利在线观看播放| 日韩免费观看网站| 天天操天天干天天插| 亚洲天堂精品视频| 浓精h攵女乱爱av| 久久99视频| 久久琪琪电影院| 亚洲精品一区二区三区区别 | 日韩黄色在线免费观看| 蜜臀久久精品久久久用户群体| 视频一区免费在线观看| 精品蜜桃一区二区三区| 亚洲卡一卡二| 91精品婷婷国产综合久久竹菊| 一区二区伦理片| 中文精品视频| 国产日韩一区二区三区| 性欧美ⅴideo另类hd| 在线不卡的av| 中文字幕第69页| 免费视频最近日韩| 亚州欧美一区三区三区在线| 亚洲一区资源| 亚洲欧美综合v| 四虎成人在线观看| 91麻豆.com| 青青青免费在线| 另类ts人妖一区二区三区| 久久久久久久久亚洲| 色噜噜在线播放| 午夜视频久久久久久| 日韩综合第一页| av成人毛片| 久久久久资源| 日韩成人动漫| 中文字幕亚洲综合久久筱田步美| 中文字幕精品一区二| 国产精品久线在线观看| 午夜xxxxx| 欧美日韩ab| 国产视色精品亚洲一区二区| 色多多在线观看| 亚洲天堂色网站| 亚洲性生活大片| 亚洲欧美一区二区视频| 日本黄色www| 亚洲国产一区二区三区高清| 精品在线不卡| 99re久久| 欧美乱妇40p| 欧美一区二区三区成人片在线| 欧美日韩色婷婷| 国产精品视频在| 国产在线视频一区二区三区| 精品成在人线av无码免费看| 免费看久久久| 国产成人精彩在线视频九色| 在线看的av网站| 日韩一区二区电影在线| 日韩欧美不卡视频| 国产农村妇女毛片精品久久麻豆| 亚洲欧美偷拍另类| 亚洲国产黄色| 亚洲免费视频一区| 午夜精品在线| 国产精品成人国产乱一区| 毛片在线播放a| 亚洲精品wwwww| 中文字幕一级片| 亚洲精品日产精品乱码不卡| 国产不卡一二三| 蜜臀久久99精品久久久久宅男| 日本丰满大乳奶| 免费一区二区三区视频导航| 91免费国产网站| 亚洲妇女成熟| 免费成人高清视频| 亚洲av成人无码久久精品老人| 欧美日韩在线播| 日产精品久久久久久久| 国产精品久线观看视频| 国产精品无码永久免费不卡| 免费成人美女在线观看| 超碰成人免费在线| 欧美电影免费播放| 欧美日韩免费高清| 永久免费精品视频| 成人美女免费网站视频| 偷拍精品精品一区二区三区| 欧美丰满少妇xxxxx做受| 婷婷在线视频观看| 亚洲跨种族黑人xxx| www.激情五月.com| 欧美另类久久久品| 国产黄色免费视频| 黄色91在线观看| 久久久久久久久久91| 国产精品乱码妇女bbbb| 实拍女处破www免费看| 成人在线视频一区二区| 五月天国产视频| 麻豆精品在线观看| 四虎永久在线精品无码视频| 日韩视频在线一区二区三区 | 国产一区二区三区av在线| 亚洲日韩中文字幕一区| 国产精品成人va在线观看| 中文在线а√在线8| 欧美精品久久久久| 日韩激情美女| 欧美日韩国产91| 成年人网站在线| www.欧美精品一二三区| 国产在线视频资源| 亚洲精品一区av在线播放| 免费观看国产视频| 亚洲成人黄色在线| 高清乱码毛片入口| 精品久久久久99| 黄色美女一级片| 欧美成人三级在线| 精品国产亚洲av麻豆| 91麻豆精品国产91久久久| 亚洲一级特黄毛片| 911国产精品| 999精品国产| 日韩午夜av电影| 国产成人三级在线播放| 日韩欧美在线1卡| 国产av无码专区亚洲av| 日韩一级免费观看| 亚洲精品一区二区三区四区| 亚洲福利在线看| 亚洲 欧美 激情 小说 另类| 亚洲欧洲xxxx| av网站在线免费播放| 主播福利视频一区| sm国产在线调教视频| 色综合久久悠悠| 欧美hdxxxx| 97精品视频在线观看| 色一区二区三区| 国产精品国产三级国产专播精品人| 韩国成人在线| 成人在线播放av| 91精品导航| 欧美国产视频在线观看| 欧州一区二区| 伊人婷婷久久| 精品福利电影| 男人揉女人奶房视频60分| 日本视频一区二区三区| 不卡中文字幕在线观看| 国产精品系列在线播放| 特级西西人体4444xxxx| 国产欧美精品一区aⅴ影院 | 国产欧洲精品视频| 久久9999免费视频| 久久精品国产美女| 日韩精品免费一区二区三区| 8x8x华人在线| 久久高清国产| 亚洲第一区第二区第三区| 成人黄色av电影| 国精产品一区二区三区| 亚洲视频1区2区| av中文在线播放| 欧美日韩免费视频| 高h调教冰块play男男双性文| 亚洲欧美中文字幕在线一区| 国产成人在线视频免费观看| 91国内产香蕉| 3d动漫一区二区三区在线观看| 国产91精品一区二区绿帽| 精品久久成人| 男女啪啪免费观看| 日韩精品乱码av一区二区| 99国产精品免费视频| 国产三级精品三级| 欧美人妻精品一区二区三区| 欧美在线一二三四区| 蜜臀av免费在线观看| 色偷偷噜噜噜亚洲男人的天堂| free性护士videos欧美| 国产视频观看一区| 日韩高清一级| 热久久最新地址| 日本va欧美va精品| 国产精品无码在线| 亚洲乱码国产乱码精品精98午夜| 日韩黄色片网站| 精品国产精品网麻豆系列| 男人天堂久久久| 日韩女在线观看| 天堂av一区二区三区在线播放 | 国产亚洲欧美一区二区| 欧美成人milf| 日韩av片网站| 久久精品水蜜桃av综合天堂| 日韩高清精品免费观看| 欧美一二三区精品| 天天影视久久综合| 国产精品99蜜臀久久不卡二区| caoporn成人免费视频在线| 日韩视频在线免费播放| 蜜臀久久99精品久久久久宅男| 在线观看日韩精品视频| 亚洲成人自拍一区| 黄色一级a毛片| 欧美另类极品videosbest最新版本| 祥仔av免费一区二区三区四区| 日韩一区国产在线观看| 亚洲一区国产| 久久久久麻豆v国产精华液好用吗| 亚洲黄色av一区| 99久久免费国产精精品| 日韩在线视频线视频免费网站| 香蕉成人av| 日韩免费三级| 日韩精品一区第一页| 男女做爰猛烈刺激| 91久久香蕉国产日韩欧美9色| 三级国产在线观看| 青青久久av北条麻妃海外网| 午夜精品福利影院| 久久精品视频91| 久久久久久久久99精品| 99久久久无码国产精品免费蜜柚| 亚洲女成人图区| 欧美成人a交片免费看| 日本一区二区三区视频在线播放| 老鸭窝毛片一区二区三区 | 日韩理论电影院| 最新天堂在线视频| 亚洲欧美另类小说| 99视频免费看| 欧美精品久久一区二区| 日韩精品免费一区二区三区竹菊 | 久久国产精品72免费观看| 永久免费看片视频教学| 日韩一区二区三区av| 2020国产在线| 欧美在线视频一区二区三区| 免费的国产精品| 希岛爱理中文字幕| 精品第一国产综合精品aⅴ| 在线黄色的网站 | 欧美破处大片在线视频| 精品人妻在线视频| 色综合久久精品| 午夜视频成人| 成人做爰66片免费看网站| 99精品免费网| 亚洲а∨天堂久久精品2021| 欧美日韩高清不卡| 不卡一本毛片| 色综合666| 国产v日产∨综合v精品视频| 日本一区二区不卡在线| 一区二区av在线| 亚洲精品观看| 欧美日韩在线免费播放| 亚洲色图第一区| 日韩资源在线| 成人性生交大片免费看小说 | 亚洲精品大片www| 亚州av在线播放| 国产欧美一区二区三区四区| 亚洲久久成人| 狂野欧美性猛交| 精品成人在线观看| 日日夜夜一区| 青青草视频在线免费播放| 中文字幕第一区综合| 黄色av网址在线| 国产欧美日韩丝袜精品一区| 91久久夜色精品国产九色| 人人妻人人澡人人爽| 亚洲福利精品在线| 日韩有码欧美| 国模杨依粉嫩蝴蝶150p|