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

OpenHarmony HDF 配置管理分析及使用

開發 前端
本文從全景介紹了 HCS 配置管理方案,重點分析了 HC-GEN 的實現和 HCS 的編譯過程,希望對讀者理解 HCS 的原理和配置方法能有所幫助

[[422661]]

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

HDF配置管理概述

HCS(HDF Configuration Source)是 HDF 驅動框架的配置描述源碼,內容以 KeyValue 為主要形式。它實現了配置代碼與驅動代碼解耦,便于開發者進行配置管理。

HC-GEN(HDF Configuration Generator)是 HCS 配置轉換工具,可以將 HDF 配置文件轉換為軟件可讀取的文件格式:

  • 在弱性能環境中,轉換為配置樹源碼,驅動可直接調用 C 代碼獲取配置。
  • 在高性能環境中,轉換為 HCB(HDF Configuration Binary)二進制文件,驅動可使用 HDF 框架提供的配置解析接口獲取配置。

以下是使用 HCB 模式的典型應用場景:

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

圖1 配置使用流程圖

HCS 經過 HC-GEN 編譯生成 HCB 文件,HDF 驅動框架中的 HCS Parser 模塊會從 HCB 文件中重建配置樹,HDF 驅動模塊使用 HCS Parser 提供的配置讀取接口獲取配置內容。

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

圖2 HCS的架構圖

HCS 文本更適合人類閱讀,但是并不方便程序直接存取,所以經過 HC-GEN 編譯,輸出二進制的 HCB 數據。HCB 在編譯后打包進內核鏡像的.rodata 只讀分區,在啟動加載時,框架定位到 HCB 數據頭,再將二進制數據重新構造為樹形數據結構供驅動查詢和讀取。下面詳細分析 HC-GEN 實現。

HCS源碼語法

HCS 的語法介紹如下:

關鍵字

HCS 配置語法保留了以下關鍵字。

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

基本結構

HCS 主要分為屬性(Attribute)和節點(Node)兩種結構。

屬性

屬性即最小的配置單元,是一個獨立的配置項。語法如下:

  1. attribute_name = value; 

 attribute_name 是字母、數字、下劃線的組合且必須以字母或下劃線開頭,字母區分大小寫。

value 的可用格式如下:

  • 數字常量,支持二進制、八進制、十進制、十六進制數,具體參考數據類型節。
  • 字符串,內容使用雙引號(“”)引用。
  • 節點引用。
  • attribute 必須以分號(;)結束且必須屬于一個 node。

節點

節點是一組屬性的集合,語法如下:

  1. node_name { 
  2.         module = "sample"
  3.         ... 
  4.   } 
  • node_name 是字母、數字、下劃線的組合且必須以字母或下劃線開頭,字母區分大小寫。
  • 大括號后無需添加結束符“;”。
  • root為保留關鍵字,用于聲明配置表的根節點。每個配置表必須以 root 節點開始。
  • root 節點中必須包含 module 屬性,其值應該為一個字符串,用于表征該配置所屬模塊。
  • 節點中可以增加 match_attr 屬性,其值為一個全局唯一的字符串。在解析配置時可以調用查找接口以該屬性的值查找到包含該屬性的節點。

數據類型

整型

整型長度自動推斷,根據實際數據長度給與最小空間占用的類型。

  • 二進制,0b 前綴,示例:0b1010。
  • 八進制,0 前綴,示例:0664。
  • 十進制 ,無前綴,且支持有符號與無符號,示例:1024,+1024 均合法。負值在讀取時注意使用有符號數讀取接口。
  • 十六進制,0x 前綴,示例:0xff00、0xFF。

字符串

字符串使用雙引號(“”)表示。

數組

數組元素支持整型、字符串,不支持混合類型。整型數組中 uint32_t uint64_t 混用會向上轉型為 uint64_t 數組。整型數組與字符串數組示例如下:

  1. attr_foo = [0x01, 0x02, 0x03, 0x04]; 
  2. attr_bar = ["hello""world"]; 

bool類型

bool 類型中 true 表示真,false 表示假。

注釋

HCS 支持兩種注釋風格。

單行注釋:

  1. 1.  // comment 

多行注釋:

  1. /* 
  2. comment 
  3. */ 

其他語法

模板

模板的用途在于生成嚴格一致的 node 結構,以便對同類型 node 進行遍歷和管理。

