婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > 淺談Linux信號機制

淺談Linux信號機制

熱門標簽:麗江真人語音電話外呼系統 400電話辦理介紹信 10086外包用的什么外呼系統 福州企業電銷機器人排名 河南防封號電銷機器人是什么 打400電話怎么辦理收費 怎么找到沒有地圖標注的店 上海申請高400開頭的電話 宿城區電話機器人找哪家

一、信號列表

root@ubuntu:# kill -l

 1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP

 6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1

11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM

16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP

21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ

26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR

31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3

38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8

43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13

48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12

53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7

58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2

63) SIGRTMAX-1 64) SIGRTMAX

其中最常見的:

  • Ctrl + C 觸發的是 SIGINT;
  • Ctrl + \ 觸發的是SIGQUIT;
  • 但是特別說明下 Ctrl + D 并不是觸發信號,而是產生一個 EOF,這也是為什么在 Python 交互模式按下這個組合會退出 Python 的原因。

1.1、實時信號非實時信號

如上,kill列舉出所有信號。實時信號與非實時信號又叫做可靠信號與不可靠信號。SIGRTMIN 及其以后的是實時信號,之前的是非實時信號。區別是實時信號支持重復排隊,但是非實時信號不支持。非實時信號在排隊時候會默認只出現一次,意思就是即使多次發送也終將只收到一個。在隊列的取出順序上也有區別,即最先取出的信號一定是實時信號。

PS:

  • kill、killall 默認發送SIGTERM 信號。
  • linux下 SIGKILL不能被阻塞、或忽略。
  • 默認情況下 SIGCHLD 不被忽略,編程時候需要注意這個(要么設置 SIG_IGN 或者主動 wait)。
  • 所有未定義處理函數的信號,默認退出進程。
  • 信號被設置block后仍存在于隊列中只是不被處理,如果放開屏蔽將會被處理。
  • 信號可以中斷sleep調用引起睡眠的進程。

1.2、信號狀態

信號的”未決“是一種狀態,指的是從信號的產生到信號被處理前的這一段時間;信號的”阻塞“是一個開關動作,指的是阻止信號被處理,但不是阻止信號產生。

例如在sleep前用 sigprocmask 阻塞了退出信號,然后sleep,然后在sleep的過程中產生一個退出信號,但是此時退出信號被阻塞過,(中文的”阻塞”在這里容易被誤解為一種狀態,實際上是一種類似于開關的動作,所以說“被阻塞過”,而不是“被阻塞”)所以處于“未決”狀態,在 sleep后又用sigprocmask關掉退出信號的阻塞開關,因為之前產生的退出信號一直處于未決狀態,當關上阻塞開關后,馬上退出“未決”狀態,得到處理,這一切發生在sigprocmask返回之前。

1.3、信號生命周期

對于一個完整的信號生命周期(從信號發送到相應的處理函數執行完畢)來說,可以分為三個重要的階段,這三個階段由四個重要事件來刻畫:

1.信號誕生;

2. 信號在進程中注冊完畢;

3.信號在進程中的注銷完畢;

4.信號處理函數執行完畢。相鄰兩個事件的時間間隔構成信號生命周期的一個階段。

下面闡述四個事件的實際意義:

  • 信號"誕生"。信號的誕生指的是觸發信號的事件發生(如檢測到硬件異常、定時器超時以及調用信號發送函數kill()或sigqueue()等)。
  • 信號在目標進程中"注冊";進程的task_struct結構中有關于本進程中未決信號的數據成員:
struct sigpending pending;
struct sigpending
{
    struct sigqueue *head, **tail;
    sigset_t signal;
};

信號在進程中注冊指的就是信號值加入到進程的未決信號集中(sigpending結構的第二個成員sigset_t signal),并且信號所攜帶的信息被保留到未決信號信息鏈的某個sigqueue結構中。只要信號在進程的未決信號集中,表明進程已經知道這些信號的存在,但還沒來得及處理,或者該信號被進程阻塞。

