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

Linux 工作隊列 workqueue 是什么鬼?

系統 Linux
這篇文章,我們就通過實際的代碼操作,來演示一下工作隊列(workqueue)的使用方式。

 

目錄

  • 工作隊列是什么
  •  驅動程序
  •  編譯、測試

別人的經驗,我們的階梯!

Linux中斷處理可用下圖總結:

圖中描述了中斷處理中的下半部分都有哪些機制,以及如何根據實際的業務場景、限制條件來進行選擇。

可以看出:這些不同的實現之間,有些是重復的,或者是相互取代的關系。

也正因為此,它們之間的使用方式幾乎是大同小異,至少是在API接口函數的使用方式上,從使用這的角度來看,都是非常類似的。

這篇文章,我們就通過實際的代碼操作,來演示一下工作隊列(workqueue)的使用方式。

工作隊列是什么

工作隊列是Linux操作系統中,進行中斷下半部分處理的重要方式!

從名稱上可以猜到:一個工作隊列就好像業務層常用的消息隊列一樣,里面存放著很多的工作項等待著被處理。

工作隊列中有兩個重要的結構體:工作隊列(workqueue_struct) 和 工作項(work_struct): 

  1. struct workqueue_struct {  
  2.     struct list_head        pwqs;           /* WR: all pwqs of this wq */  
  3.     struct list_head        list;           /* PR: list of all workqueues */  
  4.     ...  
  5.     char                    name[WQ_NAME_LEN]; /* I: workqueue name */  
  6.     ...  
  7.     /* hot fields used during command issue, aligned to cacheline */  
  8.     unsigned int            flags ____cacheline_aligned; /* WQ: WQ_* flags */  
  9.     struct pool_workqueue __percpu *cpu_pwqs; /* I: per-cpu pwqs */  
  10.     struct pool_workqueue __rcu *numa_pwq_tbl[]; /* PWR: unbound pwqs indexed by node */  
  11. };  
  1. struct work_struct {  
  2.         atomic_long_t data;  
  3.         struct list_head entry;  
  4.         work_func_t func;   // 指向處理函數  
  5. #ifdef CONFIG_LOCKDEP                                                                                   
  6.          struct lockdep_map lockdep_map;  
  7. #endif  
  8. }; 

在內核中,工作隊列中的所有工作項,是通過鏈表串在一起的,并且等待著操作系統中的某個線程挨個取出來處理。

這些線程,可以是由驅動程序通過 kthread_create 創建的線程,也可以是由操作系統預先就創建好的線程。

這里就涉及到一個取舍的問題了。

如果我們的處理函數很簡單,那么就沒有必要創建一個單獨的線程來處理了。

原因有二:

  1.   創建一個內核線程是很耗費資源的,如果函數很簡單,很快執行結束之后再關閉線程,太劃不來了,得不償失;
  2.   如果每一個驅動程序編寫者都毫無節制地創建內核線程,那么內核中將會存在大量不必要的線程,當然了本質上還是系統資源消耗和執行效率的問題;

為了避免這種情況,于是操作系統就為我們預先創建好一些工作隊列和內核線程。

我們只需要把需要處理的工作項,直接添加到這些預先創建好的工作隊列中就可以了,它們就會被相應的內核線程取出來處理。