使用 template 關鍵字定義模板 node,子 node 通過雙冒號“::”聲明繼承關系。子節點可以改寫但不能新增和刪除 template 中的屬性,子節點中沒有定義的屬性將使用 template 中的定義作為默認值。示例如下:

  1. root { 
  2.     module = "sample"
  3.     template foo { 
  4.         attr_1 = 0x1; 
  5.         attr_2 = 0x2; 
  6.     } 
  7.     bar :: foo { 
  8.     } 
  9.     bar_1 :: foo { 
  10.         attr_1 = 0x2; 
  11.     } 

 生成配置樹如下:

  1. root { 
  2.     module = "sample"
  3.     bar { 
  4.         attr_1 = 0x1; 
  5.         attr_2 = 0x2; 
  6.     } 
  7.     bar_1 { 
  8.         attr_1 = 0x2; 
  9.         attr_2 = 0x2; 
  10.     } 

 在上述示例中,bar 和 bar_1 節點繼承了 foo 節點,生成配置樹節點結構與 foo 保持了完全一致,只是屬性的值不同。

引用修改

引用修改可以實現修改另外任意一個節點的內容,語法為:

  1. node :& source_node 

 上述語句表示 node 中的內容是對 source_node 節點內容的修改。示例如下:

  1. root { 
  2.     module = "sample"
  3.     foo { 
  4.         foo_ :& root.bar{ 
  5.             attr = "foo"
  6.         } 
  7.         foo1 :& foo2 { 
  8.             attr = 0x2; 
  9.         } 
  10.         foo2 { 
  11.             attr = 0x1; 
  12.         } 
  13.     } 
  14.  
  15.     bar { 
  16.         attr = "bar"
  17.     } 

 最終生成配置樹為:

  1. root { 
  2.     module = "sample"
  3.     foo { 
  4.         foo2 { 
  5.             attr = 0x2; 
  6.         } 
  7.     } 
  8.     bar { 
  9.         attr = "foo"
  10.     } 

 在以上示例中,可以看到 foo.foo_節點通過引用將 bar.attr 屬性的值修改為了"foo",foo.foo1 節點通過引用將 foo.foo2.attr 屬性的值修改為了 0x2。foo.foo_以及 foo.foo1 節點表示對目標節點內容的修改,其自身并不會存在最終生成的配置樹中。

引用同級 node,可以直接使用 node 名稱,否則被引用的節點必須使用絕對路徑,節點間使用“.”分隔,root 表示根節點,格式為 root 開始的節點路徑序列,例如 root.foo.bar 即為一個合法的絕對路徑。

如果出現修改沖突(即多處修改同一個屬性),編譯器將提示 warning,因為這種情況下只會生效某一個修改而導致最終結果不確定。

節點復制

節點復制可以實現在節點定義時從另一個節點先復制內容,用于定義內容相似的節點。語法為:

  1. node : source_node 

 上述語句表示在定義"node"節點時將另一個節點"source_node"的屬性復制過來。示例如下:

  1. root { 
  2.     module = "sample"
  3.     foo { 
  4.         attr_0 = 0x0; 
  5.     } 
  6.     bar:foo { 
  7.         attr_1 = 0x1; 
  8.     } 

 上述代碼的最終生成配置樹為:

  1. root { 
  2.     module = "sample"
  3.     foo { 
  4.         attr_0 = 0x0; 
  5.     } 
  6.     bar { 
  7.         attr_1 = 0x1; 
  8.         attr_0 = 0x0; 
  9.     } 

 在上述示例中,編譯后 bar 節點即包含 attr_0 屬性也包含 attr_1 屬性,在 bar 中對 attr_0 的修改不會影響到 foo。

在 foo 和 bar 在同級 node 中可不指定 foo 的路徑,否則需要使用絕對路徑引用。

刪除

要對 include 導入的 base 配置樹中不需要的節點或屬性進行刪除,可以使用 delete 關鍵字。下面的舉例中 sample1.hcs 通過 include 導入了 sample2.hcs 中的配置內容,并使用 delete 刪除了 sample2.hcs 中的 attribute2 屬性和 foo_2 節點,示例如下:

  1. #include "sample1.hcs" 
  2. root { 
  3.     attr_2 = delete
  4.     foo_2 : delete { 
  5.     } 

屬性引用

為了在解析配置時快速定位到關聯的節點,可以把節點作為屬性的右值,通過讀取屬性查找到對應節點。語法為:

  1. attribute = &node; 

HCB二進制格式

HCB 為便于程序讀取的 HCS 的二進制數據格式,按照下面的編碼表進行數據組織:

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

以一個示例分析下 HCS 源碼和 HCB 的對應關系:

  1. root { 
  2.     module = "sample"
  3.     gpio = [1, 2]; 

上述 HCS 編譯后的 HCB 數據如下:

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

HC-GEN使用介紹

hc-gen 是 HCS 的編譯器,用于在編譯時將 HCS 轉化為 HCB,也可以將 HCB 反編譯為 HCS 以驗證配置數據的正確性,這在驅動調試時將很有幫助。

hc-gen v0.7 之前版本作為 prebuilt 文件以二進制下載方式提供。0.7 版本開始,為了更好的支持多環境部署和版本管理,hc-gen 在編譯過程中從源碼構建。如果調試需要,可以在 OpenHarmony 源碼的 drivers/framework/tools/hc-gen 下執行 make 生成,生成產物在該目錄的 build 子目錄中。

  1. cd drivers/framework/tools/hc-gen 
  2. make 
  3.  
  4. ./build/hc-gen –v 
  5. > Hcs compiler 0.7 

驅動開發過程中,在 hcs 配置文件修改后,可以手動使用 hc-gen 快速驗證配置的正確性,生成 HCB 配置文件方法:

  1. hcgen o [OutputHcbFileName] b [SourceHcsFileName] 

在驅動調試時,可以使用 hc-gen 反編譯 HCB 文件獲得 HCS 源碼,進行配置數據核對。反編譯 HCB 文件為 HCS 方法:

  1. hcgen o [OutputHcsFileName] d [SourceHcbFileName] 

HCS文件編譯過程

在 linux 內核中,HCS 編譯基于 KBuild 自定義規則實現自主的編譯過程,Makefile 入口在 drivers/adapter/khdf/linux/hcs/Makefile。

  1. HC_GEN_DIR := $(abspath $(SOURCE_ROOT)/drivers/framework/tools/hc-gen) 
  2. HC_GEN := $(HC_GEN_DIR)/build/hc-gen 
  3. LOCAL_HCS_ROOT := $(abspath $(dir $(realpath $(lastword $(MAKEFILE_LIST))))) 
  4.  
  5. # LOCAL_HCS_ROOT為根據目標平臺和產品拼接出的HCS路徑 
  6. HCS_DIR := $(LOCAL_HCS_ROOT) 
  7. HCB_FLAGS := -b -i -a 
  8.  
  9. HCS_OBJ := hdf_hcs_hex.o 
  10. HCS_OBJ_SRC := $(subst .o,.c,$(notdir $(HCS_OBJ))) 
  11.  
  12. CONFIG_GEN_HEX_SRC := $(addprefix $(LOCAL_HCS_ROOT)/, $(HCS_OBJ_SRC)) 
  13. CONFIG_HCS_SRC := $(subst _hcs_hex.o,.hcs,$(addprefix $(HCS_DIR)/, $(HCS_OBJ))) 
  14.  
  15. # 使用自定義的.o生成規則覆蓋KBbuild默認規則 
  16. $(obj)/$(HCS_OBJ): $(CONFIG_GEN_HEX_SRC)  
  17.         $(Q)$(CC) $(c_flags) -c -o $@ $< 
  18.         $(Q)rm -f $< 
  19.  
  20. # 將HCB文件生成后再轉換為.c文件中的hex數組,依賴目標為hc-gen工具 
  21. $(CONFIG_GEN_HEX_SRC):  $(LOCAL_HCS_ROOT)/%_hcs_hex.c: $(HCS_DIR)/%.hcs | $(HC_GEN) 
  22.         $(Q)echo gen hdf built-in config 
  23.         $(Q)if [ ! -d $(dir $@) ]; then mkdir -p $(dir $@); fi 
  24.         $(Q)$(HC_GEN) $(HCB_FLAGS) -o $(subst _hex.c,,$(@)) $< 
  25.  
  26. # 生成hc-gen工具 
  27. $(HC_GEN):  
  28.         $(Q)make -C $(HC_GEN_DIR) 
  29.  
  30. obj-$(CONFIG_DRIVERS_HDF) += $(HCS_OBJ) 

 在 HDF 適配其他平臺時,可以復用該 Makefile,核心變化點在正確配置對應平臺的 HCS 根路徑。

HCS配置使用

HCS配置讀取接口

在驅動實現中,可以使用 device_resource_if.h 中定義的接口對配置進行查詢和讀取。常用 API 介紹如下:

OpenHarmony HDF 配置管理分析及使用-鴻蒙HarmonyOS技術社區

配置讀取接口使用實例

以 UART 控制器驅動為例看 HCS 的使用。UART 在 HCS 中 device_info.hcs 中配置的設備信息為:

  1. device_uart :: device { 
  2.     device0 :: deviceNode { 
  3.         policy = 1; 
  4.         priority = 40; 
  5.         permission = 0644; 
  6.         moduleName = "HDF_PLATFORM_UART"
  7.         serviceName = "HDF_PLATFORM_UART_0"
  8.         deviceMatchAttr = "hisilicon_hi35xx_uart_0"
  9.     } 

 在 hi35xx_uart_config.hcs 中配置如下:

  1. root { 
  2.     platform { 
  3.         uart_config { 
  4.             device_uart_0x0000  { 
  5.                 serviceName = ""
  6.                 match_attr = "hisilicon_hi35xx_uart_0"
  7.                 driver_name = "ttyAMA"
  8.                 num = 0; 
  9.             } 
  10.         } 
  11.     } 

 注意到 UART 使用了 match_attr 特性,這樣驅動框架在 device_uart 設備加載時將自動將 device_uart_0x0000 節點關聯到該設備。UART 的配置解析代碼如下:

  1. static int32_t HdfUartInit(struct HdfDeviceObject *obj) 
  2.     int32_t ret; 
  3.     struct DeviceResourceIface *iface = NULL
  4.     … 
  5.     devResourceIface = DeviceResourceGetIfaceInstance(HDF_CONFIG_SOURCE); 
  6.     if (devResourceIface == NULL) { 
  7.         HDF_LOGE("%s: face is invalid", __func__); 
  8.         return HDF_FAILURE; 
  9.     } 
  10.  
  11.     devResourceIface->GetUint32(obj->property, "num", &host->num, 0); 
  12. devResourceIface->GetString(obj->property, "driver_name", &drName, "ttyAMA"); 
  13. …… 
  14.     
  15.     ret = memcpy_s(g_driverName, UART_NAME_LEN - 1, drName, strlen(drName)); 
  16.     if (ret != EOK) { 
  17.         return HDF_FAILURE; 
  18.     } 
  19.     host->method = &g_uartHostMethod; 
  20.     return HDF_SUCCESS; 

device_uart_0x0000 節點被自動關聯到了 HdfDeviceObject 的 property 成員。使用 DeviceResourceGetIfaceInstance 接口獲取到 HCS 接口實例后調用其成員方法 GetUint32 讀取名為"num"的無符號值屬性,使用 GetString 接口讀取名為"driver_name"的字符串屬性。從配置中獲取到屬性值后,再根據配置值完成相關軟硬件的初始化。

總結

本文從全景介紹了 HCS 配置管理方案,重點分析了 HC-GEN 的實現和 HCS 的編譯過程,希望對讀者理解 HCS 的原理和配置方法能有所幫助。關于 HDF 驅動框架的更多分析,請關注后續文章。

想了解更多內容,請訪問:

51CTO和華為官方合作共建的鴻蒙技術社區

https://harmonyos.51cto.com

 

責任編輯:jianghua 來源: 鴻蒙社區
相關推薦

2021-09-10 15:12:04

鴻蒙HarmonyOS應用

2021-09-10 15:10:50

鴻蒙HarmonyOS應用

2022-04-20 20:28:40

HDF 驅動框架鴻蒙操作系統

2022-10-17 14:29:24

鴻蒙應用開發

2023-09-14 15:49:42

PWM鴻蒙

2023-09-06 15:35:14

2021-09-07 15:48:28

鴻蒙HarmonyOS應用

2023-09-13 15:33:57

I2C鴻蒙

2023-10-19 08:16:22

LinuxSQL Server

2015-06-19 10:38:54

數據中心配置管理系統

2023-04-10 08:11:27

Jenkins數據庫

2022-05-24 15:06:57

AbilityeTS FA鴻蒙

2010-12-08 11:30:48

VMMOperations

2009-06-17 14:41:57

Hibernate查詢

2022-05-06 12:04:24

Ansible管理工具

2010-01-08 10:18:47

Ubuntu MySQ

2023-05-30 07:50:56

項目管理權限

2022-05-16 11:50:45

HDF驅動框架

2022-09-05 15:18:23

HDF單鏈表嵌入式系統

2023-08-17 15:01:08

ArkUI布局渲染
點贊
收藏

51CTO技術棧公眾號

日韩一级欧美一级| 亚洲精品你懂的| 欧美一级片在线播放| 熟女高潮一区二区三区| 日韩色淫视频| 亚洲精品精品亚洲| 久久婷婷国产综合尤物精品| 自拍偷拍精品视频| 欧美私人啪啪vps| 亚洲人成在线观| 一级黄色大片儿| 综合毛片免费视频| 亚洲人成在线播放网站岛国| 国产一区二区无遮挡| 中文字幕免费观看视频| 激情久久久久久| 色系列之999| 黄色污在线观看| 国产精品视频一区二区三区综合| 综合久久久久综合| 欧美不卡三区| 亚洲精选一区二区三区| 日本va欧美va瓶| 午夜精品一区二区三区在线播放| 手机看片福利视频| 国产伦精品一区二区三区在线播放 | 91麻豆精品国产91久久久久久| 亚洲欧洲一区二区福利| 天天操天天操天天| 国产精品白丝av| 国产日韩欧美中文在线播放| 国产特黄大片aaaa毛片| 欧美日本不卡高清| 久久中文久久字幕| 正在播放国产对白害羞| 欧美猛男男男激情videos| 精品久久久久一区二区国产| 成人亚洲免费视频| 欧美成人毛片| 欧美午夜片在线看| 欧美黄色一级片视频| 精品极品在线| 婷婷综合五月天| 久久这里只有精品18| 91一区二区三区在线| 国产精品伦理在线| 亚洲一区二区三区精品视频| 二区在线观看| 国产日韩影视精品| 日本一区二区三区视频免费看 | 麻豆精品久久久| 热久久这里只有精品| 国产成人亚洲欧洲在线| 在线欧美日韩| 97在线观看视频| 日本黄色片视频| aa国产精品| 欧美在线视频观看免费网站| 久久久精品免费看| 久久激情网站| 国产精品吹潮在线观看| 国产精品51麻豆cm传媒| 青青草原综合久久大伊人精品优势 | 国产精品91在线观看| yjizz国产| 久久成人国产| 国产精品久久久| 最近中文字幕在线视频| 久久国产精品99久久人人澡| 国产主播在线一区| 国产女人高潮时对白| 国产精品一区二区在线看| 97人人干人人| 天天干视频在线观看| 久久综合资源网| 亚洲精品视频一二三| 毛片在线播放a| 一区二区免费看| 日本www在线播放| 久久精品女人天堂av免费观看| 日韩欧美中文第一页| 热久久精品免费视频| 日韩三级成人| 亚洲精品一区二区三区精华液| 亚洲视频天天射| 猛男gaygay欧美视频| 中文字幕日韩在线观看| 国产大片免费看| 亚洲精品美女91| 国产精品美女网站| www.精品视频| 久久久久9999亚洲精品| 成人短视频在线看| 蜜桃av.网站在线观看| 欧美日韩一级大片网址| 91porn在线| 国产亚洲电影| 欧美美女操人视频| 欧产日产国产69| 国产麻豆精品在线| 欧美日韩亚洲在线| 日本高清成人vr专区| 欧美视频专区一二在线观看| 国产成人美女视频| 丝袜连裤袜欧美激情日韩| 上原亚衣av一区二区三区| 国产午夜激情视频| 久久国产乱子精品免费女| 国产日韩二区| 欧美日韩在线看片| 欧美性黄网官网| 97中文字幕在线观看| 91视频综合| 日韩免费在线免费观看| 亚洲av无码国产综合专区| 国产清纯白嫩初高生在线观看91 | 五月婷婷综合在线观看| 91精品在线观看国产| 日本最新高清不卡中文字幕| 亚洲第一色网站| 亚洲欧美在线视频| 久久国产色av免费观看| 成人知道污网站| 日韩视频免费在线观看| 成人公开免费视频| 成年人网站91| 欧美激情亚洲天堂| 国产日韩一区二区三免费高清| 亚洲精品在线视频| 国产香蕉在线视频| 国产经典欧美精品| 国产精品12p| 久久日本片精品aaaaa国产| 亚洲乱亚洲乱妇无码| 国产大片aaa| 成人免费三级在线| 97超碰在线人人| 97品白浆高清久久久久久| 欧美成人h版在线观看| 一级片在线观看视频| 国产欧美日韩在线视频| 91黄色小网站| 神马影视一区二区| 欧洲亚洲女同hd| 免费在线性爱视频| 色综合天天性综合| 国产jk精品白丝av在线观看| 亚洲专区免费| 免费精品视频一区| 欧美7777| 综合国产在线观看| 91肉色超薄丝袜脚交一区二区| 国产欧美日韩综合| 五月天激情视频在线观看| 成人激情诱惑| 国产日韩欧美在线| dy888亚洲精品一区二区三区| 欧美日韩另类一区| 欧美风情第一页| 国产精品资源在线看| 成年在线观看视频| 福利欧美精品在线| 欧美激情亚洲视频| 人妻少妇精品无码专区久久| 午夜国产精品影院在线观看| 加勒比精品视频| 久久一日本道色综合久久| 日韩欧美三级电影| 亚洲ww精品| 久久99国产综合精品女同| 高潮毛片7777777毛片| 五月婷婷另类国产| 少妇按摩一区二区三区| 日本不卡不码高清免费观看| 99精品一区二区三区的区别| 日韩欧洲国产| 青青a在线精品免费观看| 国产精品一区二区三区四区色| 91福利国产精品| 51精品免费网站| www.色综合.com| 亚洲男人天堂色| 综合天堂久久久久久久| 精品国产_亚洲人成在线| 成人免费毛片嘿嘿连载视频…| 色伦专区97中文字幕| www国产一区| 色域天天综合网| 国产精品国产精品88| 北条麻妃一区二区三区| 欧美两根一起进3p做受视频| 婷婷中文字幕一区| 九色综合婷婷综合| 亚洲一区二区av| 久久久亚洲网站| 在线中文资源天堂| 亚洲国产一区自拍| 国产精品嫩草影院桃色| 黑人巨大精品欧美一区免费视频 | 欧美色欧美亚洲高清在线视频| 在哪里可以看毛片| 国产精品一区二区久激情瑜伽| 欧洲精品在线播放| 日本一区二区在线看| 精品久久久久久综合日本| 日本欧美在线| 欧美在线视频观看| 成人女同在线观看| 日韩一区二区三区在线播放| 天堂中文在线8| 日韩视频不卡中文| 中文字幕福利视频| 天涯成人国产亚洲精品一区av| 欧美巨胸大乳hitomi| 91玉足脚交白嫩脚丫在线播放| 天天干天天草天天| 夜夜夜久久久| 国产毛片久久久久久国产毛片| 狠狠综合久久av一区二区蜜桃| 国产精品国产精品国产专区不卡| 精品国产美女a久久9999| 青草青草久热精品视频在线网站 | 午夜日韩在线电影| 男人操女人的视频网站| 国产精品毛片久久久久久久| 在线观看日韩精品视频| 99久久国产综合精品女不卡| av电影中文字幕| 国产一区二区三区四区五区美女| 蜜臀av午夜一区二区三区| 在线日韩av| 国产情侣第一页| 综合天堂av久久久久久久| 综合视频在线观看| 四季av在线一区二区三区| 日本精品一区二区三区高清 久久 日本精品一区二区三区不卡无字幕 | 黄网站视频在线观看| 一个色综合导航| 久久综合九色综合久| 亚洲精品视频在线观看视频| 色婷婷av一区二区三| 精品国产污网站| 亚洲av无码乱码在线观看性色 | 国产女人爽到高潮a毛片| 欧美日韩精品一二三区| 日本成人一级片| 欧美专区日韩专区| 中文字幕乱码一区二区| 欧美日韩日本视频| 91丨九色丨丰满| 日韩一区二区免费电影| www.欧美国产| 精品粉嫩超白一线天av| 粉嫩av一区二区夜夜嗨| 亚洲精品久久久一区二区三区| 成人免费一级视频| 亚洲国产91色在线| 性xxxx视频| 亚洲欧美日韩国产精品| 国产在线中文字幕| 最近中文字幕2019免费| 哥也色在线视频| 欧美国产视频日韩| 国产精品蜜芽在线观看| 2019亚洲男人天堂| 日韩天堂在线| 成人久久久久久| 澳门久久精品| 欧美黄色直播| 国产精品97| 国产精彩视频一区二区| 久久一二三四| 韩国一区二区在线播放| 成人少妇影院yyyy| av黄色在线免费观看| 《视频一区视频二区| 国产精品第108页| 91国产福利在线| 国产三级精品在线观看| 亚洲第一偷拍网| 高清国产福利在线观看| 久热在线中文字幕色999舞| 俺来俺也去www色在线观看| 日韩免费在线播放| 精品国产鲁一鲁****| 精品久久久三级| 999久久久免费精品国产| 欧美国产日韩激情| 日本vs亚洲vs韩国一区三区二区 | 一区二区三区免费在线看| 精品无人区一区二区三区| 久久国产电影| 久久成人免费观看| 久久国产人妖系列| 国产精品伦子伦| 亚洲女同ⅹxx女同tv| 天天干天天干天天操| 91精品国产美女浴室洗澡无遮挡| 欧美视频一二区| 中文字幕日韩精品在线| 91九色国产在线播放| 国产精品一区二区久久| 久久精品论坛| 国产成人三级视频| 日韩精品成人一区二区三区| 国产乱国产乱老熟300部视频| 久久精品亚洲麻豆av一区二区| 性欧美videos| 欧洲一区在线观看| 天天干天天干天天干| 久久中文久久字幕| 国产第一亚洲| 久久青青草原一区二区| 欧美国产先锋| 天天色综合天天色| 91毛片在线观看| 精品97人妻无码中文永久在线| 欧美影院午夜播放| 台湾av在线二三区观看| 欧美精品videos另类日本| 四虎国产精品永久在线国在线| 韩国精品一区二区三区六区色诱| 98精品视频| 狠狠躁狠狠躁视频专区| 久久先锋资源网| 在线观看黄网站| 精品国产一区二区三区四区四| 午夜免费视频在线国产| 国产成人综合精品在线| 人妖一区二区三区| 欧美高清中文字幕| 国产精品小仙女| 欧美老熟妇一区二区三区| 欧美精品vⅰdeose4hd| 99中文字幕一区| 国产美女扒开尿口久久久| 欧美一区二区三| 天天操天天爽天天射| 久久久99久久精品欧美| www.久久精品视频| 亚洲欧洲中文天堂| 亚洲成av在线| 日韩精品欧美专区| 日韩 欧美一区二区三区| 国产精品久久久久久久av| 欧美最新大片在线看| 波多野结衣一区二区| 国产精品美女免费看| 色婷婷热久久| 无人码人妻一区二区三区免费| 国产精品看片你懂得| 中文字幕+乱码+中文字幕明步 | 瑟瑟视频在线观看| 欧美午夜www高清视频| 精彩国产在线| 国产精品亚洲综合天堂夜夜| 日韩欧美1区| 亚洲综合123| 亚洲第一福利视频在线| 亚欧在线观看视频| 日韩av电影手机在线观看| 国产精品免费不| 亚洲性图一区二区| 亚洲欧美偷拍三级| 蜜桃91麻豆精品一二三区| 777777777亚洲妇女| 国产调教一区二区三区| 久久久久久久久久久久久久久国产| 国产精品久久国产精麻豆99网站| 中文字幕在线观看1| 欧美精品一二区| 校园春色另类视频| xxww在线观看| 洋洋av久久久久久久一区| 亚洲色偷精品一区二区三区| 国产成人综合精品在线| 一区二区电影在线观看| 亚洲av成人片无码| 色婷婷久久99综合精品jk白丝 | 久久婷婷综合激情| 中文字幕一区二区免费| 欧美高清电影在线看| 校花撩起jk露出白色内裤国产精品 | 伦伦影院午夜理论片| 亚洲r级在线视频| freemovies性欧美| 亚洲自拍av在线| 亚洲免费影院| 中文字幕另类日韩欧美亚洲嫩草| 日韩午夜精品电影| 蜜臀国产一区| 国产人妻互换一区二区| 久久久精品国产免大香伊| 国产精品自产拍| 人九九综合九九宗合| 欧美1区2区3区| 一区二区三区在线观看免费视频| 制服丝袜中文字幕一区| 一级毛片久久久| 日韩a级黄色片|