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

Linux驅動實踐:中斷處理中的【工作隊列】 Workqueue 是什么鬼?

系統 Linux
工作隊列是Linux操作系統中,進行中斷下半部分處理的重要方式!從名稱上可以猜到:一個工作隊列就好像業務層常用的消息隊列一樣,里面存放著很多的工作項等待著被處理。

[[442152]]

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

大家好,我是道哥,今天我為大伙兒解說的技術知識點是:【中斷處理中的下半部分機制-工作隊列】。

在剛開始介紹中斷處理的時候,曾經貼出下面這張圖:

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

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

也正因為此,它們之間的使用方式幾乎是大同小異,至少是在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.  
  30. extern struct workqueue_struct *system_wq; 
  31. extern struct workqueue_struct *system_highpri_wq; 
  32. extern struct workqueue_struct *system_long_wq; 
  33. extern struct workqueue_struct *system_unbound_wq; 
  34. extern struct workqueue_struct *system_freezable_wq; 
  35. extern struct workqueue_struct *system_power_efficient_wq; 
  36. extern struct workqueue_struct *system_freezable_power_efficient_wq; 

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

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

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

ntk("myirq_exit is called. \n"); // 釋放中斷處理函數 free_irq(irq, &mydev);} MODULE_LICENSE("GPL");module_init(myirq_init);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.     printk("ESC key is pressed! \n"); 
  3.     INIT_WORK(&mywork, mywork_handler); 
  4.     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函數被正確調用了。

完美!

本文轉載自微信公眾號「IOT物聯網小鎮」

【編輯推薦】

 

責任編輯:姜華 來源: IOT物聯網小鎮
相關推薦

2022-01-12 12:35:36

Linuxworkqueue工作隊列

2021-08-10 12:05:19

Linuxworkqueue內核

2011-06-20 06:14:15

ibmdwLinux

2015-03-27 13:04:20

Beanstalkd工

2015-11-12 10:03:34

前端H5web

2021-12-20 07:51:16

Linux函數應用層

2021-11-10 12:13:02

HostonlyCookie瀏覽器

2021-09-03 09:12:09

Linux中斷軟件

2020-09-27 06:53:57

MavenCDNwrapper

2017-04-03 15:35:13

知識體系架構

2023-05-18 22:51:08

2020-11-04 13:01:38

FastThreadLocalJDK

2021-08-10 11:30:30

Linux代碼中斷控制器

2021-08-03 15:10:26

Linux代碼驅動

2021-01-07 05:22:47

MySQL字段存儲

2015-03-17 10:13:52

HTML5什么鬼

2021-07-06 10:17:07

Python LaunLinuxWindows

2019-10-30 10:13:15

區塊鏈技術支付寶

2019-04-28 10:30:30

Linux操作系統Namespace

2023-03-02 08:48:43

Linuxsubshell
點贊
收藏

51CTO技術棧公眾號