1.信號在進程中的注銷。在目標進程執行過程中,會檢測是否有信號等待處理(每次從系統空間返回到用戶空間時都做這樣的檢查)。如果存在未決信號等待處理且該信號沒有被進程阻塞,則在運行相應的信號處理函數前,進程會把信號在未決信號鏈中占有的結構卸掉。是否將信號從進程未決信號集中刪除對于實時與非實時信號是不同的。對于非實時信號來說,由于在未決信號信息鏈中最多只占用一個sigqueue結構,因此該結構被釋放后,應該把信號在進程未決信號集中刪除(信號注銷完畢);而對于實時信號來說,可能在未決信號信息鏈中占用多個sigqueue結構,因此應該針對占用gqueue結構的數目區別對待:如果只占用一個sigqueue結構(進程只收到該信號一次),則應該把信號在進程的未決信號集中刪除(信號注銷完畢)。否則,不在進程的未決信號集中刪除該信號(信號注銷完畢)。進程在執行信號相應處理函數之前,首先要把信號在進程中注銷。

2.信號生命終止。進程注銷信號后,立即執行相應的信號處理函數,執行完畢后,信號的本次發送對進程的影響徹底結束。

1.4、信號的執行和注銷

內核處理一個進程收到的軟中斷信號是在該進程的上下文中,因此,進程必須處于運行狀態。當其由于被信號喚醒或者正常調度重新獲得CPU時,在其從內核空間返回到用戶空間時會檢測是否有信號等待處理。如果存在未決信號等待處理且該信號沒有被進程阻塞,則在運行相應的信號處理函數前,進程會把信號在未決信號鏈中占有的結構卸掉。當所有未被屏蔽的信號都處理完畢后,即可返回用戶空間。對于被屏蔽的信號,當取消屏蔽后,在返回到用戶空間時會再次執行上述檢查處理的一套流程。

處理信號有三種類型:進程接收到信號后退出;進程忽略該信號;進程收到信號后執行用戶設定用系統調用signal的函數。當進程接收到一個它忽略的信號時,進程丟棄該信號,就象沒有收到該信號似的繼續運行。如果進程收到一個要捕捉的信號,那么進程從內核態返回用戶態時執行用戶定義的函數。而且執行用戶定義的函數的方法很巧妙,內核是在用戶棧上創建一個新的層,該層中將返回地址的值設置成用戶定義的處理函數的地址,這樣進程從內核返回彈出棧頂時就返回到用戶定義的函數處,從函數返回再彈出棧頂時,才返回原先進入內核的地方。這樣做的原因是用戶定義的處理函數不能且不允許在內核態下執行(如果用戶定義的函數在內核態下運行的話,用戶就可以獲得任何權限)。

eg:

#include <assert.h>
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#include <signal.h>
#include <unistd.h>

void myHandler(int num)
{
    int ret = 0;
    
    if (SIGUSR1 == num)
    {
        sigset_t set;
        ret = sigemptyset(&set);
        assert(!(-1 == ret));
        ret = sigaddset(&set, SIGINT);
        assert(!(-1 == ret));
        ret = sigaddset(&set, SIGRTMIN);
        assert(!(-1 == ret));
        ret = sigprocmask(SIG_UNBLOCK, &set, NULL);
        assert(!(-1 == ret));
        printf("解除阻塞 recv sig num: %d\n", num);
    }
    else if (num == SIGINT || num == SIGRTMIN)
    {
        printf("recv sig num: %d\n", num);
    }
    else
    {
        printf(" 其他信號recv sig num: %d\n", num);
    }
}

int main(void)
{
    pid_t pid;
    int ret = 0;
    // 設置回調函數
    struct sigaction act;
    act.sa_handler = myHandler;
    act.sa_flags = SA_SIGINFO;
    // 注冊非實時信號的處理函數
    ret = sigaction(SIGINT, &act, NULL);
    assert(!(-1 == ret));
    // 注冊實時信號的處理函數
    ret = sigaction(SIGRTMIN, &act, NULL);
    assert(!(-1 == ret));
    // 注冊用戶自定義信號
    ret = sigaction(SIGUSR1, &act, NULL);
    assert(!(-1 == ret));
    
    // 把 SIGINT  SIGRTMIN 軍添加到阻塞狀態字中
    sigset_t set;
    ret = sigemptyset(&set);
    assert(!(-1 == ret));
    ret = sigaddset(&set, SIGINT);
    assert(!(-1 == ret));
    ret = sigaddset(&set, SIGRTMIN);
    assert(!(-1 == ret));
    ret = sigprocmask(SIG_BLOCK, &set, NULL);
    assert(!(-1 == ret));
    
    pid = fork();
    assert(!(-1 == ret));
    if (0 == pid)
    {
        union sigval value;
        value.sival_int = 10;
        int i = 0;
        // 發三次不穩定信號
        for (i = 0; i < 3; i++)
        {
            ret = sigqueue(getppid(), SIGINT, value);
            assert(!(-1 == ret));
            printf("發送不可靠信號 ok\n");
        }
        
        // 發三次穩定信號
        value.sival_int = 20;
        for (i = 0; i < 3; i++)
        {
            ret = sigqueue(getppid(), SIGRTMIN, value);
            assert(!(-1 == ret));
            printf("發送可靠信號ok\n");
        }
        // 向父進程發送 SIGUSR1 解除阻塞
        ret = kill(getppid(), SIGUSR1);
        assert(!(-1 == ret));
    }
    while (1)
    {
        sleep(1);
    }
    return 0;
}

