国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

Linux內核信號SIGIO使用實例講解

系統 Linux
信號是在軟件層次上對中斷機制的一種模擬,在原理上,一個進程收到一個信號與處理器收到一個中斷請求可以說是一樣的。信號是異步的,一個進程不必通過任何操作來等待信號的到達,事實上,進程也不知道信號到底什么時候到達。

[[410753]]

一、信號

1. 基本概念

信號是在軟件層次上對中斷機制的一種模擬,在原理上,一個進程收到一個信號與處理器收到一個中斷請求可以說是一樣的。信號是異步的,一個進程不必通過任何操作來等待信號的到達,事實上,進程也不知道信號到底什么時候到達。

例如鍵盤輸入中斷按鍵(^C),它的發生在程序執行過程中是不可預測的。

信號是進程間通信機制中唯一的異步通信機制,可以看作是異步通知,通知接收信號的進程有哪些事情發生了。

硬件異常也能產生信號,例如被零除、無效內存引用(test里產生的就是這種錯誤)等。這些條件通常先由內核硬件檢測到,然后通知內核。內核將決定產生什么樣的信號。

同一個信號的額外發生通常不會被排隊。如果信號在被阻塞時發生了5次,當我們反阻塞這個信號時,這個信號的信號處理函數通常只被調用一次。

同一時刻只能處理一個信號,在信號處理函數發信號給自己時,該信號會被pending。

信號的數值越小,則優先級越高。當進程收到多個待處理信號時,總是先處理優先級別高的信號。

信號處理函數的棧可以使用被中斷的也可以使用獨立的,具體可以通過系統調用設置。

信號機制經過POSIX實時擴展后,功能更加強大,除了基本通知功能外,還可以傳遞附加信息。

2. 處理方式

忽略:接收到信號后不做任何反應。捕獲:用自定義的信號處理函數來執行特定的動作。默認:接收到信號后按系統默認的行為處理該信號。這是多數應用采取的處理方式。

二、Linux下的信號類型

使用kill -l就會顯示出linux支持的信號列表。

其中列表中,編號為1 ~ 31的信號為傳統UNIX支持的信號,是不可靠信號(非實時的),編號為32 ~ 63的信號是后來擴充的,稱做可靠信號(實時信號)。不可靠信號和可靠信號的區別在于前者不支持排隊,可能會造成信號丟失,而后者不會。

下面我們對編號小于SIGRTMIN的信號進行討論(下面的編號 依次對應信號 的數值為1 - 31)。

1) SIGHUP

本信號在用戶終端連接(正常或非正常)結束時發出, 通常是在終端的控制進程結束時, 通知同一session內的各個作業, 這時它們與控制終端不再關聯。

登錄Linux時,系統會分配給登錄用戶一個終端(Session)。在這個終端運行的所有程序,包括前臺進程組和后臺進程組,一般都 屬于這個 Session。當用戶退出Linux登錄時,前臺進程組和后臺有對終端輸出的進程將會收到SIGHUP信號。這個信號的默認操作為終止進程,因此前臺進 程組和后臺有終端輸出的進程就會中止。不過可以捕獲這個信號,比如wget能捕獲SIGHUP信號,并忽略它,這樣就算退出了Linux登錄,wget也 能繼續下載。

此外,對于與終端脫離關系的守護進程,這個信號用于通知它重新讀取配置文件。

2) SIGINT

程序終止(interrupt)信號, 在用戶鍵入INTR字符(通常是Ctrl-C)時發出,用于通知前臺進程組終止進程。

3) SIGQUIT

和SIGINT類似, 但由QUIT字符(通常是Ctrl-)來控制. 進程在因收到SIGQUIT退出時會產生core文件, 在這個意義上類似于一個程序錯誤信號。

4) SIGILL

執行了非法指令. 通常是因為可執行文件本身出現錯誤, 或者試圖執行數據段. 堆棧溢出時也有可能產生這個信號。

5) SIGTRAP

由斷點指令或其它trap指令產生. 由debugger使用。

6) SIGABRT

調用abort函數生成的信號。

7) SIGBUS

非法地址, 包括內存地址對齊(alignment)出錯。比如訪問一個四個字長的整數, 但其地址不是4的倍數。它與SIGSEGV的區別在于后者是由于對合法存儲地址的非法訪問觸發的(如訪問不屬于自己存儲空間或只讀存儲空間)。