例如下面這些工作隊列,就是內核默認創建的(include/linux/workqueue.h): 

  1. /*  
  2.  * System-wide workqueues which are always present.  
  3.  *  
  4.  * system_wq is the one used by schedule[_delayed]_work[_on]().  
  5.  * Multi-CPU multi-threaded.  There are users which expect relatively  
  6.  * short queue flush time.  Don't queue works which can run for too  
  7.  * long.  
  8.  *  
  9.  * system_highpri_wq is similar to system_wq but for work items which  
  10.  * require WQ_HIGHPRI.  
  11.  *  
  12.  * system_long_wq is similar to system_wq but may host long running  
  13.  * works.  Queue flushing might take relatively long.  
  14.  *  
  15.  * system_unbound_wq is unbound workqueue.  Workers are not bound to  
  16.  * any specific CPU, not concurrency managed, and all queued works are  
  17.  * executed immediately as long as max_active limit is not reached and  
  18.  * resources are available.  
  19.  *  
  20.  * system_freezable_wq is equivalent to system_wq except that it's  
  21.  * freezable.  
  22.  *  
  23.  * *_power_efficient_wq are inclined towards saving power and converted  
  24.  * into WQ_UNBOUND variants if 'wq_power_efficient' is enabled; otherwise,  
  25.  * they are same as their non-power-efficient counterparts - e.g.  
  26.  * system_power_efficient_wq is identical to system_wq if  
  27.  * 'wq_power_efficient' is disabled.  See WQ_POWER_EFFICIENT for more info.  
  28.  */  
  29. extern struct workqueue_struct *system_wq;  
  30. extern struct workqueue_struct *system_highpri_wq;  
  31. extern struct workqueue_struct *system_long_wq;  
  32. extern struct workqueue_struct *system_unbound_wq;  
  33. extern struct workqueue_struct *system_freezable_wq;  
  34. extern struct workqueue_struct *system_power_efficient_wq;  
  35. extern struct workqueue_struct *system_freezable_power_efficient_wq; 

以上這些默認工作隊列的創建代碼是(kernel/workqueue.c): 

  1. int __init workqueue_init_early(void)  
  2.  
  3.     ...      
  4.     system_wq = alloc_workqueue("events", 0, 0);  
  5.     system_highpri_wq = alloc_workqueue("events_highpri", WQ_HIGHPRI, 0);                        
  6.     system_long_wq = alloc_workqueue("events_long", 0, 0);  
  7.     system_unbound_wq = alloc_workqueue("events_unbound", WQ_UNBOUND,  
  8.                                             WQ_UNBOUND_MAX_ACTIVE);  
  9.     system_freezable_wq = alloc_workqueue("events_freezable",  
  10.                                               WQ_FREEZABLE, 0);  
  11.     system_power_efficient_wq = alloc_workqueue("events_power_efficient",  
  12.                                               WQ_POWER_EFFICIENT, 0);  
  13.     system_freezable_power_efficient_wq = alloc_workqueue("events_freezable_power_efficient",  
  14.                                               WQ_FREEZABLE | WQ_POWER_EFFICIENT,  
  15.                                               0);  
  16.     ... 
  17.  