二、信號掩碼和信號處理函數的繼承

2.1、信號處理函數的繼承

信號處理函數是進程屬性,所以進程里的每個線程的信號處理函數是相同的。通過fork創建的子進程會繼承父進程的信號處理函數。execve 后設置為處理的信號處理函數會被重置為默認函數,設置為忽略的信號保持不變。意思是如果父進程里信號設置處理為SIG_IGN,那么等到子進程被exec了,這個信號的處理還是被忽略,不會重置為默認函數。

eg:

// test.c --> test
#include <stdlib.h>
  
typedef void (*sighandler_t)(int);
static sighandler_t old_int_handler;
  
static sighandler_t old_handlers[SIGSYS + 1];
  
void sig_handler(int signo)
{
    printf("receive signo %d\n",signo);
    old_handlers[signo](signo);
}
  
int main(int argc, char **argv)
{
    old_handlers[SIGINT] = signal(SIGINT, SIG_IGN);
    old_handlers[SIGTERM] = signal(SIGTERM, sig_handler);
  
    int ret;
  
    ret = fork();
    if (ret == 0) {
        //child
        // 這里execlp將運行 test2 作為子進程。
        execlp("/tmp/test2", "/tmp/test2",(char*)NULL);
    }else if (ret > 0) {
        //parent
        while(1) {
            sleep(1);
        }
    }else{
        perror("");
        abort();
    }
  
}
  
================================================
test2.c --> test2
#include <stdio.h>
int main(int argc, char **argv)
{
    while(1) {
        sleep(1);
    }
    return 0;
}

結論:test換成test2后,SIGINT的處理方式還是忽略,SIGTERM被重置為默認的方式。

2.2、信號掩碼的繼承

信號掩碼有以下規則:

1.每個線程可以有自己信號掩碼。

2.fork出來的子進程會繼承父進程的信號掩碼,exec后信號掩碼保持不變。如果父進程是多線程,那么子進程只繼承主線程的掩碼。

3.針對進程發送的信號,會被任意的沒有屏蔽該信號的線程接收,注意只有一個線程會隨機收到。linux下如果都可以所有線程都可以接收信號,那么信號將默認發送到主線程,posix系統是隨機發送。

4.fork之后子進程里pending的信號集初始化為空,exec會保持pending信號集。

#include <stdio.h>
#include <signal.h>
#include <unistd.h>
#include <stdlib.h>
#include <pthread.h>
  
typedef void (*sighandler_t)(int);
  
static void *thread1(void *arg)
{
    sigset_t set;
      
    printf("in thread1\n");
  
    sigemptyset(&set);
    sigaddset(&set, SIGTERM);
    pthread_sigmask(SIG_BLOCK, &set, NULL);

    while(1) {
        sleep(1);
    }
}
  
static void sigset_print(sigset_t *set)
{
    int i;
  
    for (i = 1; i <= SIGSYS; i++) {
        if (sigismember(set, i)) {
            printf("signal %d is in set\n",i);
        }
    }
}
  
int main(int argc, char **argv)
{
    int ret;
    sigset_t set;
    pthread_t pid;
  
    pthread_create(&pid, NULL, thread1, NULL);
    sleep(1);
  
    sigemptyset(&set);
    sigaddset(&set, SIGINT);
    pthread_sigmask(SIG_BLOCK, &set, NULL);
  
    ret = fork();
    if (ret == 0) {
        //child
        pthread_sigmask(SIG_BLOCK, NULL, &set);
        sigset_print(&set);
  
        while(1) {
            sleep(1);
        }
    }else if (ret > 0) {
        //parent
        while(1) {
            sleep(1);
        }
    }else{
        perror("");
        abort();
    }
  
}