8) SIGFPE

在發生致命的算術運算錯誤時發出. 不僅包括浮點運算錯誤, 還包括溢出及除數為0等其它所有的算術的錯誤。

9) SIGKILL

用來立即結束程序的運行. 本信號不能被阻塞、處理和忽略。如果管理員發現某個進程終止不了,可嘗試發送這個信號。

10) SIGUSR1

留給用戶使用

11) SIGSEGV

試圖訪問未分配給自己的內存, 或試圖往沒有寫權限的內存地址寫數據.

信號 11,即表示程序中可能存在特定條件下的非法內存訪問。

12) SIGUSR2

留給用戶使用

13) SIGPIPE

管道破裂。這個信號通常在進程間通信產生,比如采用FIFO(管道)通信的兩個進程,讀管道沒打開或者意外終止就往管道寫,寫進程會收到SIGPIPE信號。此外用Socket通信的兩個進程,寫進程在寫Socket的時候,讀進程已經終止。

14) SIGALRM

時鐘定時信號, 計算的是實際的時間或時鐘時間. alarm函數使用該信號.

15) SIGTERM

程序結束(terminate)信號, 與SIGKILL不同的是該信號可以被阻塞和處理。通常用來要求程序自己正常退出,shell命令kill缺省產生這個信號。如果進程終止不了,我們才會嘗試SIGKILL。

17) SIGCHLD

子進程結束時, 父進程會收到這個信號。

如果父進程沒有處理這個信號,也沒有等待(wait)子進程,子進程雖然終止,但是還會在內核進程表中占有表項,這時的子進程稱為僵尸 進程。這種情 況我們應該避免(父進程或者忽略SIGCHILD信號,或者捕捉它,或者wait它派生的子進程,或者父進程先終止,這時子進程的終止自動由init進程 來接管)。

18) SIGCONT

讓一個停止(stopped)的進程繼續執行. 本信號不能被阻塞. 可以用一個handler來讓程序在由stopped狀態變為繼續執行時完成特定的工作. 例如, 重新顯示提示符

19) SIGSTOP

停止(stopped)進程的執行. 注意它和terminate以及interrupt的區別:該進程還未結束, 只是暫停執行. 本信號不能被阻塞, 處理或忽略.

20) SIGTSTP

停止進程的運行, 但該信號可以被處理和忽略. 用戶鍵入SUSP字符時(通常是Ctrl-Z)發出這個信號

21) SIGTTIN

當后臺作業要從用戶終端讀數據時, 該作業中的所有進程會收到SIGTTIN信號. 缺省時這些進程會停止執行.

22) SIGTTOU

類似于SIGTTIN, 但在寫終端(或修改終端模式)時收到.

23) SIGURG

有"緊急"數據或out-of-band數據到達socket時產生.

24) SIGXCPU

超過CPU時間資源限制. 這個限制可以由getrlimit/setrlimit來讀取/改變。

25) SIGXFSZ

當進程企圖擴大文件以至于超過文件大小資源限制。

26) SIGVTALRM

虛擬時鐘信號. 類似于SIGALRM, 但是計算的是該進程占用的CPU時間.

27) SIGPROF

類似于SIGALRM/SIGVTALRM, 但包括該進程用的CPU時間以及系統調用的時間.

28) SIGWINCH

窗口大小改變時發出.

29) SIGIO

文件描述符準備就緒, 可以開始進行輸入/輸出操作.

30) SIGPWR

Power failure

31) SIGSYS

非法的系統調用。

三、 信號行為說明

不通的信號在不同的標準下,功能有所差別,下面列出主要的信號的默認行為和說明:

