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

Linux 中斷子系統的驅動解析

系統 Linux
這里主要分析 linux kernel 中 GIC v3 中斷控制器的代碼(drivers/irqchip/irq-gic-v3.c)。

[[416559]]

 GIC 驅動

這里主要分析 linux kernel 中 GIC v3 中斷控制器的代碼(drivers/irqchip/irq-gic-v3.c)。

設備樹

先來看下一個中斷控制器的設備樹信息: 

  1. gic: interrupt-controller@51a00000 {  
  2.         compatible = "arm,gic-v3" 
  3.         reg = <0x0 0x51a00000 0 0x10000>, /* GIC Dist */  
  4.               <0x0 0x51b00000 0 0xC0000>, /* GICR */  
  5.               <0x0 0x52000000 0 0x2000>,  /* GICC */  
  6.               <0x0 0x52010000 0 0x1000>,  /* GICH */  
  7.               <0x0 0x52020000 0 0x20000>; /* GICV */  
  8.         #interrupt-cells = <3> 
  9.         interrupt-controller;  
  10.         interrupts = <GIC_PPI 9  
  11.                 (GIC_CPU_MASK_SIMPLE(6) | IRQ_TYPE_LEVEL_HIGH)> 
  12.         interrupt-parent = <&gic> 
  13. }; 
  •  compatible:用于匹配GICv3驅動
  •  reg :GIC的物理基地址,分別對應GICD,GICR,GICC…
  •  #interrupt-cells:這是一個中斷控制器節點的屬性。它聲明了該中斷控制器的中斷指示符(interrupts)中 cell 的個數
  •  interrupt-controller: 表示該節點是一個中斷控制器
  •  interrupts:分別代表中斷類型,中斷號,中斷類型, PPI中斷親和, 保留字段

關于設備數的各個字段含義,詳細可以參考 Documentation/devicetree/bindings 下的對應信息。

初始化

1. irq chip driver 的聲明:

  1. IRQCHIP_DECLARE(gic_v3, "arm,gic-v3", gic_of_init); 