結論:只有在主線程里設置的掩碼才被子進程繼承了。這里面的原因在于linux里的fork只是復制了調用fork()的那個線程,因此在子進程里只有父進程的主線程被拷貝了,當然信號掩碼就是父進程的主線程的信號掩碼的復制了。再次驗證證明,如果是在thread1里調用fork,那么子進程的信號掩碼就會是thread1的拷貝了。

2.3、sigwait 與多線程

sigwait函數:sigwait等一個或者多個指定信號發生。

它所做的工作只有兩個:

第一,監聽被阻塞的信號;

第二,如果所監聽的信號產生了,則將其從未決隊列中移出來。sigwait并不改變信號掩碼的阻塞與非阻塞狀態。

在POSIX標準中,當進程收到信號時,如果是多線程的情況,我們是無法確定是哪一個線程處理這個信號。而sigwait是從進程中pending的信號中,取走指定的信號。這樣的話,如果要確保sigwait這個線程收到該信號,那么所有線程含主線程以及這個sigwait線程則必須block住這個信號,因為如果自己不阻塞就沒有未決狀態(阻塞狀態)信號,別的所有線程不阻塞就有可能當信號過來時,被其他的線程處理掉。

PS:

在多線程代碼中,總是使用sigwait或者sigwaitinfo或者sigtimedwait等函數來處理信號。而不是signal或者sigaction等函數。因為在一個線程中調用signal或者sigaction等函數會改變所以線程中的信號處理函數,而不是僅僅改變調用signal/sigaction的那個線程的信號處理函數。

2.4、多進程下的信號

多進程下鍵盤觸發的信號會同時發送到當前進程組的所有進程。如果一個程序在執行時 fork 了多個子進程,那么按鍵觸發的信號將會被這個程序的所有進程收到。

但是與多線程不一樣,多進程下的信號掩碼和信號處理函數是獨立的。每個進程都可以選擇處理或者不處理,也可以設置自己的信號掩碼。

#include <stdio.h>
#include <sys/types.h>
#include <unistd.h>
#include <signal.h>

int main(int argc, char **argv)
{
    pid_t pid = fork();

    signal(SIGCHLD, SIG_IGN);
    if (pid < 0)
        printf("error fork\n");
    else if (pid == 0)
    {
        signal(SIGINT, SIG_IGN); // 忽略 SIGINT,這樣 ctrl+c 后子進程能活下來; 不設置的話,收到信號將退出
        printf("child gid = %ld\n", getpgid(getpid()));
        do
        {
            sleep(1);
        } while (1);
    }
    else
    {
        printf("parent gid = %ld\n", getpgid(getpid()));
        do
        {
            sleep(1);
        } while (1);
    }

    return 0;
}

如上圖,可以看到,收到SIGINT 后父進程退出,子進程因為設置了忽略 SIGINT 所以子進程沒有受到影響。

三、apis

3.1、信號發生函數

1.kill(pid_t pid, int signum);

2.int sigqueue(pid_t pid, int sig, const union sigval value);

3.pthread_kill(pthread_t tid, int signum);

4.raise(int signum);// 發送信號到自己

5.void alarm(void);

6.void abort(void);

7.int setitimer(int which, const struct itimerval *new_value, struct itimerval *old_value);

PS:

sigqueue()比kill()傳遞了更多的附加信息,但sigqueue()只能向一個進程發送信號,而不能發送信號給一個進程組。如果signo=0,將會執行錯誤檢查,但實際上不發送任何信號,0值信號可用于檢查pid的有效性以及當前進程是否有權限向目標進程發送信號。

3.2、信號處理函數

1.signal(int signum, void (*handler)(int signum))

2.sigaction(int signum, struct sigaction* newact, sigaction* oldact)

sigaction act;
act.sa_handler = handler;
act.sa_flags = SA_SIGINFO;
// 注冊信號的處理函數
sigaction(SIGINT, act, NULL);

3.3、信號掩碼函數

1.sigprocmask(int how, struct sigaction* set,struct sigaction* oldset)

2.pthread_sigmask(int how, struct sigaction* set,struct sigaction* oldset)

sigprocmask用于設置進程的信號掩碼,pthread_sigmask用于設置線程的信號掩碼,二者參數相同。第一個參數有SIG_BLOCK, SIG_UNBLOCK, SIG_SETMASK

3.4、信號集合變量

sigset_t set

sigemptyset(&set) //清空阻塞信號集合變量