名稱 數字 標準 默認行為 說明
SIGILL 4 ANSI 終止+coredump 執行了非法指令. 通常是因為可執行文件本身出現錯誤, 或者試圖執行數據段. 堆棧溢出時也有可能產生這個信號
SIGABRT 6 ANSI 終止+coredump 調用abort函數生成的信號
SIGBUS 7 4.2 BSD 終止+coredump 非法地址, 包括內存地址對齊(alignment)出錯。比如訪問一個四個字長的整數, 但其地址不是4的倍數。它與SIGSEGV的區別在于后者是由于對合法存儲地址的非法訪問觸發的(如訪問不屬于自己存儲空間或只讀存儲空間)
SIGFPE 8 ANSI 終止+coredump 在發生致命的算術運算錯誤時發出. 不僅包括浮點運算錯誤, 還包括溢出及除數為0等其它所有的算術的錯誤
SIGSEGV 11 ANSI 終止+coredump 試圖訪問未分配給自己的內存, 或試圖往沒有寫權限的內存地址寫數據。訪問空指針,野指針基本都產生這個信號,也是最常見的信號
SIGSTKFLT 16 N/A 終止 堆棧錯誤
SIGPIPE 13 POSIX 終止 管道破裂。這個信號通常在進程間通信產生,比如采用FIFO(管道)通信的兩個進程,讀管道沒打開或者意外終止就往管道寫,寫進程會收到SIGPIPE信號。此外用Socket通信的兩個進程,寫進程在寫Socket的時候,讀進程已經終止
SIGTRAP 5 POSIX 終止+coredump 由斷點指令或其它trap指令產生. 由debugger使用
SIGHUP 1 POSIX 終止 用戶終端連接(正常或非正常)結束時發出, 通常是在終端的控制進程結束時, 通知同一session內的各個作業, 這時它們與控制終端不再關聯
SIGINT 2 ANSI 終止 程序終止(interrupt)信號, 在用戶鍵入INTR字符(通常是Ctrl-C)時發出,用于通知前臺進程組終止進程
SIGQUIT 3 POSIX 終止+coredump 和SIGINT類似, 但由QUIT字符(通常是Ctrl-)來控制. 進程在因收到SIGQUIT退出時會產生core文件, 在這個意義上類似于一個程序錯誤信號
SIGKILL 9 POSIX 終止 用來立即結束程序的運行. 本信號不能被阻塞、捕獲和忽略。如果管理員發現某個進程終止不了,可嘗試發送這個信號
SIGCHLD 17 POSIX 忽略 子進程結束時, 父進程會收到這個信號。如果父進程沒有處理這個信號,也沒有等待(wait)子進程,子進程雖然終止,但是還會在內核進程表中占有表項,這時的子進程稱為僵尸進程。這種情 況我們應該避免(父進程或者忽略SIGCHILD信號,或者捕捉它,或者wait它派生的子進程,或者父進程先終止,這時子進程的終止自動由init進程來接管)
SIGCONT 18 POSIX 繼續/忽略 讓一個停止(stopped)的進程繼續執行. 本信號不能被阻塞 . 可以用一個handler來讓程序在由stopped狀態變為繼續執行時完成特定的工作. 例如, 重新顯示提示符..在進程掛起時是繼續,否則是忽略
SIGSTOP 19 POSIX 暫停 暫停進程的執行. 注意它和terminate以及interrupt的區別:該進程還未結束, 只是暫停執行. 本信號不能被阻塞、捕獲或忽略
SIGALRM 14 POSIX 終止 時鐘定時信號, 計算的是實際的時間或時鐘時間. alarm函數使用該信號

四、信號分類

在以上列出的信號中,程序不可捕獲、阻塞或忽略的信號有:

  1. SIGKILL,SIGSTOP  

不能恢復至默認動作的信號有:

  1. SIGILL,SIGTRAP  

默認會導致進程流產的信,有:

  1. SIGABRT,SIGBUS,SIGFPE,SIGILL,SIGIOT,SIGQUIT,SIGSEGV,SIGTRAP,SIGXCPU,SIGXFSZ  

默認會導致進程退出的信號有:

  1. SIGALRM,SIGHUP,SIGINT,SIGKILL,SIGPIPE,SIGPOLL,SIGPROF,SIGSYS,SIGTERM,SIGUSR1,SIGUSR2,SIGVTALRM  

默認會導致進程停止的信號有:

  1. SIGSTOP,SIGTSTP,SIGTTIN,SIGTTOU  

默認進程忽略的信號有:

  1. SIGCHLD,SIGPWR,SIGURG,SIGWINCH 

此外,SIGIO在SVR4是退出,在4.3BSD中是忽略;

SIGCONT在進程掛起時是繼續,否則是忽略,不能被阻塞

終止程序的時候在不得已的情況下不能用SIGKILL,因為SIGKILL不會對子進程進行處理,只是把對自己進行處理。