九九热线视频只有这里最精品| 久久精品视频7| 国产日韩中文在线中文字幕| 一区二区三区在线影院| 国产精品人成电影| 在线看的片片片免费| 久久影视三级福利片| 91久久免费观看| 午夜啪啪福利视频| 性猛交xxxx| 久久99国内精品| 国内揄拍国内精品少妇国语| 日本人亚洲人jjzzjjz| 香蕉成人av| 亚洲精品伦理在线| 欧美久久久久久久| 国产激情久久久久久熟女老人av| 97欧美在线视频| 欧美电视剧在线看免费| 虎白女粉嫩尤物福利视频| 欧美猛烈性xbxbxbxb| 成人avav影音| 欧美性受xxxx白人性爽| 日韩国产第一页| 香蕉视频一区二区三区| 欧美一级欧美一级在线播放| 小泽玛利亚av在线| 国产1区2区3区在线| 蜜臀va亚洲va欧美va天堂 | 国产福利一区二区三区视频| 7777kkkk成人观看| 国产精品 欧美激情| 国产调教一区二区三区| 亚洲电影在线观看| 亚洲国产日韩在线一区| 国产精品原创视频| 色伊人久久综合中文字幕| 真人抽搐一进一出视频| 精品孕妇一区二区三区| 成人夜色视频网站在线观看| 国产欧美日韩亚洲精品| 亚洲午夜18毛片在线看| 在线不卡亚洲| 欧美老女人在线视频| av电影在线不卡| 丝袜连裤袜欧美激情日韩| 精品久久国产字幕高潮| 国产精品欧美激情在线观看| 无遮挡动作视频在线观看免费入口| 国产一区 二区 三区一级| 日韩av片免费在线观看| 西西44rtwww国产精品| 日韩国产一区| 亚洲最新在线视频| 免费污网站在线观看| 日韩理论电影中文字幕| 欧美日本高清视频在线观看| 亚洲视频在线a| 久久野战av| 91黄色在线观看| 成人在线看视频| 蜜桃精品在线| 欧美日韩综合不卡| 久久国产激情视频| 日本欧美在线| 91精品黄色片免费大全| 日本美女久久久| 99精品女人在线观看免费视频| 性久久久久久久| 九九爱精品视频| а√天堂资源官网在线资源| 欧美日韩国产在线看| 亚洲最新免费视频| 日本福利午夜视频在线| 97se亚洲国产综合自在线| 国产精品麻豆va在线播放| 青青艹在线观看| 日韩av在线播放中文字幕| 国产欧美日韩免费| 欧美特黄aaaaaa| 黄色成人av网站| 9.1国产丝袜在线观看| 岛国av中文字幕| 美女视频第一区二区三区免费观看网站 | 国产精品天天看| 亚洲日本无吗高清不卡| 黄网站app在线观看| 一区二区三区精品视频在线| www婷婷av久久久影片| 成人黄色动漫| 欧美综合久久久| 1314成人网| 香蕉久久精品日日躁夜夜躁| 亚洲精品久久久久久下一站| 人妻大战黑人白浆狂泄| 日韩激情免费| 欧美精品久久久久a| 欧美成人综合色| 噜噜噜躁狠狠躁狠狠精品视频| 亚州欧美日韩中文视频| 国产第一页在线观看| 韩国成人在线视频| 成人有码视频在线播放| 日本精品久久久久| 国产精品午夜免费| 日韩成人手机在线| 国产成人精品一区二区三区在线| 色嗨嗨av一区二区三区| 亚洲图片 自拍偷拍| 偷拍视屏一区| 欧美超级乱淫片喷水| 亚洲免费在线视频观看| 国产精品自拍三区| 色狠狠久久av五月综合| 成年人国产在线观看| 欧美丝袜第三区| 精品国产一区在线| 亚洲人体av| 国产精品夫妻激情| 天天操天天干天天操| 亚洲色图制服诱惑| 日本中文字幕高清| 亚洲涩涩av| 亚洲欧美综合v| 久久久久免费看| 99香蕉国产精品偷在线观看 | 91精品国产麻豆国产自产在线| 色婷婷激情视频| 亚洲图片久久| 欧美激情一二三| 国产农村妇女毛片精品久久| 欧美激情中文不卡| 国产精品无码av在线播放| 欧美日韩国产一区二区在线观看| 亚洲的天堂在线中文字幕| 国精产品久拍自产在线网站| 久久一区二区三区四区五区 | 亚洲黄色免费av| 日韩精品一区二区三区三区免费 | 国产欧美精品国产国产专区 | 999在线观看| 蜜臀久久99精品久久一区二区| 日韩视频中文字幕| 午夜一区二区三区四区| 久久在线免费观看| 丰满爆乳一区二区三区| 欧美日韩一区二区三区四区不卡 | 亲子乱一区二区三区电影| 亚洲第一天堂网| 亚洲精品视频在线观看网站| www午夜视频| 日韩欧美国产精品综合嫩v| 国产成人综合精品| 精品人妻aV中文字幕乱码色欲| 99久久综合99久久综合网站| 亚洲精蜜桃久在线| 97人人做人人爽香蕉精品| 日韩欧美国产麻豆| 激情综合网五月天| 成人免费视频播放| 亚洲一区二区三区欧美| av影院在线免费观看| 欧美成va人片在线观看| 久久精品99久久久久久| av在线不卡网| 色哺乳xxxxhd奶水米仓惠香| 欧美理论影院| 在线视频免费一区二区| 一级特黄aaaaaa大片| 亚洲欧美在线高清| 色哟哟在线观看视频| 欧美午夜久久| 亚洲iv一区二区三区| 午夜成人免费影院| 色就色 综合激情| 北条麻妃在线观看视频| 国产黄色成人av| 欧美三级在线观看视频| 奇米狠狠一区二区三区| 26uuu久久噜噜噜噜| 国产高清视频免费观看| 亚洲一区二区三区小说| 亚洲成人av免费在线观看| 视频一区在线播放| 熟妇熟女乱妇乱女网站| 老司机精品视频在线播放| 国产va免费精品高清在线| 天天综合在线视频| 亚洲一区二区欧美日韩| 少妇毛片一区二区三区| 久久精品二区亚洲w码| 亚洲成人第一| 日韩一区二区三区高清在线观看| 久久精品久久久久久| 亚洲精品911| 亚洲蜜臀av乱码久久精品蜜桃| 中文字幕亚洲乱码| 国内一区二区三区| 亚洲已满18点击进入在线看片 | 久久久精品久久久久| 亚洲精品一区二区三区区别| 一区二区成人在线观看| 蜜臀久久99精品久久久久久| 国产福利91精品一区| 国产a级片免费观看| 韩日一区二区三区| 99久久精品免费看国产四区| 性欧美gay| 欧美激情影音先锋| 97超碰人人在线| 亚洲精品国产精品久久清纯直播| 黄色片视频网站| 综合久久久久综合| aaaaa级少妇高潮大片免费看| 久久人人97超碰国产公开结果| 欧美日本韩国在线| 北条麻妃在线一区二区免费播放 | **在线精品| 欧美福利小视频| 欧美日韩xx| 一本色道久久综合狠狠躁篇的优点| 怡红院成永久免费人全部视频| 国产精品福利一区二区三区| 国产九九九视频| 男人的天堂亚洲一区| 日本a级片免费观看| 欧美午夜免费影院| 黄色高清视频网站| 成人中文视频| 日本不卡二区高清三区| 日韩成人av在线资源| 97免费资源站| 亚洲国产精品免费视频| 国产在线精品播放| av成人亚洲| 国产精品国产三级国产专播精品人 | 久久成人免费网站| 99视频精品免费| 羞羞答答国产精品www一本| 欧美日韩不卡在线视频| 亚洲精品a级片| 久久99国产精品99久久| xxxx日韩| 国产精品乱码视频| 色天使综合视频| 国产成人97精品免费看片| gogo在线高清视频| 久久天天躁狠狠躁夜夜躁2014| 国精品人妻无码一区二区三区喝尿| 色综合天天在线| 中文字幕第15页| 黑人巨大精品欧美一区二区一视频 | 亚洲国产精品免费| 黄频在线免费观看| 精品久久久久久久久久久久久久久久久 | 国产精品欧美一区二区三区奶水 | 九色精品91| 日本精品二区| 禁断一区二区三区在线| 午夜免费电影一区在线观看| 欧美1级片网站| 大地资源第二页在线观看高清版| 首页亚洲中字| 日韩免费电影一区二区三区| 日韩激情一区| 9l视频自拍9l视频自拍| 欧美激情视频一区二区三区在线播放 | 在线播放国产一区| 欧美精品777| 精品人妻无码一区二区| 欧美日韩一区二区在线观看 | 欧美图区在线视频| 国产成人在线视频观看| 在线中文字幕不卡| 97超视频在线观看| 精品日韩99亚洲| 国产三级第一页| 精品国产乱码久久久久久闺蜜| 国产精品永久久久久久久久久| 色先锋aa成人| 亚洲影院一区二区三区| 精品剧情在线观看| 国产99999| 亚洲精品黄网在线观看| 欧美亚洲日本| 中文字幕av一区二区| 国产视频福利在线| 美女性感视频久久久 | 亚洲人成五月天| 天堂а√在线8种子蜜桃视频| 欧美成人高清电影在线| 四虎影视在线播放| 久久九九精品99国产精品| 看黄在线观看| 成人免费激情视频| 亚洲精华一区二区三区| 久久婷婷国产综合尤物精品| 欧美韩国日本在线观看| 成年人网站国产| 久久国产综合精品| 手机av在线免费| 奇米精品一区二区三区在线观看一 | 人妻丰满熟妇aⅴ无码| 国产精品不卡一区二区三区| 中文在线观看免费网站| 欧美视频一区在线| 在线亚洲欧美日韩| 亚洲大胆人体视频| 成人片在线看| 国产精品久久91| 激情亚洲另类图片区小说区| 亚洲欧洲精品一区二区| 亚洲影院免费| aaa黄色大片| 国产精品无遮挡| 91视频免费网址| 欧美成人猛片aaaaaaa| 午夜小视频在线| 日韩美女视频免费在线观看| h视频久久久| 最近中文字幕免费mv| 日韩和的一区二区| 国产乱了高清露脸对白| 洋洋成人永久网站入口| 久久国产视频播放| 日韩精品一区二区三区swag| 蜜芽在线免费观看| 国产精品久久久久久久久久东京| 日韩免费在线电影| 欧美日韩亚洲在线| 在线亚洲欧美| 伦伦影院午夜理论片| 国产精品女主播av| 中文字幕第2页| 国产午夜精品美女视频明星a级| 日本暖暖在线视频| 国产精品日韩电影| 欧美日韩国产高清电影| 免费午夜视频在线观看| 99r精品视频| 在线观看亚洲欧美| 欧美一区二区女人| 日韩欧美在线番号| 1769国产精品| 老司机精品视频在线播放| 精品少妇人妻av免费久久洗澡| 欧美aaaaaa午夜精品| 天天操天天干天天操天天干| 色www精品视频在线观看| 免费av在线电影| 国产v综合v亚洲欧美久久| 精品国产欧美日韩| 国产av人人夜夜澡人人爽| 国产视频一区二区三区在线观看| 精品无码av在线| 精品电影一区二区三区| av电影院在线看| 久久久亚洲综合网站| 久久久久国产精品午夜一区| 人妻少妇无码精品视频区| 日本高清免费不卡视频| 成人精品一区二区三区校园激情| 国产69精品久久久久99| 日韩黄色三级在线观看| 久久国产精品免费观看| 免费高清在线一区| 亚洲熟女乱综合一区二区三区 | 精品少妇爆乳无码av无码专区| 欧美日韩一区二区三区不卡 | 在线视频中文亚洲| 亚洲天堂网站| 少妇久久久久久被弄到高潮| 麻豆国产精品官网| caoporn91| 亚洲缚视频在线观看| 黑人巨大精品| 精品国产二区在线| 三级欧美韩日大片在线看| 激情五月激情综合| 精品美女一区二区三区| 亚洲黄色中文字幕| 久久久精品动漫| 轻轻草成人在线| 欧美日韩偷拍视频| 国产视频自拍一区| 日韩成人免费av| 97超碰在线人人| 亚洲国产精品成人综合 | 色综合久久天天| 日本高清在线观看wwwww色| 岛国视频一区| 日日夜夜一区二区| 久久久久无码国产精品不卡| 亚洲欧美日本另类| 日韩精品美女| 正在播放国产精品| 99国产精品久| 亚洲网站免费观看| 97精品在线视频| 久久九九热re6这里有精品|