定義 IRQCHIP_DECLARE 之后,相應的內容會保存到 __irqchip_of_table 里邊: 

  1. #define IRQCHIP_DECLARE(name, compat, fn) OF_DECLARE_2(irqchip, name, compat, fn)  
  2. #define OF_DECLARE_2(table, name, compat, fn) \   
  3.         _OF_DECLARE(table, name, compat, fn, of_init_fn_2)  
  4. #define _OF_DECLARE(table, name, compat, fn, fn_type)            \   
  5.     static const struct of_device_id __of_table_##name        \   
  6.         __used __section(__##table##_of_table)            \   
  7.          = { .compatible = compat,                \   
  8.              .data = (fn == (fn_type)NULL) ? fn : fn  } 

__irqchip_of_table 在鏈接腳本 vmlinux.lds 里,被放到了 __irqchip_begin 和 __irqchip_of_end 之間,該段用于存放中斷控制器信息: 

  1. #ifdef CONFIG_IRQCHIP  
  2.     #define IRQCHIP_OF_MATCH_TABLE()                    \  
  3.         . = ALIGN(8);                           \  
  4.         VMLINUX_SYMBOL(__irqchip_begin) = .;                \  
  5.         *(__irqchip_of_table)                       \  
  6.         *(__irqchip_of_end)  
  7. #endif 

在內核啟動初始化中斷的函數中,of_irq_init 函數會去查找設備節點信息,該函數的傳入參數就是 __irqchip_of_table 段,由于 IRQCHIP_DECLARE 已經將信息填充好了,of_irq_init 函數會根據 “arm,gic-v3” 去查找對應的設備節點,并獲取設備的信息。or_irq_init 函數中,最終會回調 IRQCHIP_DECLARE 聲明的回調函數,也就是 gic_of_init,而這個函數就是 GIC 驅動的初始化入口。

2. gic_of_init 流程: 

  1. static int __init gic_of_init(struct device_node *node, struct device_node *parent)  
  2.  
  3.   ......  
  4.  dist_base = of_iomap(node, 0);                                           ------(1)  
  5.  if (!dist_base) {  
  6.   pr_err("%pOF: unable to map gic dist registers\n", node);  
  7.   return -ENXIO; 
  8.  }  
  9.  err = gic_validate_dist_version(dist_base);                              ------(2)  
  10.  if (err) {  
  11.   pr_err("%pOF: no distributor detected, giving up\n", node);  
  12.   goto out_unmap_dist;  
  13.  }  
  14.  if (of_property_read_u32(node, "#redistributor-regions", &nr_redist_regions))  ------(3)  
  15.   nr_redist_regions = 1 
  16.  rdist_regs = kzalloc(sizeof(*rdist_regs) * nr_redist_regions, GFP_KERNEL);  
  17.  if (!rdist_regs) {  
  18.   err = -ENOMEM;  
  19.   goto out_unmap_dist;  
  20.  }  
  21.  for (i = 0; i < nr_redist_regions; i++) {                                ------(4)  
  22.   struct resource res;  
  23.   int ret;  
  24.   ret = of_address_to_resource(node, 1 + i, &res);  
  25.   rdist_regs[i].redist_base = of_iomap(node, 1 + i);  
  26.   if (ret || !rdist_regs[i].redist_base) {  
  27.    pr_err("%pOF: couldn't map region %d\n", node, i);  
  28.    err = -ENODEV;  
  29.    goto out_unmap_rdist;  
  30.   }  
  31.   rdist_regs[i].phys_base = res.start;  
  32.  }  
  33.  if (of_property_read_u64(node, "redistributor-stride", &redist_stride))  ------(5)  
  34.   redist_stride = 0 
  35.  err = gic_init_bases(dist_base, rdist_regs, nr_redist_regions,           ------(6)  
  36.         redist_stride, &node->fwnode);  
  37.  if (err)  
  38.   goto out_unmap_rdist;  
  39.  gic_populate_ppi_partitions(node);                                       ------(7)  
  40.  gic_of_setup_kvm_info(node);  
  41.  return 0;  
  42.   ......  
  43.  return err;  
  1.  映射 GICD 的寄存器地址空間。
  2.  驗證 GICD 的版本是 GICv3 還是 GICv4(主要通過讀GICD_PIDR2寄存器bit[7:4]. 0x1代表GICv1, 0x2代表GICv2…以此類推)。
  3.  通過 DTS 讀取 redistributor-regions 的值。
  4.  為一個 GICR 域分配基地址。
  5.  通過 DTS 讀取 redistributor-stride 的值。
  6.  下面詳細介紹。
  7.  設置一組 PPI 的親和性。 
  1. static int __init gic_init_bases(void __iomem *dist_base,  
  2.      struct redist_region *rdist_regs,  
  3.      u32 nr_redist_regions,  
  4.      u64 redist_stride,  
  5.      struct fwnode_handle *handle)  
  6.  
  7.   ......  
  8.  typer = readl_relaxed(gic_data.dist_base + GICD_TYPER);                ------(1)  
  9.  gic_data.rdists.id_bits = GICD_TYPER_ID_BITS(typer);  
  10.  gic_irqs = GICD_TYPER_IRQS(typer);  
  11.  if (gic_irqs > 1020)  
  12.   gic_irqs = 1020 
  13.  gic_data.irq_nr = gic_irqs 
  14.  gic_data.domain = irq_domain_create_tree(handle, &gic_irq_domain_ops,  ------(2)  
  15.        &gic_data);  
  16.  gic_data.rdists.rdist = alloc_percpu(typeof(*gic_data.rdists.rdist));  
  17.  gic_data.rdists.has_vlpis = true 
  18.  gic_data.rdists.has_direct_lpi = true 
  19.   ......  
  20.  set_handle_irq(gic_handle_irq);                                        ------(3) 
  21.  gic_update_vlpi_properties();                                          ------(4)  
  22.  if (IS_ENABLED(CONFIG_ARM_GIC_V3_ITS) && gic_dist_supports_lpis())  
  23.   its_init(handle, &gic_data.rdists, gic_data.domain);                  ------(5)  
  24.  gic_smp_init();                                                        ------(6)  
  25.  gic_dist_init();                                                       ------(7)  
  26.  gic_cpu_init();                                                        ------(8)  
  27.  gic_cpu_pm_init();                                                     ------(9)  
  28.  return 0;  
  29.   ......  
  1.  確認支持 SPI 中斷號最大的值為多少。
  2.  向系統中注冊一個 irq domain 的數據結構,irq_domain 主要作用是將硬件中斷號映射到 irq number,后面會做詳細的介紹。
  3.  設定 arch 相關的 irq handler。gic_irq_handle 是內核 gic 中斷處理的入口函數,后面會做詳細的介紹。
  4.  gic 虛擬化相關的內容。
  5.  初始化 ITS。
  6.  設置 SMP 核間交互的回調函數,用于 IPI,回到函數為 gic_raise_softir。
  7.  初始化 Distributor。
  8.  初始化 CPU interface。
  9.  初始化 GIC 電源管理。

中斷的映射

當早期的系統只存在一個中斷控制器,而且中斷數目也不多的時候,一個很簡單的做法就是一個中斷號對應到中斷控制器的一個號,可以說是簡單的線性映射:

但當一個系統中有多個中斷控制器,而且中斷號也逐漸增加的時候。linux 內核為了應對此問題,引入了 irq_domain 的概念。

irq_domain 的引入相當于一個中斷控制器就是一個 irq_domain。這樣一來所有的中斷控制器就會出現級聯的布局。利用樹狀的結構可以充分的利用 irq 數目,而且每一個 irq_domain 區域可以自己去管理自己 interrupt 的特性。

每一個中斷控制器對應多個中斷號, 而硬件中斷號在不同的中斷控制器上是會重復編碼的, 這時僅僅用硬中斷號已經不能唯一標識一個外設中斷,因此 linux kernel 提供了一個虛擬中斷號的概念。

接下來我們看下硬件中斷號是如何映射到虛擬中斷號的。

數據結構

在看硬件中斷號映射到虛擬中斷號之前,先來看下幾個比較重要的數據結構。 

  1. struct irq_desc 描述一個外設的中斷,稱之中斷描述符。  
  2. struct irq_desc {  
  3.  struct irq_common_data irq_common_data;  
  4.  struct irq_data  irq_data;    
  5.  unsigned int __percpu *kstat_irqs;  
  6.  irq_flow_handler_t handle_irq;    
  7.   ......  
  8.  struct irqaction *action;   
  9.  ......  
  10. } ____cacheline_internodealigned_in_smp; 
  •  irq_data:中斷控制器的硬件數據
  •  handle_irq:中斷控制器驅動的處理函數,指向一個 struct irqaction 的鏈表,一個中斷源可以多個設備共享,所以一個 irq_desc 可以掛載多個 action,由鏈表結構組織起來
  •  action:設備驅動的處理函數

struct irq_data 包含中斷控制器的硬件數據。 

  1. struct irq_data {  
  2.  u32   mask;  
  3.  unsigned int  irq;  
  4.  unsigned long  hwirq;  
  5.  struct irq_common_data *common;  
  6.  struct irq_chip  *chip;  
  7.  struct irq_domain *domain;  
  8. #ifdef CONFIG_IRQ_DOMAIN_HIERARCHY  
  9.  struct irq_data  *parent_data;  
  10. #endif  
  11.  void   *chip_data;  
  12. }; 
  •  irq:虛擬中斷號
  •  hwirq:硬件中斷號
  •  chip:對應的 irq_chip 數據結構
  •  domain:對應的 irq_domain 數據結構

struct irq_chip 用于對中斷控制器的硬件操作。 

  1. struct irq_chip {  
  2.  struct device *parent_device;  
  3.  const char *name;  
  4.  unsigned int (*irq_startup)(struct irq_data *data);  
  5.  void  (*irq_shutdown)(struct irq_data *data); 
  6.  void  (*irq_enable)(struct irq_data *data);  
  7.  void  (*irq_disable)(struct irq_data *data);  
  8.  void  (*irq_ack)(struct irq_data *data);  
  9.  void  (*irq_mask)(struct irq_data *data);  
  10.  void  (*irq_mask_ack)(struct irq_data *data);  
  11.  void  (*irq_unmask)(struct irq_data *data);  
  12.  void  (*irq_eoi)(struct irq_data *data); 
  13.  int  (*irq_set_affinity)(struct irq_data *data, const struct cpumask *dest, bool force);  
  14.  int  (*irq_retrigger)(struct irq_data *data);  
  15.  int  (*irq_set_type)(struct irq_data *data, unsigned int flow_type);  
  16.  int  (*irq_set_wake)(struct irq_data *data, unsigned int on);  
  17.  void  (*irq_bus_lock)(struct irq_data *data);  
  18.  void  (*irq_bus_sync_unlock)(struct irq_data *data);  
  19.  ...... 
  20. }; 
  •  parent_device:指向父設備
  •  name:/proc/interrupts 中顯示的名字
  •  irq_startup:啟動中斷,如果設置成 NULL,則默認為 enable
  •  irq_shutdown:關閉中斷,如果設置成 NULL,則默認為 disable
  •  irq_enable:中斷使能,如果設置成 NULL,則默認為 chip->unmask
  • irq_disable:中斷禁止
  •  irq_ack:開始新的中斷
  •  irq_mask:中斷源屏蔽
  •  irq_mask_ack:應答并屏蔽中斷
  •  irq_unmask:解除中斷屏蔽
  •  irq_eoi:中斷處理結束后調用
  •  irq_set_affinity:在 SMP 中設置 CPU 親和力
  •  irq_retrigger:重新發送中斷到 CPU
  •  irq_set_type:設置中斷觸發類型
  •  irq_set_wake:使能/禁止電源管理中的喚醒功能
  •  irq_bus_lock:慢速芯片總線上的鎖
  •  irq_bus_sync_unlock:同步釋放慢速總線芯片的鎖

struct irq_domain 與中斷控制器對應,完成硬件中斷號 hwirq 到 virq 的映射。 

  1. struct irq_domain {  
  2.  struct list_head link;  
  3.  const char *name;  
  4.  const struct irq_domain_ops *ops;  
  5.  void *host_data;  
  6.  unsigned int flags;  
  7.  unsigned int mapcount;  
  8.  /* Optional data */  
  9.  struct fwnode_handle *fwnode;  
  10.  enum irq_domain_bus_token bus_token;  
  11.  struct irq_domain_chip_generic *gc;  
  12. #ifdef CONFIG_IRQ_DOMAIN_HIERARCHY  
  13.  struct irq_domain *parent;  
  14. #endif  
  15. #ifdef CONFIG_GENERIC_IRQ_DEBUGFS  
  16.  struct dentry  *debugfs_file;  
  17. #endif  
  18.  /* reverse map data. The linear map gets appended to the irq_domain */  
  19.  irq_hw_number_t hwirq_max;  
  20.  unsigned int revmap_direct_max_irq;  
  21.  unsigned int revmap_size;  
  22.  struct radix_tree_root revmap_tree;  
  23.  unsigned int linear_revmap[];  
  24. }; 
  •  link:用于將 irq_domain 連接到全局鏈表 irq_domain_list 中
  •  name:irq_domain 的名稱
  •  ops:irq_domain 映射操作函數集
  •  mapcount:映射好的中斷的數量
  •  fwnode:對應中斷控制器的 device node
  •  parent:指向父級 irq_domain 的指針,用于支持級聯 irq_domain
  •  hwirq_max:該 irq_domain 支持的中斷最大數量
  •  linear_revmap[]:hwirq->virq 反向映射的線性表

struct irq_domain_ops 是 irq_domain 映射操作函數集。 

  1. struct irq_domain_ops {  
  2.  int (*match)(struct irq_domain *d, struct device_node *node,  
  3.        enum irq_domain_bus_token bus_token);  
  4.  int (*select)(struct irq_domain *d, struct irq_fwspec *fwspec,  
  5.         enum irq_domain_bus_token bus_token);  
  6.  int (*map)(struct irq_domain *d, unsigned int virq, irq_hw_number_t hw);  
  7.  void (*unmap)(struct irq_domain *d, unsigned int virq);  
  8.  int (*xlate)(struct irq_domain *d, struct device_node *node, 
  9.        const u32 *intspec, unsigned int intsize,  
  10.        unsigned long *out_hwirq, unsigned int *out_type);  
  11.  ......  
  12. }; 
  •  match:用于中斷控制器設備與 irq_domain 的匹配
  •  map:用于硬件中斷號與 Linux 中斷號的映射
  •  xlate:通過 device_node,解析硬件中斷號和觸發方式

struct irqaction 主要是用來存設備驅動注冊的中斷處理函數。 

  1. struct irqaction {  
  2.  irq_handler_t  handler;   
  3.  void   *dev_id;    
  4.   ......  
  5.  unsigned int  irq;    
  6.  unsigned int  flags;   
  7.   ......  
  8.  const char  *name;     
  9.  struct proc_dir_entry *dir;  
  10. } ____cacheline_internodealigned_in_smp; 
  •  handler:設備驅動里的中斷處理函數
  •  dev_id:設備 id
  •  irq:中斷號
  •  flags:中斷標志,注冊時設置,比如上升沿中斷,下降沿中斷等
  •  name:中斷名稱,產生中斷的硬件的名字
  •  dir:指向 /proc/irq/ 相關的信息

這里,我們用一張圖來匯總下上面的數據結構:

上面的結構體 struct irq_desc 是設備驅動加載的過程中完成的,讓設備樹中的中斷能與具體的中斷描述符 irq_desc 匹配,其中 struct irqaction 保存著設備的中斷處理函數。右邊框內的結構體主要是在中斷控制器驅動加載的過程中完成的,其中 struct irq_chip 用于對中斷控制器的硬件操作,struct irq_domain 用于硬件中斷號到 Linux irq 的映射。

下面我們結合代碼看下中斷控制器驅動和設備驅動是如何創建這些結構體,并且硬中斷和虛擬中斷號是如何完成映射的。

中斷控制器注冊 irq_domain

通過 __irq_domain_add 初始化 irq_domain 數據結構,然后把 irq_domain 添加到全局的鏈表 irq_domain_list 中。

外設的驅動創建硬中斷和虛擬中斷號的映射關系

設備的驅動在初始化的時候可以調用 irq_of_parse_and_map 這個接口函數進行該 device node 中和中斷相關的內容的解析,并建立映射關系

  •  of_irq_parse_one 函數用于解析DTS文件中設備定義的屬性,如"reg", “interrupt”
  •  irq_find_matching_fwspec 遍歷 irq_domain_list 鏈表,找到 device node 匹配的 irq_domain
  • gic_irq_domain_translate 解析出中斷信息,比如硬件中斷號 hwirq,中斷觸發方式
  •  irq_domain_alloc_descs 分配一個虛擬的中斷號 virq,分配和初始化中斷描述符 irq_desc
  •  gic_irq_domain_alloc 為 hwirq 和 virq 創建映射關系。內部會通過 irq_domain_set_info 調用 irq_domain_set_hwirq_and_chip,然后通過 virq 獲取 irq_data 結構體,并將 hwirq 設置到 irq_data->hwirq 中, 最終完成 hwirq 到 virq 的映射
  • irq_domain_set_info 根據硬件中斷號的范圍設置 irq_desc->handle_irq 的指針,共享中斷入口為 handle_fasteoi_irq,私有中斷入口為 handle_percpu_devid_irq

最后,我們可以通過 /proc/interrupts 下的值來看下它們的關系:

現在,我們已經知道內核為硬件中斷號與 Linux 中斷號做了映射,相關數據結構的綁定及初始化,并且設置了中斷處理函數執行的入口。接下來我們再看下設備的中斷是怎么來注冊的?

中斷的注冊

設備驅動中,獲取到了 irq 中斷號后,通常就會采用 request_irq/request_threaded_irq 來注冊中斷,其中 request_irq 用于注冊普通處理的中斷。request_threaded_irq 用于注冊線程化處理的中斷,線程化中斷的主要目的把中斷上下文的任務遷移到線程中,減少系統關中斷的時間,增強系統的實時性。 

  1. static inline int __must_check  
  2. request_irq(unsigned int irq, irq_handler_t handler, unsigned long flags,  
  3.         const char *name, void *dev)  
  4.  
  5.     return request_threaded_irq(irq, handler, NULL, flags, name, dev);  

其中 irq 是 linux 中斷號,handler 是中斷處理函數,flags 是中斷標志位,name 是中斷的名字。在講具體的注冊流程前,先看一下主要的中斷標志位: 

  1. #define IRQF_SHARED  0x00000080              //多個設備共享一個中斷號,需要外設硬件支持  
  2. #define IRQF_PROBE_SHARED 0x00000100              //中斷處理程序允許sharing mismatch發生  
  3. #define __IRQF_TIMER  0x00000200               //時鐘中斷  
  4. #define IRQF_PERCPU  0x00000400               //屬于特定CPU的中斷  
  5. #define IRQF_NOBALANCING 0x00000800               //禁止在CPU之間進行中斷均衡處理  
  6. #define IRQF_IRQPOLL  0x00001000              //中斷被用作輪訓  
  7. #define IRQF_ONESHOT  0x00002000              //一次性觸發的中斷,不能嵌套,1)在硬件中斷處理完成后才能打開中斷;2)在中斷線程化中保持關閉狀態,直到該中斷源上的所有thread_fn函數都執行完 
  8. #define IRQF_NO_SUSPEND  0x00004000      //系統休眠喚醒操作中,不關閉該中斷 
  9. #define IRQF_FORCE_RESUME 0x00008000              //系統喚醒過程中必須強制打開該中斷  
  10. #define IRQF_NO_THREAD  0x00010000      //禁止中斷線程化  
  11. #define IRQF_EARLY_RESUME 0x00020000      //系統喚醒過程中在syscore階段resume,而不用等到設備resume階段  
  12. #define IRQF_COND_SUSPEND 0x00040000      //與NO_SUSPEND的用戶共享中斷時,執行本設備的中斷處理函數 

創建完成后,通過 ps 命令可以查看系統中的中斷線程,注意這些線程是實時線程 SCHED_FIFO: 

  1. # ps -A | grep "irq/"  
  2. root          1749     2       0      0 irq_thread          0 S [irq/433-imx_drm]  
  3. root          1750     2       0      0 irq_thread          0 S [irq/439-imx_drm]  
  4. root          1751     2       0      0 irq_thread          0 S [irq/445-imx_drm]  
  5. root          1752     2       0      0 irq_thread          0 S [irq/451-imx_drm]  
  6. root          2044     2       0      0 irq_thread          0 S [irq/279-isl2902]  
  7. root          2192     2       0      0 irq_thread          0 S [irq/114-mmc0]  
  8. root          2199     2       0      0 irq_thread          0 S [irq/115-mmc1]  
  9. root          2203     2       0      0 irq_thread          0 S [irq/322-5b02000]  
  10. root          2361     2       0      0 irq_thread          0 S [irq/294-4-0051]  

 

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

2021-08-03 15:10:26

Linux代碼驅動

2021-12-08 08:41:31

Linux 中斷子系統Linux 系統

2021-12-10 08:45:45

Linux GIC Linux 系統

2021-12-14 08:51:23

Linux 中斷子系統Linux 系統

2021-08-31 11:53:38

Linux inputLinux 系統

2017-07-14 14:35:27

Linux中斷系統

2021-12-15 10:02:25

鴻蒙HarmonyOS應用

2015-10-19 17:36:19

MOST內核Linux

2021-08-17 14:39:00

鴻蒙HarmonyOS應用

2021-07-22 08:03:08

Windows 操作系統Linux

2023-06-28 15:00:02

開源鴻蒙輸入系統架構

2021-09-02 15:27:54

鴻蒙HarmonyOS應用

2016-10-17 08:49:15

WindowsLinuxArch Linux

2023-04-12 15:31:11

系統服務管理鴻蒙

2016-07-22 10:50:56

Linux內核無線子系統

2021-12-17 16:42:09

鴻蒙HarmonyOS應用

2021-11-08 15:04:47

鴻蒙HarmonyOS應用

2022-01-06 16:17:58

鴻蒙HarmonyOS應用

2022-02-17 20:57:07

OpenHarmon操作系統鴻蒙

2021-09-18 14:40:37

鴻蒙HarmonyOS應用
點贊
收藏

51CTO技術棧公眾號

97夜夜澡人人双人人人喊| 久久精品最新地址| 丁香婷婷激情网| av中文字幕在线| 精品中文av资源站在线观看| 欧美高清视频在线观看| 欧美丰满少妇人妻精品| 日韩经典一区| 亚洲第一搞黄网站| 亚洲巨乳在线观看| 欧日韩在线视频| 人人狠狠综合久久亚洲| 欧美黄色片免费观看| 无码一区二区三区在线| 国模大尺度视频一区二区| 黄网动漫久久久| 综合视频在线观看| 亚洲色欧美另类| 韩国av一区二区三区在线观看| 午夜精品久久久久久久99热浪潮| eeuss中文字幕| 国产精品一线| 欧美精品日日鲁夜夜添| 波多野结衣乳巨码无在线| 黄色动漫在线| 中文字幕精品综合| 国产九区一区在线| 国产毛片久久久久| 日本视频在线一区| 欧美精品久久久久久久免费观看| 久久免费手机视频| 奇米777国产一区国产二区| 欧美一区二区三区视频在线观看 | 66久久国产| 国产一区av在线| 偷拍女澡堂一区二区三区| 91精品啪在线观看国产手机| 欧美日韩国产高清一区二区 | 精品系列免费在线观看| 欧美亚洲第一区| 国产精彩视频在线| 欧美视频二区| 久久影视电视剧免费网站清宫辞电视| 一级片视频免费看| 伊人春色精品| 日韩激情av在线播放| 欧美xxxxx精品| 亚洲一二av| 欧美一区二区三区电影| 久久久精品高清| 玖玖精品在线| 欧美三级中文字幕| 老司机午夜av| 九七电影院97理论片久久tvb| 色伊人久久综合中文字幕| 人妻有码中文字幕| 自拍偷自拍亚洲精品被多人伦好爽| 姬川优奈aav一区二区| 国产极品在线视频| 综合另类专区| 欧美体内she精视频| 在线观看亚洲色图| 四虎精品在线观看| 91精品国产手机| 亚洲一区二区三区四区精品| 精品久久久久久久久久岛国gif| 欧美一二三区在线观看| 日韩精品xxx| 精品人人人人| 亚洲精品一区二区久| 永久免费毛片在线观看| 久久久久久影院| 色中色综合影院手机版在线观看 | 黄色视屏免费在线观看| 亚洲精品你懂的| 成人在线免费高清视频| 91超碰在线免费| 欧美香蕉大胸在线视频观看 | 欧美 日韩 国产 成人 在线观看| 亚洲日本视频在线| 亚洲精品久久久久中文字幕欢迎你| 日本女人性视频| 日韩中文字幕在线一区| 精品美女一区二区三区| 国产欧美视频一区| 秋霞综合在线视频| 亚洲人成网站免费播放| 成人18视频免费69| 国内综合精品午夜久久资源| 午夜免费日韩视频| 欧美特级黄色片| 蜜臀久久99精品久久久久久9 | 祥仔av免费一区二区三区四区| 欧美日韩亚洲综合一区 | 久久99精品久久久久久久久久久久 | 日本福利一区二区三区| 国内精品偷拍视频| 成人性视频网站| 免费中文日韩| 视频免费一区| 亚洲国产欧美在线| 精品久久久久久中文字幕2017| 精品亚洲二区| 亚洲精品永久免费| 亚洲精品久久久久久国| 在线精品小视频| 欧美专区第一页| 一区二区三区免费观看视频| 成人午夜免费视频| 图片区小说区区亚洲五月| 天堂av在线电影| 色综合久久久久综合体| 三级网站免费看| 丁香5月婷婷久久| 北条麻妃久久精品| 人人干人人干人人干| 久久精品国产久精国产爱| 国产一区二区三区四区hd| 国产视频网站在线| 亚洲国产日日夜夜| 亚洲免费999| 亚洲警察之高压线| 中文字幕9999| 中文字幕高清在线免费播放| 国产精品一二三四区| 欧美久久电影| а√天堂8资源在线| 欧美久久久久中文字幕| aaaaa级少妇高潮大片免费看| 综合在线一区| 国产精品久久久久久久久久久新郎| 日本高清视频www| 亚洲精品视频在线看| 九色91popny| 香蕉久久夜色精品国产更新时间| 操日韩av在线电影| 亚洲天堂avav| 久久九九久精品国产免费直播| 精品人妻大屁股白浆无码| 日韩美女在线看免费观看| 日韩精品在线观看视频| 国产亚洲精品码| 狠狠狠色丁香婷婷综合激情| 人偷久久久久久久偷女厕| 都市激情国产精品| 日韩女优视频免费观看| 亚洲天堂网av在线| 奇米影视一区二区三区小说| 国产日产精品一区二区三区四区 | 超碰97人人做人人爱少妇| 夜夜躁狠狠躁日日躁av| 国产日韩欧美一区二区三区乱码| 国内精品视频一区二区三区| 麻豆国产精品| 色诱女教师一区二区三区| 中文人妻熟女乱又乱精品| 久久久久久久久免费| 成人毛片视频网站| 日韩美女国产精品| 性欧美办公室18xxxxhd| 亚洲精品久久久久久久久久| 亚洲一区在线看| 不许穿内裤随时挨c调教h苏绵 | 国产三级精品三级| 99蜜桃臀久久久欧美精品网站| 国产厕拍一区| 欧美一区二区.| 日本一级在线观看| 欧美日韩在线影院| 成人乱码一区二区三区av| 亚洲影音一区| 日韩一区免费观看| 免费在线成人激情电影| 亚洲深夜福利在线| 国产精品久久久久久免费免熟| 中文字幕一区二区三区四区| 国产欧美一区二| 黄色综合网站| 久草一区二区| 欧美最新精品| 最近2019年中文视频免费在线观看| 中文在线字幕免费观| 国产精品成人免费精品自在线观看 | 中文字幕亚洲一区二区av在线| av免费网站观看| 奇米狠狠一区二区三区| 国产在线一区二区三区| 午夜伦理在线视频| 日韩成人久久久| 久久久久久无码精品大片| 国产精品久线在线观看| 亚洲成人av免费观看| 亚洲人体大胆视频| 欧美1o一11sex性hdhd| 成人免费91| 97国产精品免费视频| 国产区视频在线播放| 在线不卡一区二区| 国产福利拍拍拍| 国产精品毛片久久久久久久| 亚洲一区二区三区四区精品| 日韩精品久久久久久| 青青草影院在线观看| 国产精品白浆| 国产精品一二区| a级大胆欧美人体大胆666| 国产亚洲美女久久| 午夜精品久久久久久久第一页按摩 | a级大片免费看| 夜夜夜久久久| 亚洲一区精品视频| 国产精品xxxav免费视频| 国产精品久久久久久久久男| 三级网站视频在在线播放| 亚洲欧美日韩视频一区| 草逼视频免费看| 欧美伊人久久久久久久久影院 | 精产国品一区二区三区| 久久不射2019中文字幕| 国产树林野战在线播放| 天堂在线精品| 成人资源av| 欧美黄页在线免费观看| 7777精品视频| 韩国中文字幕在线| 国产亚洲欧美日韩精品| 婷婷伊人综合中文字幕| 制服丝袜亚洲色图| 人人妻人人爽人人澡人人精品| 亚洲国产日韩综合久久精品| 色哟哟一一国产精品| 2020国产精品自拍| 熟妇人妻久久中文字幕| 韩日欧美一区二区三区| 99视频精品免费| 国产日韩一区| 日韩久久久久久久久久久久| 亚洲不卡av不卡一区二区| 国产自产精品| 久久香蕉精品香蕉| 99久久久精品免费观看国产 | 超碰在线观看免费版| 曰本色欧美视频在线| 日韩电影免费| 亚洲精品成人免费| 国内精品久久久久久久久久久| 精品视频在线免费观看| 久久久久亚洲视频| 日韩欧美高清视频| 国产黄色片免费看| 亚洲电影一级黄| 久操视频免费在线观看| 国产精品丝袜久久久久久app| 久久久精品成人| 国产亚洲女人久久久久毛片| 欧美 日本 国产| www.在线欧美| 亚洲精品久久一区二区三区777| 国内精品在线播放| 91欧美一区二区三区| 麻豆国产精品一区二区三区| 中文字幕免费高清在线| 免费成人av资源网| 欧美特级aaa| 九色综合国产一区二区三区| 五月天激情视频在线观看| 日本视频中文字幕一区二区三区 | 国产麻豆精品95视频| 第一区免费在线观看| 黄网站免费久久| 午夜大片在线观看| 国产精品一二三区在线| 欧美熟妇精品一区二区| 国产一区福利在线| 在线观看免费视频国产| 9久草视频在线视频精品| 国产传媒第一页| 国产婷婷色一区二区三区| 欧美丰满老妇熟乱xxxxyyy| 国产精品久久久久影院亚瑟| 美国精品一区二区| 亚洲精品国产视频| 国产一级一片免费播放放a| 天天av天天翘天天综合网色鬼国产| 午夜毛片在线观看| 欧美日韩一区中文字幕| 精品国自产在线观看| 日韩一区二区三区免费观看| 天天干天天草天天射| 国产亚洲一区二区在线| 精精国产xxxx视频在线| 亚洲 日韩 国产第一| 成人视屏在线观看| 亚洲自拍高清视频网站| 亚洲丝袜美腿一区| 中文有码久久| 一区在线播放| 搡女人真爽免费午夜网站| 九九国产精品视频| 四季av综合网站| 久久综合给合久久狠狠狠97色69| av最新在线观看| 五月婷婷欧美视频| 一级黄色大片网站| 亚洲第一色在线| 777电影在线观看| 久久综合免费视频| 国外成人福利视频| 黑人另类av| 国产精品99视频| 欧洲黄色一级视频| 韩国欧美国产1区| 影音先锋人妻啪啪av资源网站| 国产精品久久午夜夜伦鲁鲁| 国产精品500部| 91精品在线观看入口| 青青草免费在线视频| 美女福利精品视频| 97蜜桃久久| 91福利视频导航| 精品国产一区二区三区小蝌蚪 | 亚洲一区二区三区综合| 亚洲欧洲韩国日本视频| 黄色污污视频软件| 亚洲成年人在线| 九义人在线观看完整免费版电视剧| 91成人在线观看国产| 精品一区二区三区亚洲| 日本午夜一区二区三区| 亚洲精选久久| 女人扒开腿免费视频app| 国产精品无码永久免费888| 日本熟妇毛茸茸丰满| 制服丝袜日韩国产| 波多野结衣在线影院| 日本sm极度另类视频| 嫩草国产精品入口| 国产黄色激情视频| 国产在线精品免费| 懂色av粉嫩av浪潮av| 色婷婷久久久久swag精品| 少妇精品高潮欲妇又嫩中文字幕| 久久亚洲影音av资源网 | 国产成人精品久久亚洲高清不卡| 久久丝袜视频| 91免费黄视频| 国产精品18久久久久久久久久久久 | 欧美性色黄大片手机版| 人妻妺妺窝人体色www聚色窝| 久久国产精品久久久久| 久久伊人国产| 一区二区成人国产精品| 男女性色大片免费观看一区二区| 国产美女喷水视频| 色香蕉久久蜜桃| 欧美美乳在线| 欧美孕妇与黑人孕交| 丝袜av一区| 杨幂毛片午夜性生毛片| 中文字幕第一区| 在线视频1卡二卡三卡| 国产一区二区三区日韩欧美| free欧美| 欧洲精品国产| 精品一区二区三区免费| 国产免费久久久久| 制服丝袜中文字幕亚洲| 9191在线播放| 国产成人一区二区三区免费看| 国产精品久久久久久久久久妞妞| 熟妇人妻久久中文字幕| 欧美午夜片欧美片在线观看| 激情小说 在线视频| 国产成人精品视| 欧美一级全黄| 在线观看的毛片| 最近日韩中文字幕| 99久久久久成人国产免费| 精品中文字幕乱| 亚洲第一二区| aa在线免费观看| 国产欧美精品在线观看| 在线中文字幕网站| 欧美成人精品在线视频| 一区二区三区四区精品视频| 免费视频爱爱太爽了| av电影天堂一区二区在线观看| www.久久精品视频| 一区二区三区在线播放欧美| 另类一区二区| 男人j进女人j| 久久久久久久一区| 国产片在线播放| 97国产真实伦对白精彩视频8| 国语产色综合| 一级做a免费视频| 岛国av午夜精品| 欧美69xxx| 国产亚洲欧美一区二区| 免费观看日韩电影|