五、信號驅動IO-SIGIO-29

下面我們主要講SIGIO-29的使用。

參考上圖:

  • 時刻1 通過sigaction系統調用建立信號SIGIO的信號處理函數,該函數壺立即返回,注意,對應的驅動必須支持方法.fastnc
  • 時刻2 數據此時沒有準備好,應進程會繼續執行,而內核會繼續等待數據,也就是說等待數據階段應用進程是非阻塞的。
  • 時刻3 內核準備好了數據,要向應用進程復制數據,通過函數kill_fasync()向應用程序遞交SIGIO信號,二應用程序的信號處理程序會被調用到,在該函數中我們可以通過read等系統調用從內核賦值程序到進程
  • 時刻4 在賦值數據期間,進程阻塞
  • 時刻5 數據復制完成,會返回成功的指示,應用程序可以繼續處理數據

信號驅動 I/O 的 CPU 利用率很高,因為在圖中,等待數據的那段時間2,應用程序可以繼續執行其他操作。

六、程序實現

1. 信號注冊函數signal()

  1. #include <signal.h> 
  2. typedef void (*sighandler_t)(int); 
  3. sighandler_t signal(int signum, sighandler_t handler); 

功能:

  1. 給信號signum注冊處理函數,函數原型是void (*sighandler_t)(int
  2. 當收到信號signum后,就會調用注冊的函數 

參數:

  1. int signum  信號值 
  2. sighandler_t handler  信號處理函數 

2.內核函數

  1. void kill_fasync(struct fasync_struct **fp, int sig, int band) 

功能:

發送信號sig給進程,通知進程是可讀還是可寫,由band給出

  1. 發送信號sig給進程,通知進程是可讀還是可寫,由band給出 
  2. POLLIN    :可讀 
  3. POLLOUT:可寫 

通用字符設備的.fasync方法,一般都是固定的寫法,我們暫時可以不用關心他的原理,會用即可,具體寫法如下:

  1. static ssize_t hello_write (struct file *filep, const char __user *buf, size_t size, loff_t *pos) 
  2.  int error; 
  3. ………… 
  4.  kill_fasync(&hello_fasync,SIGIO,POLLIN); 
  5.  return size
  6.  
  7. static struct file_operations hello_ops =  
  8. ………… 
  9.  .fasync = hello_fasync_func, 
  10. }; 

2. 源程序