此外,由于工作隊列 system_wq 被使用的頻率很高,于是內核就封裝了一個簡單的函數(schedule_work)給我們使用: 

  1. /**  
  2.  * schedule_work - put work task in global workqueue  
  3.  * @work: job to be done  
  4.  *  
  5.  * Returns %false if @work was already on the kernel-global workqueue and  
  6.  * %true otherwise.  
  7.  *  
  8.  * This puts a job in the kernel-global workqueue if it was not already  
  9.  * queued and leaves it in the same position on the kernel-global  
  10.  * workqueue otherwise. 
  11.  */  
  12. static inline bool schedule_work(struct work_struct *work){     
  13.     return queue_work(system_wq, work);  

當然了,任何事情有利就有弊!

由于內核默認創建的工作隊列,是被所有的驅動程序共享的。

如果所有的驅動程序都把等待處理的工作項委托給它們來處理,那么就會導致某個工作隊列中過于擁擠。

根據先來后到的原則,工作隊列中后加入的工作項,就可能因為前面工作項的處理函數執行的時間太長,從而導致時效性無法保證。

因此,這里存在一個系統平衡的問題。

關于工作隊列的基本知識點就介紹到這里,下面來實際操作驗證一下。

驅動程序

之前的幾篇文章,在驅動程序中測試中斷處理的操作流程都是一樣的,因此這里就不在操作流程上進行贅述了。

這里直接給出驅動程序的全貌代碼,然后查看 dmesg 的輸出信息。

創建驅動程序源文件和 Makefile: 

  1. $ cd tmp/linux-4.15/drivers  
  2. $ mkdir my_driver_interrupt_wq  
  3. $ touch my_driver_interrupt_wq.c  
  4. $ touch Makefile 

示例代碼全貌

測試場景是:加載驅動模塊之后,如果監測到鍵盤上的ESC鍵被按下,那么就往內核默認的工作隊列system_wq中增加一個工作項,然后觀察該工作項對應的處理函數是否被調用。 

  1. #include <linux/kernel.h>  
  2. #include <linux/module.h>  
  3. #include <linux/interrupt.h>  
  4. static int irq;            
  5. static char * devname;     
  6. static struct work_struct mywork;                
  7.   // 接收驅動模塊加載時傳入的參數  
  8. module_param(irq, int, 0644);  
  9. module_param(devname, charp, 0644);  
  10. // 定義驅動程序的 ID,在中斷處理函數中用來判斷是否需要處理           
  11.  #define MY_DEV_ID           1226  
  12. // 驅動程序數據結構  
  13. struct myirq  
  14.  
  15.     int devid;  
  16. };  
  17.  struct myirq mydev  ={ MY_DEV_ID };  
  18. #define KBD_DATA_REG        0x60    
  19. #define KBD_STATUS_REG      0x64  
  20. #define KBD_SCANCODE_MASK   0x7f  
  21. #define KBD_STATUS_MASK     0x80  
  22. // 工作項綁定的處理函數  
  23. static void mywork_handler(struct work_struct *work)  
  24.  
  25.     printk("mywork_handler is called. \n");  
  26.     // do some other things  
  27. }         
  28. //中斷處理函數  
  29. static irqreturn_t myirq_handler(int irq, void * dev)  
  30.  
  31.     struct myirq mydev;  
  32.     unsigned char key_code;  
  33.     mydev = *(struct myirq*)dev;       
  34.      // 檢查設備 id,只有當相等的時候才需要處理  
  35.     if (MY_DEV_ID == mydev.devid)  
  36.     {  
  37.         // 讀取鍵盤掃描碼  
  38.         key_code = inb(KBD_DATA_REG);    
  39.         if (key_code == 0x01)  
  40.         { 
  41.              printk("ESC key is pressed! \n");         
  42.              // 初始化工作項 
  43.             INIT_WORK(&mywork, mywork_handler);        
  44.              // 加入到工作隊列 system_wq  
  45.                     schedule_work(&mywork);  
  46.         }  
  47.     }     
  48.     return IRQ_HANDLED;  
  49. }   
  50. // 驅動模塊初始化函數  
  51. static int __init myirq_init(void)  
  52.  
  53.     printk("myirq_init is called. \n");  
  54.     // 注冊中斷處理函數  
  55.     if(request_irq(irq, myirq_handler, IRQF_SHARED, devname, &mydev)!=0)  
  56.     {  
  57.         printk("register irq[%d] handler failed. \n", irq);  
  58.         return -1;  
  59.     }  
  60.     printk("register irq[%d] handler success. \n", irq);  
  61.     return 0;  
  62. }   
  63. // 驅動模塊退出函數  
  64. static void __exit myirq_exit(void)  
  65.  
  66.     printk("myirq_exit is called. \n");  
  67.     // 釋放中斷處理函數  
  68.     free_irq(irq, &mydev);  
  69. }   
  70. MODULE_LICENSE("GPL");  
  71. module_init(myirq_init);  
  72. module_exit(myirq_exit); 

Makefile 文件 

  1. ifneq ($(KERNELRELEASE),)  
  2.     obj-m :my_driver_interrupt_wq.o  
  3. else  
  4.     KERNELDIR ?= /lib/modules/$(shell uname -r)/build  
  5.     PWD := $(shell pwd)  
  6. default:  
  7.     $(MAKE) -C $(KERNELDIR) M=$(PWD) modules  
  8. clean:  
  9.     $(MAKE) -C $(KERNEL_PATH) M=$(PWD) clean  
  10. endif 