sigfillset(&set)  //添加所有的信號到阻塞集合變量里

sigaddset(&set,SIGINT) //添加單一信號到阻塞信號集合變量

sigdelset(&set,SIGINT) //從阻塞信號集合變量中刪除單一信號

sigismember(&set,int signum) //測試信號signum是否包含在信號集合set中,如果包含返回1,不包含返回0,出錯返回-1。錯誤代碼也只有一個EINVAL,表示signum不是有效的信號代碼。

3.5、信號屏蔽函數

1.int sigpending(sigset_t *set); // 返回阻塞的信號集

2.int sigsuspend(const sigset_t *mask);

sigsuspend表示臨時將信號屏蔽字設為mask,并掛起進程直到有信號產生(非屏蔽信號才能喚醒或終止進程),如果信號處理函數返回,那么siguspend將恢復之前的信號屏蔽字(temporarily)

假設sisuspend阻塞進程時產生了信號A,且A不是mask內的屏蔽信號,那么A的信號處理函數有兩種情形,

一:直接終止進程,此時進程都不存在了,那么sigsuspend當然無須返回了(不存在進程了sigsuspend也不存在了,函數棧嘛);

二:如果信號A的處理函數返回,那么信號屏蔽字恢復到sigsuspend之前的(sigsuspend調用時將信號屏蔽字設為mask,所以要恢復到sigsuspend調用之前的),然后sigsuspend返回-1并將error置為EINTR.

以上就是淺談Linux信號機制的詳細內容,更多關于Linux信號機制的資料請關注腳本之家其它相關文章!

標簽:連云港 隴南 遵義 運城 雞西 朝陽 面試通知 荊門