驅動程序:hello.c

  1. /*   
  2.  *公眾號:一口Linux 
  3.  *2021.6.21 
  4.  *version: 1.0.0 
  5. */ 
  6. #include <linux/init.h> 
  7. #include <linux/module.h> 
  8. #include <linux/kdev_t.h> 
  9. #include <linux/fs.h> 
  10. #include <linux/cdev.h> 
  11. #include <linux/uaccess.h> 
  12. #include <linux/poll.h>  
  13. #include<asm/signal.h> 
  14.  
  15. static int major = 237; 
  16. static int minor = 0; 
  17. static dev_t devno; 
  18. static struct cdev cdev; 
  19. struct device *class_dev = NULL
  20. struct class *cls; 
  21.  
  22. struct fasync_struct *hello_fasync; 
  23.  
  24. static int hello_open (struct inode *inode, struct file *filep) 
  25.  printk("hello_open()\n"); 
  26.  return 0; 
  27. static int hello_release (struct inode *inode, struct file *filep) 
  28.  printk("hello_release()\n"); 
  29.  
  30.  return 0; 
  31.  
  32. #define KMAX_LEN 32 
  33. char kbuf[KMAX_LEN+1] = "kernel"
  34.  
  35.  
  36. //read(fd,buff,40); 
  37.  
  38. static ssize_t hello_read (struct file *filep, char __user *buf, size_t size, loff_t *pos) 
  39.  int error; 
  40.  
  41.   
  42.  if(size > strlen(kbuf)) 
  43.  { 
  44.   size = strlen(kbuf); 
  45.  } 
  46.  
  47.  if(copy_to_user(buf,kbuf, size)) 
  48.  { 
  49.   error = -EFAULT; 
  50.   return error; 
  51.  } 
  52.  
  53.  return size
  54. //write(fd,buff,40); 
  55. static ssize_t hello_write (struct file *filep, const char __user *buf, size_t size, loff_t *pos) 
  56.  int error; 
  57.  
  58.  if(size > KMAX_LEN) 
  59.  { 
  60.   size = KMAX_LEN; 
  61.  } 
  62.  memset(kbuf,0,sizeof(kbuf)); 
  63.  if(copy_from_user(kbuf, buf, size)) 
  64.  { 
  65.   error = -EFAULT; 
  66.   return error; 
  67.  } 
  68.  printk("%s\n",kbuf); 
  69.  kill_fasync(&hello_fasync,SIGIO,POLLIN); 
  70.  return size
  71.  
  72. int hello_fasync_func(int fd,struct file* filep,int on
  73.  printk("led_fasync \n"); 
  74.  return fasync_helper(fd,filep,on,&hello_fasync); 
  75.  
  76. static struct file_operations hello_ops =  
  77.  .open = hello_open, 
  78.  .release = hello_release, 
  79.  .read = hello_read, 
  80.  .write = hello_write, 
  81.  .fasync = hello_fasync_func, 
  82. }; 
  83. static int hello_init(void) 
  84.  int result; 
  85.  int error; 
  86.   
  87.  printk("hello_init \n"); 
  88.  result = register_chrdev( major, "hello", &hello_ops); 
  89.  if(result < 0) 
  90.  { 
  91.   printk("register_chrdev fail \n"); 
  92.   return result; 
  93.  } 
  94.  cls = class_create(THIS_MODULE, "hellocls"); 
  95.  if (IS_ERR(cls)) { 
  96.   printk(KERN_ERR "class_create() failed for cls\n"); 
  97.   result = PTR_ERR(cls); 
  98.   goto out_err_1; 
  99.  } 
  100.  devno = MKDEV(major, minor); 
  101.   
  102.  class_dev = device_create(cls, NULL, devno, NULL"hellodev"); 
  103.  if (IS_ERR(class_dev)) { 
  104.   result = PTR_ERR(class_dev); 
  105.   goto out_err_2; 
  106.  } 
  107.   
  108.  return 0; 
  109.  
  110. out_err_2: 
  111.  class_destroy(cls); 
  112. out_err_1: 
  113.  unregister_chrdev(major,"hello"); 
  114.  return  result; 
  115. static void hello_exit(void) 
  116.  printk("hello_exit \n"); 
  117.  device_destroy(cls, devno); 
  118.  class_destroy(cls); 
  119.  unregister_chrdev(major,"hello"); 
  120.  return
  121. module_init(hello_init); 
  122. module_exit(hello_exit); 
  123. MODULE_LICENSE("GPL"); 
  124. //proc/devices 

write.c

  1. /*   
  2.  *一口Linux 
  3.  *2021.6.21 
  4.  *version: 1.0.0 
  5. */ 
  6.  
  7. #include <stdio.h> 
  8. #include <sys/types.h> 
  9. #include <sys/stat.h> 
  10. #include <fcntl.h> 
  11. main() 
  12.  int fd; 
  13.  int len; 
  14.  char buf[64]={0}; 
  15.  char buf2[64+1]="peng"
  16.   
  17.   
  18.  fd = open("/dev/hellodev",O_RDWR); 
  19.  if(fd<0) 
  20.  { 
  21.   perror("open fail \n"); 
  22.   return
  23.  } 
  24.  
  25.   
  26.  printf("before write\n"); 
  27.  len = write(fd,buf2,strlen(buf2)); 
  28.  printf("after write\n"); 
  29.  
  30.  printf("len = %d\n",len); 
  31.   
  32.    
  33.  close(fd); 

test.c

  1. /*   
  2.  *公眾號:一口Linux 
  3.  *2021.6.21 
  4.  *version: 1.0.0 
  5. */ 
  6. #include <stdio.h> 
  7. #include <sys/types.h> 
  8. #include <sys/stat.h> 
  9. #include <fcntl.h> 
  10. #include<signal.h> 
  11.  
  12. char buff[64] = {0}; 
  13. int fd; 
  14.  
  15. void func(int signo) 
  16.  printf("signo= %d\n",signo); 
  17.  read(fd,buff,sizeof(buff)); 
  18.  printf("buff=%s\n",buff); 
  19.  return ; 
  20.  
  21. main() 
  22.  int flage; 
  23.  
  24.  fd = open("/dev/hellodev",O_RDWR); 
  25.  if(fd<0) 
  26.  { 
  27.   perror("open fail \n"); 
  28.   return
  29.  } 
  30.  fcntl(fd,F_SETOWN,getpid()); 
  31.  flage=fcntl(fd,F_GETFL); 
  32.  fcntl(fd,F_SETFL,flage|FASYNC); 
  33.     signal(SIGIO,func); 
  34.  while(1);  
  35.  close(fd); 