編譯、測試 

  1. $ make  
  2. $ sudo insmod my_driver_interrupt_wq.ko irq=1 devname=mydev  

檢查驅動模塊是否加載成功: 

  1. $ lsmod | grep my_driver_interrupt_wq  
  2. my_driver_interrupt_wq    16384  0 

再看一下 dmesg 的輸出信息: 

  1. $ dmesg  
  2. ...  
  3. [  188.247636] myirq_init is called.   
  4. [  188.247642] register irq[1] handler success. 

說明:驅動程序的初始化函數 myirq_init 被調用了,并且成功注冊了 1 號中斷的處理程序。

此時,按一下鍵盤上的 ESC 鍵。

操作系統在捕獲到鍵盤中斷之后,會依次調用此中斷的所有中斷處理程序,其中就包括我們注冊的 myirq_handler 函數。

在這個函數中,當判斷出是ESC按鍵時,就初始化一個工作項(把結構體 work_struct 類型的變量與一個處理函數綁定起來),然后丟給操作系統預先創建好的工作隊列(system_wq)去處理,如下所示: 

  1. if (key_code == 0x01)  
  2.  
  3.     printk("ESC key is pressed! \n");  
  4.     INIT_WORK(&mywork, mywork_handler);  
  5.     schedule_work(&mywork);  

因此,當相應的內核線程從這個工作隊列(system_wq)中取出工作項(mywork)來處理的時候,函數 mywork_handler 就會被調用。

現在來看一下 dmesg 的輸出信息: 

  1. [  305.053155] ESC key is pressed!   
  2. [  305.053177] mywork_handler is called. 

可以看到:mywork_handler函數被正確調用了。

完美! 

 

責任編輯:龐桂玉 來源: 良許Linux
相關推薦

2021-12-27 07:55:59

Linux 中斷處理Linux 系統

2015-03-27 13:04:20

Beanstalkd工

2011-06-20 06:14:15

ibmdwLinux

2015-11-12 10:03:34

前端H5web

2021-11-10 12:13:02

HostonlyCookie瀏覽器

2020-09-27 06:53:57

MavenCDNwrapper

2017-04-03 15:35:13

知識體系架構

2015-03-17 10:13:52

HTML5什么鬼

2021-07-06 10:17:07

Python LaunLinuxWindows

2019-10-30 10:13:15

區塊鏈技術支付寶

2020-11-04 13:01:38

FastThreadLocalJDK

2015-09-29 09:47:14

2019-01-07 12:40:19

2015-09-22 09:25:16

RTORPO災備技術

2021-01-07 05:22:47

MySQL字段存儲

2022-09-07 08:41:57

SpringIstio分布式

2021-08-10 12:05:19

Linuxworkqueue內核

2018-01-16 08:47:23

2015-07-16 10:49:31

虛擬化容器技術

2019-01-17 14:35:01

點贊
收藏

51CTO技術棧公眾號