巨人網絡通訊聲明:本文標題《淺談Linux信號機制》,本文關鍵詞  淺談,Linux,信號,機制,淺談,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《淺談Linux信號機制》相關的同類信息!
  • 本頁收集關于淺談Linux信號機制的相關信息資訊供網民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    精品久久久三级丝袜| 欧美在线看片a免费观看| 亚洲国产日韩a在线播放性色| 国产精品午夜在线观看| 国产精品美女久久久久久久 | 亚洲一二三级电影| 一区二区三区四区中文字幕| 亚洲一区二区三区爽爽爽爽爽| 亚洲精品中文字幕在线观看| 一区二区三区精品视频在线| 亚洲成人动漫在线免费观看| 日日夜夜一区二区| 国产一区视频在线看| 国产福利一区在线观看| 成人美女在线视频| 在线免费精品视频| 日韩精品中午字幕| 国产精品网站在线观看| 亚洲一区二区三区三| 蜜桃视频一区二区三区在线观看| 久草热8精品视频在线观看| 成人午夜免费视频| 91视频国产资源| 日韩欧美黄色影院| 日韩理论片一区二区| 婷婷国产v国产偷v亚洲高清| 国产成人午夜精品影院观看视频| 国模娜娜一区二区三区| 成人黄色大片在线观看| 欧美在线视频你懂得| 欧美成人伊人久久综合网| 国产精品久久毛片| 蜜桃视频在线观看一区二区| 99久久精品免费看国产免费软件| 欧美日韩国产免费一区二区| 久久精品一区二区三区不卡| 亚洲超碰精品一区二区| 国v精品久久久网| 欧美美女一区二区在线观看| 国产欧美精品一区aⅴ影院| 日韩精品乱码av一区二区| 成人高清视频在线观看| 日韩三级伦理片妻子的秘密按摩| 国产精品国产精品国产专区不蜜| 日韩不卡手机在线v区| 91丨porny丨国产入口| 亚洲精品在线免费观看视频| 亚洲一区二区精品视频| 国产成人av电影在线观看| 欧美日韩国产首页在线观看| 国产精品久久国产精麻豆99网站| 日韩av一区二| 欧美绝品在线观看成人午夜影视| 国产精品三级视频| 国产激情一区二区三区四区| 日韩色在线观看| 首页国产欧美日韩丝袜| 日本精品裸体写真集在线观看| 国产视频一区不卡| 国产精选一区二区三区| 欧美一区二区二区| 日韩avvvv在线播放| 91久久精品一区二区三| 国产精品不卡一区二区三区| 国产成人精品一区二区三区网站观看| 欧美成人综合网站| 久久成人综合网| 91精品综合久久久久久| 日韩激情一区二区| 欧美一区二区三区四区视频 | 精品久久久久久久久久久院品网| 亚洲成人午夜电影| 欧美喷潮久久久xxxxx| 亚洲一区成人在线| 欧美日韩另类一区| 性做久久久久久久免费看| 欧美日韩视频一区二区| 一区二区三区国产精华| 欧美在线|欧美| 午夜欧美大尺度福利影院在线看| 欧美群妇大交群的观看方式| 香蕉加勒比综合久久| 欧美电影一区二区| 精品在线播放免费| 欧美国产一区二区在线观看| 成人av电影免费观看| 国产精品色哟哟| 91福利视频网站| 日本强好片久久久久久aaa| 欧美一二三四在线| 高清日韩电视剧大全免费| 一区在线播放视频| 欧美综合一区二区三区| 久久成人精品无人区| 欧美激情综合网| 欧美丝袜丝交足nylons图片| 免费不卡在线视频| 国产精品护士白丝一区av| 91视频免费看| 免费成人美女在线观看.| 亚洲国产精品v| 欧美日韩视频在线第一区| 国产在线不卡一区| 伊人性伊人情综合网| 精品精品国产高清a毛片牛牛| 成人免费av在线| 蜜臀久久99精品久久久久宅男 | 午夜av一区二区三区| 精品电影一区二区| 欧洲一区在线电影| 国产在线精品不卡| 视频在线观看一区| 国产精品久久久99| 精品噜噜噜噜久久久久久久久试看| 99久久99久久精品免费看蜜桃| 亚洲成a人片综合在线| 国产视频在线观看一区二区三区| 欧美综合久久久| 国产成人在线观看免费网站| 日韩中文字幕区一区有砖一区 | 免费美女久久99| 亚洲视频一区在线| 国产视频一区不卡| 日韩免费看网站| 欧美精品久久99久久在免费线| 99re6这里只有精品视频在线观看 99re8在线精品视频免费播放 | 奇米精品一区二区三区在线观看一| 国产精品美女久久久久高潮| 日韩一区二区三区电影在线观看| 欧洲一区在线电影| 风间由美中文字幕在线看视频国产欧美 | 欧美大黄免费观看| 欧美日韩国产欧美日美国产精品| 高清免费成人av| 国产精品一区二区91| 韩国一区二区在线观看| 奇米四色…亚洲| 麻豆国产一区二区| 日韩精品乱码免费| 天堂va蜜桃一区二区三区漫画版| 亚洲精品国产a| 亚洲美女屁股眼交| 亚洲免费视频成人| 亚洲三级电影全部在线观看高清| 国产欧美日本一区视频| 国产精品污www在线观看| 国产日产欧美一区二区视频| 国产网站一区二区| 国产精品天天看| 中文字幕不卡在线观看| 亚洲国产精品激情在线观看| 国产亚洲欧洲997久久综合| 国产视频视频一区| 亚洲欧洲日韩在线| 夜色激情一区二区| 亚洲3atv精品一区二区三区| 日韩电影免费在线看| 久久不见久久见免费视频1| 韩国精品主播一区二区在线观看| 国产在线精品一区二区不卡了 | 欧美一级在线视频| 日韩欧美国产1| 国产色91在线| 亚洲桃色在线一区| 日韩精品电影在线| 国产一区二区三区观看| 成人午夜大片免费观看| 91丨九色丨蝌蚪富婆spa| 欧美视频完全免费看| 日韩女优毛片在线| 国产精品国产三级国产aⅴ无密码| 亚洲同性gay激情无套| 午夜精品久久久久久久99水蜜桃| 免费观看成人av| 91婷婷韩国欧美一区二区| 欧美高清一级片在线| 久久日韩粉嫩一区二区三区| 18成人在线视频| 日本不卡一二三区黄网| caoporn国产一区二区| 91精品黄色片免费大全| 成人免费在线观看入口| 美女精品自拍一二三四| 国产91精品在线观看| 在线一区二区三区| 精品国产第一区二区三区观看体验| 国产精品日韩成人| 欧美aⅴ一区二区三区视频| 国产999精品久久久久久绿帽| 欧美日韩亚洲丝袜制服| 国产精品素人一区二区| 美洲天堂一区二卡三卡四卡视频| 99久久伊人网影院| 久久精品视频网| 日本sm残虐另类| 99精品视频一区| 国产精品久久久久三级| 久久99九九99精品| 777xxx欧美| 亚洲丰满少妇videoshd|