3. 執行結果

編譯

  1. make 
  2. gcc test.c -o run 
  3. gcc write.c -o run 

執行:

  1. insmod hello.ko 

先開啟一個終端 ,執行

  1. ./run 

再開啟一個終端 ,執行

  1. ./w 

執行結果如下:

 

可以看到,寫入數據后,信號處理程序被調用到,并且打印出信號的值29,同時從驅動力讀取出數據。

本文轉載自微信公眾號「一口Linux」,可以通過以下二維碼關注。轉載本文請聯系一口Linux公眾號。

 

責任編輯:武曉燕 來源: 一口Linux
相關推薦

2020-11-05 09:59:24

Linux內核信號量

2010-06-11 17:44:10

UML對象圖

2010-06-30 11:09:16

Linux SNMP

2012-05-08 11:01:45

linux守護進程

2010-06-22 12:52:37

Linux at命令

2010-05-05 13:13:55

Unix內核

2009-12-24 15:09:16

Linux內核版本

2021-10-06 20:00:08

LinuxLinux內核Kasan

2010-04-30 16:08:20

Unix內核

2010-04-30 16:19:17

Unix內核

2010-09-14 17:20:57

2010-06-03 18:22:38

Hadoop

2011-04-02 16:37:26

PAT

2009-12-25 14:30:05

Linux Vi命令

2023-11-02 08:25:58

C++Lambda

2017-08-02 14:37:31

LinuxKdump內核崩潰

2009-12-30 16:38:44

Ubuntu內核

2009-12-24 17:06:35

編譯Fedora內核

2010-04-21 13:47:45

Unix內核

2010-09-03 10:23:49

PPP Multili
點贊
收藏

51CTO技術棧公眾號