激情欧美一区| av电影在线观看| 在线日韩电影| 亚洲一区av在线播放| 91制片厂毛片| 自由的xxxx在线视频| av资源站一区| 国产精品视频自拍| 中文字幕第28页| 欧美性感美女一区二区| 欧美一级一区二区| www国产黄色| 黄a在线观看| 91亚洲精品乱码久久久久久蜜桃| 国产免费一区二区三区在线观看| 国产第一页浮力| 亚洲第一论坛sis| 欧美一区二区在线看| www.爱色av.com| av激情在线| 国产欧美一区二区三区在线看蜜臀 | 国产成人在线视频| 欧美激情国产精品免费| 成人影院在线| 日韩精品免费在线视频| 涩多多在线观看| 黄色亚洲网站| 亚洲一区二区精品久久av| 日韩精彩视频| 日本激情一区二区| 国产美女精品人人做人人爽| 日韩美女视频免费在线观看| 国产乡下妇女做爰| 91精品啪在线观看国产18| 亚洲天堂开心观看| 久久久久9999| 精品视频成人| 3d动漫精品啪啪一区二区竹菊| aaa毛片在线观看| 888av在线视频| 亚洲激情男女视频| 午夜探花在线观看| 亚洲欧美视频一区二区| 久久精品一区二区三区av| 精品欧美一区二区三区久久久| 国产熟女一区二区三区五月婷| 日本成人在线电影网| 日本午夜精品理论片a级appf发布| 国产精品suv一区二区| 欧美freesex交免费视频| 精品国产一区二区三区久久| 四虎国产成人精品免费一女五男| 国产剧情一区| 亚洲一区二区久久久| 午夜理伦三级做爰电影| 伊人久久大香线蕉无限次| 日韩精品在线观看一区| 亚洲精品女人久久久| 亚洲素人在线| 亚洲深夜福利在线| 久久久视频6r| jlzzjlzz亚洲女人| 色噜噜狠狠狠综合曰曰曰88av| 免费视频91蜜桃| 精品一区不卡| 色琪琪综合男人的天堂aⅴ视频| 亚洲图片第一页| 99久久www免费| 免费av在线一区| 欧美成人三级视频| 亚洲国产婷婷| 秋霞午夜一区二区| 亚洲精品久久久久久久蜜桃| 日本特黄久久久高潮| 国产精品视频久久| 国产免费一区二区三区免费视频| 国产经典欧美精品| 狠狠色噜噜狠狠狠狠色吗综合| 亚洲欧美综合在线观看| 国产欧美日韩一区二区三区在线观看| 日韩在线电影一区| 爆操欧美美女| 婷婷综合另类小说色区| 成年人黄色片视频| 精品国产乱码一区二区三区| 精品国产一区二区三区久久久蜜月 | 91在线精品一区二区| 欧美日韩在线观看一区| 午夜激情在线观看| 亚洲一二三四在线| 三级4级全黄60分钟| 国产激情一区| 日韩电影视频免费| 成人18视频免费69| 99国产精品久久久久久久| 国产精品亚洲精品| 后进极品白嫩翘臀在线视频| 久久九九99视频| 特级西西444| 韩日精品一区二区| 欧美一区二区三区视频| caopeng视频| 欧美三级第一页| 国产福利精品av综合导导航| 国产高清免费在线观看| 久久久国产一区二区三区四区小说 | 永久免费av片在线观看全网站| 亚洲综合色成人| 男人女人黄一级| www.国产精品一区| 久久精品国产亚洲精品| 六月丁香激情综合| 国产精品一区二区三区乱码| 日韩av不卡播放| 黑人精品视频| 91精品久久久久久久91蜜桃| 欧美 变态 另类 人妖| 伊人成综合网| 国产精品精品久久久| 天堂av在线资源| 亚洲精品福利视频网站| a在线观看免费视频| 亚洲aaa级| 欧美精品激情在线观看| 国产在成人精品线拍偷自揄拍| 91亚洲精华国产精华精华液| 国产欧美123| 午夜不卡一区| 在线电影av不卡网址| 在线观看黄网站| 高潮精品一区videoshd| 潘金莲一级淫片aaaaa免费看| 另类专区亚洲| 精品香蕉在线观看视频一| 久久国产精品波多野结衣av| 国模大尺度一区二区三区| 亚洲三区在线观看| 精品欧美日韩精品| 尤物九九久久国产精品的特点| 四虎精品永久在线| 91影院在线免费观看| 免费观看美女裸体网站| 91精品国产自产精品男人的天堂| 久久精品亚洲一区| 国产一区二区三区视频免费观看| 国产欧美日韩在线视频| 一区二区在线播放视频| 欧美人与牛zoz0性行为| 日本在线精品视频| 国产在线网站| 欧美综合一区二区| 男人的天堂av网| 另类的小说在线视频另类成人小视频在线| 欧美日韩国产三区| 性欧美freehd18| 在线不卡国产精品| 97人妻精品一区二区三区视频| 综合精品久久久| 日本一区二区三区在线免费观看| 亚洲精品97| 成人av免费在线看| 老色鬼在线视频| 亚洲精品在线看| 久久影视中文字幕| 亚洲欧洲另类国产综合| 亚洲欧美日韩中文字幕在线观看| 国产精品扒开腿做爽爽爽软件| 成人在线看片| 深夜av在线| 中文字幕欧美专区| 国产日韩免费视频| 亚洲图片有声小说| 亚欧洲乱码视频| 激情综合网激情| 免费视频爱爱太爽了| 日韩高清成人在线| 国产精品情侣自拍| 亚洲91av| 亚洲欧美激情在线视频| 在线免费看91| 亚洲第一久久影院| 亚洲天堂岛国片| 国产在线播放一区| 免费成人午夜视频| 成人动漫免费在线观看| 91精品国产高清久久久久久91裸体 | 日本波多野结衣在线| 在线亚洲欧美专区二区| 麻豆天美蜜桃91| 91天堂素人约啪| 亚洲这里只有精品| 亚洲第一毛片| 亚洲午夜精品国产| 国产香蕉精品| 国产日产欧美a一级在线| 欧美xxxx免费虐| 一区二区三区视频免费| 亚洲AV无码精品色毛片浪潮| 91九色最新地址| 妺妺窝人体色www婷婷| 国产三级一区二区| 丰满少妇xbxb毛片日本| 美女视频黄 久久| 免费 成 人 黄 色| 一本一本久久a久久综合精品| 久久综合九色综合网站| 永久免费观看精品视频| 日本一区二区不卡| 青草影视电视剧免费播放在线观看| 亚洲性夜色噜噜噜7777| 成人精品在线播放| 7777精品伊人久久久大香线蕉完整版| 久热这里只有精品6| 亚洲视频免费在线观看| 欧美偷拍一区二区三区| 成人午夜视频在线| 美女被艹视频网站| 久久99久国产精品黄毛片色诱| 99爱视频在线| 国产精品啊啊啊| 免费成人深夜夜行网站视频| 精品国产一区二区三区av片| 国产在线一区二| 亚洲网一区二区三区| 成人黄色av免费在线观看| 欧美××××黑人××性爽| 91chinesevideo永久地址| 羞羞视频在线观看免费| 操91在线视频| 蜜桃视频在线观看www社区| 亚洲人成电影在线| 日韩一级在线播放| 精品美女一区二区| 亚洲国产精品一| 日韩片之四级片| 国产肥老妇视频| 日韩一二三四区| jizz中国女人| 精品美女一区二区| 日本精品一二区| 亚洲国内精品视频| 天天操天天射天天舔| 亚洲精品一线二线三线| 二区三区在线视频| 欧美大片国产精品| 亚洲国产成人一区二区| 日韩欧美国产1| 亚洲精品久久久久久无码色欲四季 | 国产精品探花视频| 91 com成人网| www.污视频| 欧美精品一区二区三区在线| 人妻一区二区三区四区| 亚洲第一天堂av| 天天干天天操av| 日韩福利在线播放| 九色视频在线观看免费播放| 亚洲一区二区国产| av女优在线| 久久久国产成人精品| 直接在线观看的三级网址| 欧美超级免费视 在线| 人人澡人人添人人爽一区二区| 久久久久久久国产精品| 日韩精品极品| 国产成人精品日本亚洲专区61 | 亚洲淫片在线视频| 日韩三级精品| 精品视频一区二区三区四区| 中文字幕av一区二区三区人| 一本一本a久久| 欧美高清不卡| 黄色影院一级片| 奇米在线7777在线精品| 亚洲图片 自拍偷拍| 99久久免费国产| 国产人妻大战黑人20p| ...中文天堂在线一区| 久久在线视频精品| 日本高清不卡视频| 99国产精品久久久久久久成人 | 欧美午夜精品在线| 中文字幕一区二区三区波野结| 欧美日韩中文字幕一区| 亚洲精品福利网站| 亚洲天堂视频在线观看| 超碰在线最新| 欧美一级在线播放| www.成人在线.com| 老牛影视免费一区二区| 五月天久久久| 欧美牲交a欧美牲交| 麻豆91在线观看| 国产一卡二卡三卡四卡| 欧美激情中文字幕| 久久精品久久国产| 欧美日韩久久一区二区| 偷拍精品一区二区三区| www.精品av.com| www.日韩| 国产v亚洲v天堂无码| 水蜜桃久久夜色精品一区| 成人免费毛片在线观看| 麻豆一区二区三| 青青草成人免费视频| 亚洲日本电影在线| 伊人久久中文字幕| 精品国产91洋老外米糕| 9i精品一二三区| 欧美亚洲视频一区二区| 久久伦理中文字幕| 午夜精品福利一区二区| av不卡在线看| 国产精品日日摸夜夜爽| 中文字幕在线一区二区三区| 无码aⅴ精品一区二区三区| 精品国产亚洲在线| 国产色在线观看| 国产精品久久电影观看| 美日韩中文字幕| 国产一区二区三区小说| 国产综合成人久久大片91| 亚洲午夜久久久久久久国产| 富二代精品短视频| 日本韩国免费观看| 欧美激情中文字幕乱码免费| 亚洲国产伊人| 亚洲精品9999| 爽好多水快深点欧美视频| 性欧美丰满熟妇xxxx性久久久| 亚洲一区二区在线免费看| 国产精品美女一区| 色99之美女主播在线视频| 成人午夜毛片| 日韩欧美精品一区二区| 久久九九免费| 公侵犯人妻一区二区三区| 精品国产精品自拍| 天天射天天操天天干| 97视频在线观看免费| 精品欠久久久中文字幕加勒比| 国产91在线亚洲| 国产成人亚洲综合a∨婷婷图片| 国产成人av免费在线观看| 欧美精品v日韩精品v韩国精品v| av资源网站在线观看| 国产精品都在这里| 欧美中文字幕一区二区| 天天爽天天爽夜夜爽| 日本一区二区三区在线观看| www毛片com| 一区二区三区天堂av| 日韩漫画puputoon| 制服国产精品| 国产精品一品视频| 免费在线一区二区三区| 亚洲国产女人aaa毛片在线| 涩涩涩视频在线观看| 欧美色图亚洲自拍| 日韩二区在线观看| 国产人与禽zoz0性伦| 欧美一区二视频| gratisvideos另类灌满| 鲁片一区二区三区| 蜜臀av一区二区在线免费观看| 免费黄色国产视频| 日韩片之四级片| 中文在线中文资源| 香蕉久久免费影视| 国产精品一区二区三区乱码| 日韩特黄一级片| 国产亚洲精品久久久久久| 色噜噜成人av在线| 国产91沈先生在线播放| av在线播放不卡| 涩涩视频在线观看| 欧美成人精品一区二区| 欧美a级网站| 亚洲国产精品三区| 夜色激情一区二区| 五月激情婷婷网| 国产精品一区二区三| 欧美99在线视频观看| www.色天使| 777久久久精品| 一个人www视频在线免费观看| 亚洲日本一区二区三区在线不卡| 国产不卡在线播放| 波多野结衣绝顶大高潮| 欧美老少配视频| 久久综合欧美| 一级片免费在线观看视频| 欧美性xxxx18| 黄在线免费看| 欧美精品二区三区四区免费看视频 | 久久精品一卡二卡| 色综合久久久久综合| 污视频在线免费观看网站| 亚洲国产激情一区二区三区| 东方aⅴ免费观看久久av|