av7777777| 国产精品久久久久久久一区探花 | 日韩欧美黄色大片| 欧美日韩在线网站| 91麻豆精品国产| 精品久久久久av| 在线精品在线| 欧美一级高清免费| 欧美裸体视频| 欧美日韩dvd| 欧美第一黄网免费网站| 亚洲女人被黑人巨大进入al| 中文字幕九色91在线| 大伊香蕉精品视频在线| 在线免费激情视频| 亚洲三级网页| 色哟哟亚洲精品| 国产又大又长又粗又黄| 麻豆网在线观看| 国产日韩欧美综合一区| 欧美激情专区| 激情六月婷婷久久| 一区二区三区四区免费观看| 91丨porny丨户外露出| 福利在线白白| 欧美变态口味重另类| 国产高清一区在线观看| 国产日产一区| 亚洲尤物视频网| 日本午夜精品一区二区三区电影| 综合一区中文字幕| 久久久亚洲高清| 一本大道香蕉8中文在线视频| 欧美日韩精品久久久| 久久女人天堂| 国产精品国产三级国产专播精品人| 一区在线免费| 97超碰国产精品| 欧美三级xxx| 精品视频在线一区| 欧美一二三区| 一区二区国产视频| 98色花堂精品视频在线观看| 7777免费精品视频| 麻豆成人在线观看| h精品动漫在线观看| 亚洲欧美日韩中文在线| 欧美影视一区| 成人xxx免费视频播放| 亚洲黄色免费电影| 一本到av在线| 91成人免费网站| 青青热久免费精品视频在线18| 在线观看亚洲a| 欧美亚洲二区| 成人黄色免费片| 日本午夜一区二区| 免费极品av一视觉盛宴| 久久99久久精品| 法国空姐在线观看免费| 日韩av在线播放中文字幕| 欧美成人黑人xx视频免费观看| 黄色网在线免费观看| 色88888久久久久久影院按摩| 在线播放国产区| 一区二区三区在线播放| 伊人中文在线| 欧美日韩夫妻久久| 丝袜美腿一区| 奇米成人av国产一区二区三区| 国内自拍欧美| 欧美xxxx黑人又粗又长精品| 韩国精品久久久| 成人污网站在线观看| 日本在线不卡视频一二三区| 欧美少妇一级片| 精品欧美aⅴ在线网站| 国产精品一区二区婷婷| 中文字幕一区二区5566日韩| 黄色a级片免费看| 国产综合色产在线精品| 初尝黑人巨炮波多野结衣电影| 岛国视频午夜一区免费在线观看| 日本天码aⅴ片在线电影网站| 中文字幕一区电影| 好看的av在线不卡观看| 一区二区三区四区国产| 欧美激情一区二区三区| 在线免费观看你懂的| 亚洲欧美另类自拍| 亚洲系列另类av| 97se在线视频| 国产成人精品网址| 亚洲大胆人体大胆做受1| 久久国产天堂福利天堂| 亚洲性色视频| 日本粉色视频在线观看| 亚洲毛片在线观看.| 欧美激情91| 熟妇人妻无乱码中文字幕真矢织江| 日韩一区欧美一区| 美乳在线观看| 亚洲国产欧美在线| 香蕉视频在线观看免费| 最好看的2019的中文字幕视频| 欧美一区91| 在线观看h视频| 高清欧美性猛交xxxx黑人猛交| 午夜欧美视频| 九色porny在线| 国产日本欧美视频| 亚洲天堂av一区| 国产深夜视频在线观看| 97在线视频观看| 成人午夜又粗又硬又大| 金瓶狂野欧美性猛交xxxx | 99久久综合| 最新欧美日韩亚洲| 婷婷夜色潮精品综合在线| 国产精品久久久久久久久免费高清| 不卡视频一区二区三区| 色婷婷av一区二区三区久久| 视频一区中文字幕精品| 久久夜精品香蕉| 国产一区二区久久| 欧美日韩尤物久久| 日韩专区精品| 久久青青草综合| 亚洲小说欧美激情另类| 中文字幕久久精品一区二区| 国产精品久久久久一区二区国产| 国产高清精品一区| 国产成人av一区二区三区| 91精品久久香蕉国产线看观看| 狠狠爱一区二区三区| 日韩伦理一区二区三区av在线| 一区二区高清视频| 91视频成人免费| av亚洲产国偷v产偷v自拍| 中国黄色录像片| 久久久在线免费观看| 欧美黄色片视频| 秋霞午夜一区二区| 成人两性免费视频| 九色91在线视频| 免费成人深夜夜行网站视频| 欧美 日韩 国产在线观看| 久草在线国产| 蜜芽tv福利在线视频| 国产精品一区hongkong| 国产精品videossex撒尿| 国语一区二区三区| 欧美1区免费| 国产高清精品在线| 亚洲卡通动漫在线| 欧美成人video| 91国语精品自产拍在线观看性色 | 日韩不卡视频在线观看| 你懂的一区二区三区| 奇米影视一区二区三区小说| 国产欧美日韩一区二区三区在线观看| 亚洲国产视频一区| 中文字幕一区日韩电影| 99久久99久久精品国产片| 男女激情无遮挡| 久久亚洲国产成人精品无码区| 国产97免费视| 国产精品丝袜久久久久久不卡| 中文字幕日韩电影| 日韩一级完整毛片| 欧美视频不卡中文| 亚洲国产天堂久久国产91| 日本vs亚洲vs韩国一区三区 | 久久综合久久综合九色| 欧美精品99| 91精品一区国产高清在线gif| 久热国产精品| 在线观看日韩毛片| 日韩视频免费观看高清完整版在线观看 | 日韩肉感妇bbwbbwbbw| 亚洲高清视频一区二区| 国产欧美一区二区在线播放| 韩国精品久久久999| 欧美在线视频一二三| 天天操天天干天天玩| 欧美日韩亚洲一二三| 天天爱天天操天天干| 成人免费乱码大片a毛片软件| 欧美在线观看视频网站| sihu成人| 理论视频在线观看| 日本成人一区二区三区| 免费毛片在线看片免费丝瓜视频 | www.com毛片| 久久久久中文字幕| 欧美激情精品在线| 欧美激情2020午夜免费观看| 青青久久av北条麻妃海外网| 欧美成人激情在线| 久久国产精彩视频|