日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 运维知识 > linux >内容正文

linux

Linux EXPORT_SYMBOL宏详解

發布時間:2023/12/16 linux 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Linux EXPORT_SYMBOL宏详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

文章目錄

  • 前言
  • 一、EXPORT_SYMBOL簡介
  • 二、EXPORT_SYMBOL源碼詳解
  • 三、模塊導出符號
  • 總結
  • 參考資料

前言

內核模塊被載入后,就會被動態地連接到內核(與用戶空間的動態庫類似,只有函數被顯式的導出為外部函數后,才可以被動態庫調用)。在內核中,導出內核函數需要特殊的指令:EXPORT_SYMBOL宏和EXPORT_SYMBOL_GPL宏。
在內核代碼中我們經常看到EXPORT_SYMBOL宏,用來導出一個內核符號。比如:
EXPORT_SYMBOL宏:

// linux-4.10.1/kernel/module.cint register_module_notifier(struct notifier_block *nb) {return blocking_notifier_chain_register(&module_notify_list, nb); } EXPORT_SYMBOL(register_module_notifier);int unregister_module_notifier(struct notifier_block *nb) {return blocking_notifier_chain_unregister(&module_notify_list, nb); } EXPORT_SYMBOL(unregister_module_notifier);

EXPORT_SYMBOL_GPL宏:

// linux-4.10.1/kernel/module.c/** Mutex protects:* 1) List of modules (also safely readable with preempt_disable),* 2) module_use links,* 3) module_addr_min/module_addr_max.* (delete and add uses RCU list operations). */ DEFINE_MUTEX(module_mutex); EXPORT_SYMBOL_GPL(module_mutex);

一、EXPORT_SYMBOL簡介

我們都知道Linux 是單內核,作為一個不可分割的靜態執行庫,內核通常以單個靜態的二進制文件形式存放在磁盤中,在一個單獨的內核地址空間上運行,由于內核都處在同一內核地址空間,因此內核可以直接調用函數。如果只是單一的內核映像存在,而沒有內核模塊存在,EXPORT_SYMBOL通常是沒有啥意義的,因為對于靜態編譯鏈接而成的單一的內核映像而言,所有的符號引用都將在靜態鏈接階段完成。

由于Linux支持動態地加載內核模塊,運行內核在運行時根據需要動態地加載模塊,由于有內核模塊的存在,內核模塊通常會使用內核映像中的符號,因此使用EXPORT_SYMBOL將內核映像的符號導出,這樣在內核模塊中就能使用該符號了。

內核模塊是獨立編譯的,然后加載到正在運行的內核中,當編譯內核模塊時,編譯器引用到內核中的符號時,會產生未解決的引用,處理“未解決引用”問題的就要在模塊加載期間找到當前“未解決的引用”符號在內存中的實際目標地址。內核和內核模塊通過符號表的形式向外部導出符號的相關信息,這種導出符號的方式在代碼層面以EXPORT_SYMBOL宏定義的形式存在。

解決模塊中的未解決引用是在模塊的加載階段,用nm命名查看模塊未解決的引用:

nm nf_conntrack.ko

輸出中U代表未解決的引用,對于未解決的引用符號,不顯示該符號相對于模塊起始地址的相對偏移地址,即沒有符號值。

查看模塊所有的未定義引用:

nm nf_conntrack.ko | grep '\<U\>'

二、EXPORT_SYMBOL源碼詳解

// linux-4.10.1/include/linux/export.hstruct kernel_symbol {unsigned long value;const char *name; };/* For every exported symbol, place a struct in the __ksymtab section */ #define ___EXPORT_SYMBOL(sym, sec) \extern typeof(sym) sym; \__CRC_SYMBOL(sym, sec) \static const char __kstrtab_##sym[] \__attribute__((section("__ksymtab_strings"), aligned(1))) \= VMLINUX_SYMBOL_STR(sym); \static const struct kernel_symbol __ksymtab_##sym \__used \__attribute__((section("___ksymtab" sec "+" #sym), used)) \= { (unsigned long)&sym, __kstrtab_##sym }#define EXPORT_SYMBOL(sym) \__EXPORT_SYMBOL(sym, "")#define EXPORT_SYMBOL_GPL(sym) \__EXPORT_SYMBOL(sym, "_gpl")#define EXPORT_SYMBOL_GPL_FUTURE(sym) \__EXPORT_SYMBOL(sym, "_gpl_future")

C語言的宏定義中 # 和 ## 運算符:
#運算符是將其后面的宏參數轉化為字符串,用來創建字符串,例如#sym,表示"sym"。
##運算符用來替換粘合兩個不同的符號,例如__ksymtab_##sym,就表示"__ksymtab_sym"。

attribute:__attribute__實際上是GCC的一種編譯器命令,用來指示編譯器執行實現某些高級操作。__attribute__可以設置函數屬性(Function Attribute)、變量屬性(Variable Attribute)和類型屬性(Type Attribute),函數屬性可以幫助開發人員向函數聲明中添加一些特性,這可以使編譯器在錯誤檢查方面增強。

使用EXPORT_SYMBOL(export_function)導出export_function函數,上述宏可以擴展為:

static const char __kstrtab_export_function[] = "export_function"; static const struct kernel_symbol __ksymtab_export_function = {(unsigned long)&export_function, __kstrtab_export_function };

第一個變量是一個字符串靜態變量,用來表示導出的符號名稱"export_function"。
第二個變量類型是struct kernel_symbol數據結構,用來表示一個內核符號的實例,struct kernel_symbol的定義為:

// linux-4.10.1/include/linux/export.hstruct kernel_symbol {unsigned long value;const char *name; };

其中,value是該符號在內存中的地址,name是符號名。所以,由該數據結構可以知道,用EXPORT_SYMBOL(export_function)來導出符號"export_function",實際上是要通過struct kernel_symbol的一個對象告訴外部關于這個符號的兩點信息:符號名稱和地址。這樣使得內核根據函數的字符串名稱,即可找到匹配的代碼地址,在解決未定義的引用時需要這要做。

因此,由EXPORT_SYMBOL等宏導出的符號,與一般的變量定義并沒有實質性的差異,唯一的不同點在于它們被放在了特定的section中。

上面的符號"export_function"會放在"__ksymtab_strings"的section中,struct kernel_symbol __ksymtab_export_function會放在
“__ksymtab"的section中。對于EXPORT_SYMBOL_GPL和EXPORT_SYMBOL_GPL_FUTURE而言,其struct kernel_symbol實例所在的section名稱則分別為”__ksymtab_gpl"和"__ksymtab_gpl_future")。

我已 nf_conntrack.ko 模塊為例子:

readelf -S nf_conntrack.ko


對這些section的使用需要經過一個中間環節,即鏈接腳本與鏈接器部分。鏈接腳本告訴鏈接器把所有目標文件中的名為“__ksymtab”的section放置在最終內核(或者是內核模塊)映像文件的名為“__ksymtab”的section中(對于目標文件中的名為“__ksymtab_gpl”、“__ksymtab_gpl_future”、“__kcrctab”、“__kcrctab_gpl”和“__kcrctab_gpl_future”的section都同樣處理)。

如下所示:

// linux-4.10.1/include/asm-generic/vmlinux.lds.h/* Kernel symbol table: Normal symbols */ \__ksymtab : AT(ADDR(__ksymtab) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___ksymtab) = .; \KEEP(*(SORT(___ksymtab+*))) \VMLINUX_SYMBOL(__stop___ksymtab) = .; \} \\/* Kernel symbol table: GPL-only symbols */ \__ksymtab_gpl : AT(ADDR(__ksymtab_gpl) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___ksymtab_gpl) = .; \KEEP(*(SORT(___ksymtab_gpl+*))) \VMLINUX_SYMBOL(__stop___ksymtab_gpl) = .; \} \......\/* Kernel symbol table: GPL-future-only symbols */ \__ksymtab_gpl_future : AT(ADDR(__ksymtab_gpl_future) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___ksymtab_gpl_future) = .; \KEEP(*(SORT(___ksymtab_gpl_future+*))) \VMLINUX_SYMBOL(__stop___ksymtab_gpl_future) = .; \} \\/* Kernel symbol table: Normal symbols */ \__kcrctab : AT(ADDR(__kcrctab) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___kcrctab) = .; \KEEP(*(SORT(___kcrctab+*))) \VMLINUX_SYMBOL(__stop___kcrctab) = .; \} \\/* Kernel symbol table: GPL-only symbols */ \__kcrctab_gpl : AT(ADDR(__kcrctab_gpl) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___kcrctab_gpl) = .; \KEEP(*(SORT(___kcrctab_gpl+*))) \VMLINUX_SYMBOL(__stop___kcrctab_gpl) = .; \} \\......\/* Kernel symbol table: GPL-future-only symbols */ \__kcrctab_gpl_future : AT(ADDR(__kcrctab_gpl_future) - LOAD_OFFSET) { \VMLINUX_SYMBOL(__start___kcrctab_gpl_future) = .; \KEEP(*(SORT(___kcrctab_gpl_future+*))) \VMLINUX_SYMBOL(__stop___kcrctab_gpl_future) = .; \} \\/* Kernel symbol table: strings */ \__ksymtab_strings : AT(ADDR(__ksymtab_strings) - LOAD_OFFSET) { \*(__ksymtab_strings) \} \

這里之所以要把所有向外界導出的符號統一放到一個特殊的section里面,是為了在加載其他模塊時用來處理那些“未解決的引用”符號。上述由鏈接腳本定義的幾個變量__start___ksymtab、__stop___ksymtab、__start___ksymtab_gpl、__stop___ksymtab_gpl、__start___ksymtab_gpl_future、__stop___ksymtab_gpl_future等,它們會在對內核或者是某一內核模塊的導出符號表進行查找時用到。

內核源碼中為使用這些鏈接器產生的變量作了如下的聲明:

// linux-4.10.1/kernel/module.c/* Provided by the linker */ extern const struct kernel_symbol __start___ksymtab[]; extern const struct kernel_symbol __stop___ksymtab[]; extern const struct kernel_symbol __start___ksymtab_gpl[]; extern const struct kernel_symbol __stop___ksymtab_gpl[]; extern const struct kernel_symbol __start___ksymtab_gpl_future[]; extern const struct kernel_symbol __stop___ksymtab_gpl_future[]; extern const s32 __start___kcrctab[]; extern const s32 __start___kcrctab_gpl[]; extern const s32 __start___kcrctab_gpl_future[];

內核代碼便可以直接使用這些變量而不會引起編譯錯誤。內核模塊的加載器在處理模塊中“未解決的引用”的符號時,會使用到這里定義的這些變量。

三、模塊導出符號

由前面我們可以知道模塊不僅可以使用內核或者其他模塊導出的符號,而且可以向外部導出自己的符號,模塊導出符號使用的宏和內核導出符號所使用的完全一樣:EXPORT_SYMBOL、EXPORT_SYMBOL_GPL和EXPORT_SYMBOL_FUTURE。

內核模塊會把導出的符號分別放到“__ksymtab”、“__ksymtab_gpl”和“__ksymtab_gpl_future”section中。如果一個內核模塊向外界導出了自己的符號,那么將由模塊的編譯工具鏈負責生成這些導出符號section,而且這些section都帶有A標志,所以在模塊加載過程中會被搬移到CORE section區域中。如果模塊沒有向外界導出任何符號,那么在模塊的ELF文件中,將不會產生這些section。

備注:A (alloc),表示 Section 的屬性,alloc(SHF_ALLOC) 表示 Section 在模塊運行期間需要占據內存。
沒有SHF_ALLOC標志的section,這樣的section最終不占有實際內存地址。

顯然,內核需要對模塊導出的符號進行管理,以便在處理其他模塊中那些“未解決的引用”符號時能夠找到這些符號。內核對模塊導出的符號的管理使用到了struct module結構中如下的成員變量。

內核中為每一個內核模塊都分配了一個struct module實例:

// linux-4.10.1/include/linux/module.hstruct module {....../* Exported symbols */const struct kernel_symbol *syms; //內核模塊導出的符號所在起始地址const s32 *crcs; //內核模塊導出符號的校驗碼所在起始地址unsigned int num_syms; //核模塊導出的符號的數目 ....../* GPL-only exported symbols. */unsigned int num_gpl_syms;const struct kernel_symbol *gpl_syms;const s32 *gpl_crcs;....../* symbols that will be GPL-only in the near future. */const struct kernel_symbol *gpl_future_syms;const s32 *gpl_future_crcs;unsigned int num_gpl_future_syms;...... }

以struct module結構體的 Exported symbols 為例:
const struct kernel_symbol *syms表示:內核模塊導出的符號所在起始地址。
const s32 *crcs表示:內核模塊導出符號的校驗碼所在起始地址。
unsigned int num_syms:表示內核模塊導出的符號的數目。

syms是一個數組,有num_syms個數組項,數組的類型是struct kernel_symbol,負責將表示符name分配到內存地址value。
crcs也是一個有num_syms個數組項的數組,存儲了導出符號的校驗和,用于實現版本控制。

// linux-4.10.1/include/linux/export.hstruct kernel_symbol {unsigned long value;const char *name; };

內核通過調用 find_module_sections函數在Section header table的查找,獲得“__ksymtab”、“__ksymtab_gpl”和“__ksymtab_gpl_future”section在CORE section中的地址,將其記錄在mod->syms、mod->crcs、mod->gpl_syms、mod->gpl_crcs、mod->gpl_future_syms、mod->gpl_future_crcs中,其中 syms表示:內核模塊導出的符號所在起始地址,crcs表示:內核模塊導出符號的校驗碼所在起始地址。如下所示:

// linux-4.10.1/kernel/module.c/* Find a module section: 0 means not found. */ static unsigned int find_sec(const struct load_info *info, const char *name) {unsigned int i;for (i = 1; i < info->hdr->e_shnum; i++) {Elf_Shdr *shdr = &info->sechdrs[i];/* Alloc bit cleared means "ignore it." */if ((shdr->sh_flags & SHF_ALLOC)&& strcmp(info->secstrings + shdr->sh_name, name) == 0)return i;}return 0; }/* Find a module section, or NULL. Fill in number of "objects" in section. */ static void *section_objs(const struct load_info *info,const char *name,size_t object_size,unsigned int *num) {unsigned int sec = find_sec(info, name);/* Section 0 has sh_addr 0 and sh_size 0. */*num = info->sechdrs[sec].sh_size / object_size;return (void *)info->sechdrs[sec].sh_addr; }static int find_module_sections(struct module *mod, struct load_info *info) {......mod->syms = section_objs(info, "__ksymtab",sizeof(*mod->syms), &mod->num_syms);mod->crcs = section_addr(info, "__kcrctab");mod->gpl_syms = section_objs(info, "__ksymtab_gpl",sizeof(*mod->gpl_syms),&mod->num_gpl_syms);mod->gpl_crcs = section_addr(info, "__kcrctab_gpl");mod->gpl_future_syms = section_objs(info,"__ksymtab_gpl_future",sizeof(*mod->gpl_future_syms),&mod->num_gpl_future_syms);mod->gpl_future_crcs = section_addr(info, "__kcrctab_gpl_future");...... }

這樣內核通過這些變量將可得到模塊導出的符號的所有信息,如圖所示:

總結

以上就是Linux 內核中 EXPORT_SYMBOL宏 詳解,有一部分相關內容在模塊的加載過程才能得到體現,這里沒有描述其過程。

參考資料

深入Linux設備驅動程序內核機制
深入Linux內核架構

總結

以上是生活随笔為你收集整理的Linux EXPORT_SYMBOL宏详解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

在线观看视频99 | www.五月婷婷.com| 免费福利在线观看 | 国产精品原创av片国产免费 | 国产在线小视频 | 午夜国产影院 | 91九色视频观看 | 91精品国产92久久久久 | 中文字幕一区二区三区四区久久 | 97视频人人澡人人爽 | 中文字幕在线观看三区 | 色综合久久久久综合体 | 久精品视频免费观看2 | 国产精品色 | 97精品国自产拍在线观看 | 福利视频导航网址 | 精品一区二区在线观看 | av在线播放快速免费阴 | 国产亚洲在线 | 天堂av在线网 | 九九免费在线观看视频 | 婷婷色中文网 | 欧美一区二区三区四区夜夜大片 | 免费黄色在线网址 | 亚洲成人一二三 | 97色综合| 伊人中文网 | 久久精品9 | 日韩艹 | av网址最新| 在线观看国产高清视频 | 正在播放一区 | 成人午夜精品久久久久久久3d | 特级黄色片免费看 | 久久人人爽人人爽 | 亚洲精品大全 | 国产亚洲免费的视频看 | 色婷婷啪啪免费在线电影观看 | 美女视频黄的免费的 | 在线观看欧美成人 | 久久精品一区二区三 | 国产91成人 | 狠狠久久伊人 | 人人爽影院 | 日韩欧美高清视频在线观看 | 狠狠色狠狠色终合网 | 99精品福利 | 黄色在线免费观看网址 | 午夜精品一区二区三区视频免费看 | 色的网站在线观看 | 亚洲美女视频在线观看 | 99视频国产在线 | 亚洲人成人天堂h久久 | 久久y| 激情综合五月天 | 免费观看第二部31集 | 69视频国产 | 久久国产露脸精品国产 | 99精品视频在线观看视频 | 国内久久看 | 在线日韩中文 | av怡红院| 狠狠狠狠狠狠狠狠干 | 青青河边草免费观看 | 成 人 黄 色 片 在线播放 | 国产一级不卡毛片 | 久久久精品国产免费观看同学 | 91精品一区国产高清在线gif | 亚洲高清资源 | 国产剧情av在线播放 | 综合黄色网| 天天干天天操天天射 | 国产在线欧美日韩 | 免费日韩电影 | 人人澡超碰碰97碰碰碰软件 | 国产手机在线视频 | 日本精品久久久久影院 | 97超碰伊人 | 婷婷六月天丁香 | 丁香婷婷激情 | 字幕网av| 欧美日韩99 | 人人超碰人人 | 男女精品久久 | 美女网站黄免费 | 91精品久久久久久 | 日韩精品免费一区二区 | 日韩中文字幕免费视频 | 久久精品—区二区三区 | 最新av在线播放 | 国产99久久久精品 | 激情文学综合丁香 | 91网站在线视频 | 亚洲少妇自拍 | 亚洲成人动漫在线观看 | 亚洲成人xxx | 不卡的av在线 | 久久99国产综合精品免费 | 精品国产视频在线观看 | 九九视频免费在线观看 | 一级久久精品 | 又黄又爽又无遮挡的视频 | 日韩久久精品一区二区 | 久草在线免费资源站 | 日韩精品在线视频 | 国产在线一区二区 | 欧美男女爱爱视频 | 久久久久久久精 | 亚洲精品玖玖玖av在线看 | 成人免费在线播放视频 | 中文字幕在线视频一区二区 | 亚洲欧美精品在线 | 99精品视频在线观看播放 | 欧美视频一区二 | 97国产超碰 | 黄av免费在线观看 | 午夜18视频在线观看 | 亚洲成人黄色av | 日本成址在线观看 | 免费成人黄色av | av电影亚洲 | 草在线 | 亚洲日b视频 | 久久久久免费观看 | 97影视| a视频在线观看免费 | 久色婷婷| 97在线观视频免费观看 | 综合久久久 | 日韩欧美视频免费看 | 久久久久国产一区二区 | 成年人电影免费在线观看 | 97超碰在线人人 | 久久久久久久综合色一本 | 91综合视频在线观看 | 欧美在线观看视频免费 | 日韩久久精品一区二区三区下载 | 国产xx在线 | 九色porny真实丨国产18 | 免费三级黄色 | 丁香六月婷 | 免费av网址在线观看 | 国产一级片观看 | 国产精品欧美日韩在线观看 | 在线免费观看av网站 | a在线观看国产 | 青青草久草在线 | 亚洲国产精品电影 | 国产成人免费精品 | 国产丝袜美腿在线 | 久草精品视频 | 免费av在 | 欧美性超爽 | 91久久国产露脸精品国产闺蜜 | 最新av在线免费观看 | 久久视频国产精品免费视频在线 | 在线观看日韩av | 九九热在线免费观看 | 国产精品乱码久久久 | 天天色天 | 午夜黄色影院 | 国产精品成人免费一区久久羞羞 | www.五月婷 | 江苏妇搡bbbb搡bbbb | 96香蕉视频 | 天天草天天干天天 | 色欧美成人精品a∨在线观看 | 国产特级毛片aaaaaa高清 | 天堂在线免费视频 | 在线一区二区三区 | 视频一区在线播放 | 99视频黄 | 国产在线精品一区二区不卡了 | 国产精品99久久久久久有的能看 | 久久视频网 | 成人在线视频免费观看 | 婷婷99 | 色狠狠干| 免费观看v片在线观看 | 天干啦夜天干天干在线线 | 中文字幕亚洲字幕 | 成人在线视频论坛 | 国产亚洲精品久久久久久大师 | 成人在线黄色 | 在线香蕉视频 | 伊人中文字幕在线 | 一级片观看 | 欧美精品在线观看免费 | 丁香六月天 | 激情欧美日韩一区二区 | 999国产| 国产精品网红直播 | 国产欧美在线一区二区三区 | 亚洲另类视频在线 | 亚洲黄色片| 欧美最新大片在线看 | 天堂av色婷婷一区二区三区 | 99精品在线 | 国产大尺度视频 | 欧美一区二区三区在线观看 | 久久99九九99精品 | 月下香电影 | 国产精品男女啪啪 | 有没有在线观看av | 中文字幕高清有码 | 天天射一射 | 视频在线91 | 六月丁香激情综合 | 国产精品麻豆三级一区视频 | 成人小视频在线观看免费 | www.五月天激情 | 在线视频 你懂得 | 久久国产手机看片 | 伊人亚洲综合网 | 亚洲第一区在线播放 | 国产精品成人一区二区三区吃奶 | 精品视频123区在线观看 | 美女在线免费视频 | 狠狠躁日日躁狂躁夜夜躁 | 成人午夜精品久久久久久久3d | 婷婷丁香狠狠爱 | 欧美一级片在线免费观看 | 欧美日韩调教 | 亚洲永久国产精品 | 国产亚洲欧美日韩高清 | 亚洲aⅴ乱码精品成人区 | 日韩在线播放欧美字幕 | 久久er99热精品一区二区三区 | 亚洲综合视频在线 | 五月天综合网 | 国产自在线观看 | 免费国产视频 | 在线亚洲欧美视频 | 日韩啪啪小视频 | 在线视频精品播放 | 欧美另类巨大 | 色网站在线免费 | 国产精品欧美在线 | 国产日韩欧美在线看 | 国产又粗又猛又爽又黄的视频免费 | 亚洲国产黄色 | 国产黄色免费观看 | 91成人精品| 特级西西444www高清大视频 | 毛片网站观看 | 国产午夜在线观看 | 国产精品12345| 69久久99精品久久久久婷婷 | 久久99久久99久久 | 成人午夜av电影 | 日韩午夜在线播放 | 西西44人体做爰大胆视频 | 香蕉久久国产 | 五月婷婷在线综合 | 久久亚洲视频 | 国产一二三四在线观看视频 | 久热只有精品 | 日本中文字幕影院 | 成人综合婷婷国产精品久久免费 | 色 中文字幕 | 天天看天天操 | 最近免费中文字幕大全高清10 | 久久观看 | 国产原创av在线 | 日本黄网站| 精品国产亚洲在线 | 日韩不卡高清 | 亚洲三级性片 | 在线va网站 | 91麻豆精品久久久久久 | 蜜臀aⅴ国产精品久久久国产 | 五月天精品视频 | 久久99久久99免费视频 | 天天要夜夜操 | 日韩在线三区 | 四虎在线免费观看 | 99视频一区 | 欧美日韩中文在线观看 | 午夜视频黄 | 欧美性黑人 | 国产一区二区三区免费在线观看 | 一区二区三区四区五区在线 | 久久精品视频国产 | 在线观看国产www | 日韩午夜精品 | 91视频这里只有精品 | 欧美先锋影音 | 午夜影视剧场 | 五月婷丁香网 | 91女子私密保健养生少妇 | 日本少妇视频 | 美女视频黄的免费的 | 玖玖爱免费视频 | 欧美激情奇米色 | 天天射色综合 | 国偷自产视频一区二区久 | 麻豆影视在线免费观看 | 亚洲1区在线 | 亚洲永久国产精品 | 欧美精品久久久久久久亚洲调教 | 九九九热精品免费视频观看 | 国产69精品久久久久久久久久 | 一区二区三区久久精品 | 毛片美女网站 | av电影av在线 | 久久福利影视 | 午夜影院先 | 久久超| 天天爽天天射 | 天天爽夜夜爽人人爽曰av | 在线免费黄网站 | 国产999精品久久久久久绿帽 | 在线观看欧美成人 | 五月天激情婷婷 | 国内精品中文字幕 | 中文字幕日韩免费视频 | 国产伦精品一区二区三区免费 | 国产高清av | 在线看的av网站 | 日韩免费一区二区在线观看 | 免费看黄色毛片 | 9热精品| 久草网首页 | 国模一二三区 | www.午夜视频 | 五月综合网 | 九九热免费精品视频 | 久草在线综合 | 91久久电影| 免费a级黄色毛片 | 九色在线视频 | www.亚洲视频 | 亚洲涩综合 | 亚洲va欧美va人人爽 | 99久久综合精品五月天 | 91在线91| av在线免费播放网站 | 最近中文字幕在线 | 中文字幕在线观看视频一区 | 97免费公开视频 | 免费看的国产视频网站 | 99久久久久| 91污污视频在线观看 | 久久午夜电影院 | 欧美婷婷色 | 在线观看久久久久久 | 久久亚洲婷婷 | 91麻豆精品国产自产在线游戏 | 国产成人a v电影 | 一本一本久久a久久精品综合妖精 | 亚洲精品乱码久久久久 | 亚洲精品久久久久www | 久久成人毛片 | 91高清视频在线 | 色干综合 | 开心激情网五月天 | 国产高清99 | 五月婷久| 国产成人一区二区三区电影 | 青青河边草免费 | 久久久久久久久久免费视频 | 午夜久久影视 | 视频国产一区二区三区 | 在线国产精品一区 | 黄色软件在线观看免费 | 亚洲色图av| 亚洲精品一区二区网址 | 日本久久免费视频 | 97国产一区二区 | 免费观看全黄做爰大片国产 | 啪啪肉肉污av国网站 | 亚洲最新在线 | 久久久久久草 | 99视频久| 特级a毛片 | 成人国产精品电影 | 综合伊人av | 日本久草电影 | 91女神的呻吟细腰翘臀美女 | 欧美日韩久久不卡 | 免费精品人在线二线三线 | 黄色成人在线 | 午夜久久久久久久久 | 国产精品久久久久久久久久尿 | 中文字幕亚洲精品在线观看 | 又长又大又黑又粗欧美 | 9在线观看免费高清完整 | 国产精品人成电影在线观看 | 国产私拍在线 | 97在线看 | 99精品免费视频 | 中文字幕亚洲字幕 | 免费观看一级 | 国产精品国内免费一区二区三区 | 五月天婷婷在线观看视频 | 欧美日韩免费一区二区 | 亚洲精品视频网 | 欧美日韩久久不卡 | 国产日韩高清在线 | 97超碰人人看 | 日韩免费观看一区二区三区 | 成人小视频在线免费观看 | 天天艹天天 | 91私密视频 | 国产大陆亚洲精品国产 | 激情九九| 久久精精品视频 | 97电影在线看视频 | 91精品啪在线观看国产线免费 | 中文字幕一区二区三区在线视频 | 中文亚洲欧美日韩 | 久久久久久久毛片 | 日韩激情第一页 | 久久久久综合精品福利啪啪 | 成人高清在线 | 99视频在线观看一区三区 | 免费国产一区二区 | 五月婷激情 | 亚洲片在线观看 | 免费观看性生交 | 91av免费看 | 国产精品系列在线观看 | 青青草在久久免费久久免费 | 国产欧美精品xxxx另类 | 人人澡人人添人人爽一区二区 | 中文一区在线观看 | 久久久久久久毛片 | 国产高清在线观看 | 99视频久久| 国产精品va在线播放 | 97av免费视频 | 四虎在线永久免费观看 | 999久久久 | 成年人黄色免费视频 | 欧美精品国产综合久久 | 波多野结衣在线播放视频 | 日韩精品视频免费专区在线播放 | 日日操日日| 天堂视频中文在线 | 久久综合五月天 | 在线观看日韩视频 | 中文字幕在线观看资源 | 久草视频在线免费看 | 久久99国产精品久久99 | 久久久久久久久久久久久久免费看 | 久久久久国产a免费观看rela | 国产视频在线播放 | 亚洲午夜精品一区二区三区电影院 | 五月天激情电影 | 在线视频精品播放 | 国产日韩欧美视频 | 日韩精品大片 | 成人国产精品免费 | 国产丝袜网站 | 亚洲资源 | 成人av电影免费在线播放 | 超碰97人人在线 | 最近中文字幕国语免费av | 国产精品av久久久久久无 | 国产大片黄色 | 美女视频久久 | 成人午夜电影在线播放 | 日韩免费在线网站 | 91成人网在线 | 精品国产不卡 | 成人久久影院 | 国产精品系列在线观看 | 亚洲激情 在线 | 亚洲精品乱码久久久久久蜜桃91 | 日本久久成人中文字幕电影 | 香蕉视频久久 | 夜夜爽夜夜操 | 欧美在线观看禁18 | 一级黄网| 一级特黄aaa大片在线观看 | 在线免费观看国产精品 | 国产免费亚洲 | 不卡av电影在线观看 | av888av.com| 久久久久9999亚洲精品 | 亚洲免费观看在线视频 | 久草久草在线 | 亚洲视频免费在线观看 | 最新色视频 | 久久国产视屏 | 最近中文字幕高清字幕在线视频 | 亚洲精品乱码白浆高清久久久久久 | 91最新国产 | 久久久久久久久影院 | 亚洲精品美女在线观看播放 | 婷婷丁香九月 | 日韩特级黄色片 | 国产视频在线观看一区 | 中文字幕精品一区久久久久 | 免费黄a| 91在线视频精品 | 最近2019中文免费高清视频观看www99 | 欧美成人一区二区 | 亚洲一区av | 91视频大全 | 国产精品免费观看网站 | 在线免费性生活片 | 精品一区二区三区久久 | 亚洲精品在线视频网站 | 夜夜骑首页 | 成人免费在线看片 | 国产最新在线视频 | av在线永久免费观看 | 欧美日韩中文字幕综合视频 | 亚洲激情在线视频 | 成片免费观看视频999 | www操操 | 精品国产一区二区三区蜜臀 | 欧美精品一二 | 国产无限资源在线观看 | 亚洲狠狠丁香婷婷综合久久久 | av动态图片 | 色婷婷免费视频 | 久久九九影视网 | 热久久免费视频精品 | av电影久久| 97电影在线看视频 | 免费在线a| 国产精品久久久久久久久久久久午夜 | 中文字幕在线播放一区二区 | 午夜视频在线观看欧美 | 免费av大全| 五月天网站在线 | 成人精品国产免费网站 | 日日操网| 国产精品女| 免费在线黄网 | 伊人久久五月天 | 99一级片| 日韩一区二区免费播放 | 日韩高清在线不卡 | 日韩欧美视频一区二区三区 | 国产精品日韩高清 | 在线性视频日韩欧美 | 四虎国产精品免费观看视频优播 | 91豆花在线| 4438全国亚洲精品在线观看视频 | 日本久久免费视频 | 免费观看国产成人 | 国产精品毛片一区二区在线 | av资源网在线播放 | 国产在线观看二区 | 99久久久久免费精品国产 | 最近中文字幕免费 | 国产精品黄色影片导航在线观看 | 亚洲精品视频在线 | av高清不卡 | 天天狠狠 | 99久久精品国产一区二区三区 | 日韩免费精品 | 久久久在线免费观看 | 成人黄色在线观看视频 | 蜜臀av性久久久久av蜜臀三区 | 夜夜澡人模人人添人人看 | 精品日韩中文字幕 | 黄色国产高清 | 日韩一二三区不卡 | 一级做a爱片性色毛片www | 99视频精品全国免费 | 亚洲在线观看av | 丁香激情网 | 国产手机精品视频 | 一级片免费观看 | 成年人在线观看网站 | 午夜精品影院 | 四虎国产精品永久在线国在线 | 成人影片免费 | 激情五月播播久久久精品 | 91色国产| 国产成人精品av | 国产精品国产亚洲精品看不卡 | 人人干人人艹 | 91成人天堂久久成人 | 国产一级二级在线观看 | 九九免费精品视频 | 久久精品99国产精品日本 | 韩日成人av | 天天曰天天爽 | 偷拍区另类综合在线 | 久久超碰免费 | 你操综合 | 久久久国产精品久久久 | 免费亚洲成人 | 中文字幕在线观看2018 | 国产婷婷一区二区 | 91亚洲综合 | 久久成人欧美 | 亚洲高清激情 | 国产黄色观看 | 在线视频观看91 | 中文字幕亚洲欧美 | 一区二区三区免费在线观看视频 | 欧亚日韩精品一区二区在线 | 最新国产精品久久精品 | 一本色道久久综合亚洲二区三区 | 精品国产亚洲在线 | 一区 二区 精品 | 国产1区2区| 国产一区精品在线 | 久久成人18免费网站 | 久在线观看视频 | 亚洲成人软件 | 亚洲成人黄色av | 久久亚洲专区 | 国产一区免费看 | a在线一区 | 中文视频在线播放 | 有码视频在线观看 | 国产成人精品一区二区在线 | 成人国产精品久久久久久亚洲 | 亚洲国产视频直播 | 国产午夜精品福利视频 | 500部大龄熟乱视频使用方法 | 日韩av电影免费在线观看 | 欧美亚洲xxx | 91精品视频免费在线观看 | 成人久久久久久久久久 | www黄com| 91精品999| 免费在线成人 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 九色在线视频 | 亚洲在线视频免费观看 | 日韩手机视频 | 九九色在线观看 | 国产成人精品一区二区在线 | 欧美精品一区二区三区一线天视频 | 美女精品网站 | 国产精品美女视频网站 | 天堂av在线免费观看 | 久草资源在线 | 韩国av免费观看 | 国产精品a久久 | 天天操天天摸天天射 | 国产亚洲激情视频在线 | 婷婷5月激情5月 | 国产亚洲日本 | 国产精品专区h在线观看 | 日韩欧美精品在线观看视频 | 久久久国产精品一区二区中文 | 欧美福利网址 | 欧美久久久久久久久久久久久 | 18国产精品白浆在线观看免费 | 国产精品久久久99 | 久久久久观看 | 国产精品人成电影在线观看 | 久久久久免费精品国产 | 在线观看日韩一区 | 欧女人精69xxxxxx | 国产又黄又爽又猛视频日本 | 久久亚洲精品国产亚洲老地址 | 亚洲日本三级 | 亚洲三级在线免费观看 | 国产精品久久久久久电影 | 国产亚洲精品女人久久久久久 | 天天操欧美 | 97免费在线观看视频 | 香蕉影院在线 | 精品福利在线视频 | 四虎在线影视 | 成人久久精品视频 | 色偷偷网站视频 | 高清一区二区三区av | 日韩中文字幕免费在线观看 | 超碰日韩 | 欧美一区在线看 | 成人蜜桃视频 | 成人a级网站 | 天天操天天干天天操天天干 | 夜夜夜夜猛噜噜噜噜噜初音未来 | 免费日韩一区二区三区 | 天天综合网久久 | 中文字幕在线播放一区二区 | 亚洲另类在线视频 | 色婷婷a | 午夜精品一区二区三区在线播放 | 日本女人在线观看 | 精品av在线播放 | 91在线国产观看 | 日韩激情精品 | 婷婷久久网| 91激情小视频 | 久久国产系列 | 麻豆视频免费看 | 免费观看v片在线观看 | 成人黄色影片在线 | 亚州国产视频 | av免费网站在线观看 | 97视频在线观看免费 | 91精品久久久久久综合乱菊 | 色婷久久 | 免费观看性生活大片3 | 国产成人高清 | 91禁看片 | 成人91免费视频 | 欧美性大战久久久久 | 99欧美精品 | 国产精品密入口果冻 | 精品一区二区6 | 久久在线精品视频 | 婷婷视频在线观看 | 人人插人人 | 国产在线更新 | 日韩亚洲国产中文字幕 | 在线观看www. | 久久国产亚洲视频 | 天堂av免费 | 一区二区视频电影在线观看 | 色婷婷久久久 | 黄色午夜网站 | www.伊人色.com | 欧美精品一二 | 国产亚洲精品免费 | 日韩欧美在线综合网 | 婷色| 久草在线费播放视频 | 久久精品a | 久久伊99综合婷婷久久伊 | 天天舔夜夜操 | 中中文字幕av | 香蕉视频国产在线 | 探花视频免费在线观看 | 91视频国产高清 | 成人激情开心网 | 亚洲欧洲一区二区在线观看 | 狠狠操狠狠操 | a在线免费观看视频 | 狠狠婷婷 | 日韩av免费在线电影 | 中文亚洲欧美日韩 | 深夜精品福利 | 91亚洲在线 | 黄色片网站大全 | 欧美一级性生活 | 玖玖在线精品 | 成人免费观看在线视频 | 亚洲电影一级黄 | 亚洲五月花| 国产又粗又猛又色 | 国产午夜精品久久 | 天天艹日日干 | 久久婷婷精品 | 国产精品理论视频 | 97在线观看免费高清完整版在线观看 | 久久综合五月 | 久久国产色 | 99热精品国产一区二区在线观看 | 91香蕉视频黄 | 99久久久久久国产精品 | 最新国产在线 | 国产精品久久久久久久久久久久午夜 | 日韩中文字幕免费在线播放 | av字幕在线 | 日韩av一区二区三区 | 高清有码中文字幕 | 日本久久久久久 | 午夜av激情 | 中文字幕在线观看第三页 | 欧美亚洲精品一区 | 日韩av电影免费在线观看 | 日韩激情一二三区 | 国产精品视频专区 | 国产精品美女www爽爽爽视频 | 麻豆mv在线观看 | 国产美女精品视频免费观看 | 在线国产不卡 | 超碰人在线 | 亚洲一区 影院 | 天天爽天天爽 | 久久婷婷五月综合色丁香 | 亚洲免费资源 | 天天曰天天曰 | 国产一区不卡在线 | 日本女人的性生活视频 | 久久艹精品 | 国产精品视频资源 | 69热国产视频 | 国产麻豆精品传媒av国产下载 | 97狠狠操 | 在线播放视频一区 | 日韩精品视频在线观看免费 | 国产免费成人 | 国产精品永久久久久久久www | 国产免费久久久久 | 免费国产在线观看 | 亚洲成人影音 | 六月丁香久久 | 久久精品综合视频 | 在线观看黄色的网站 | 一区二三国产 | 精品国产伦一区二区三区观看说明 | 欧美精品免费在线观看 | 久久免费视频网站 | 午夜久久视频 | 黄色午夜网站 | 成人污视频在线观看 | 欧美一级视频在线观看 | 亚洲综合色婷婷 | 色婷婷综合久久久久中文字幕1 | av成人免费在线看 | 久久精品99国产精品 | 久久国产精彩视频 | 99久久精品无码一区二区毛片 | 丁香婷五月 | 欧美精品亚洲精品日韩精品 | 欧美久久综合 | 国产美腿白丝袜足在线av | 国产成人精品一区二区三区网站观看 | 99久久久久久久 | 中文字幕在线国产精品 | 日韩黄色网络 | 日韩特级片 | 男女拍拍免费视频 | 亚洲视频精选 | 久久手机看片 | 日韩欧美电影在线 | 久热香蕉视频 | 精品一区精品二区高清 | 韩国在线视频一区 | 久久字幕 | 国产综合婷婷 | 欧美激情在线看 | 色网站黄 | 亚洲精品在线免费 | 亚洲资源视频 | 香蕉视频在线免费 | www.久久91 | 亚洲成a人片77777kkkk1在线观看 | 91成人区 | 亚洲一级黄色片 | 丁香婷婷社区 | 亚洲一级片在线看 | 成人av电影免费在线观看 | 久草在线一免费新视频 | 国产又粗又硬又长又爽的视频 | 久久国产高清视频 | 久久国产精品一区二区三区四区 | 国产成人精品久久亚洲高清不卡 | 伊人在线视频 | 精品国产99国产精品 | 欧美亚洲免费在线一区 | 国产成人综合在线观看 | 91黄在线看 | 91人人干 | 中文字幕91在线 | 亚洲精品乱码白浆高清久久久久久 | 日韩福利在线观看 | 99精品在线观看视频 | 高清不卡一区二区三区 | 色婷婷五 | 五月天色中色 | 精品视频www | 国产色道 | 四虎在线观看网址 | 天天操天天射天天 | 日操干| 亚洲综合五月 | 香蕉视频导航 | 欧美成年网站 | 一 级 黄 色 片免费看的 | 欧美一级艳片视频免费观看 | 久久国产精品久久w女人spa | 久久成人精品视频 | 综合精品在线 | 久久激情视频免费观看 | 欧美日韩精品影院 | 黄色大片日本免费大片 | 色噜噜狠狠狠狠色综合久不 | 国产精品精品国产 | 91漂亮少妇露脸在线播放 | 久久99这里只有精品 | 欧美永久视频 | 久久久久亚洲天堂 | 2019中文 | 色婷婷亚洲婷婷 | 五月婷婷综合在线 | 在线观看福利网站 | 视频在线观看日韩 | 午夜久久美女 | 国产免费三级在线观看 | 国产精品igao视频网入口 | 久久永久免费视频 | 日韩超碰在线 | 日韩精品一区二区三区第95 | 婷婷精品国产欧美精品亚洲人人爽 | 精品字幕在线 | 久久久综合九色合综国产精品 | 黄色影院在线免费观看 | 99精品视频在线看 | 深爱激情综合 | 99国产成+人+综合+亚洲 欧美 | 日韩免费不卡av | 97理论片 | 日韩一区在线播放 | 国产99一区| 国产福利免费看 | 日本不卡视频 | 免费成人在线网站 | 91电影福利 | 免费在线精品视频 | 亚洲精品视频在线观看视频 | 人人爽人人做 | 亚洲欧美日韩国产一区二区 | 日韩中文免费视频 | 亚洲涩涩网站 | 婷婷在线精品视频 | 在线a人v观看视频 | 69精品在线 | 亚洲国产中文字幕在线视频综合 | 国产成年人av | 91精品在线免费视频 | 欧美另类重口 | 伊人宗合网 | 99在线观看视频网站 | 中文字幕有码在线播放 | 欧美久久久久久久久久久久 | 成年人在线视频观看 | 天天色棕合合合合合合 | 激情影音先锋 | 久久国产精品成人免费浪潮 | 亚洲国产欧美在线人成大黄瓜 | 成人黄色短片 | 狠狠躁日日躁狂躁夜夜躁 | 国产精品一区二区在线免费观看 | 西西www4444大胆在线 | 久久香蕉电影网 | 精品久久片 | 成人一区电影 | 在线观看韩日电影免费 | 国产精品理论在线观看 | 手机在线日韩视频 | 婷婷五月色综合 | 国产一区国产精品 | 日韩欧美一区二区三区在线观看 | 狠狠的日日 | 色噜噜狠狠狠狠色综合 | 亚洲黄在线观看 | 99久久99视频只有精品 | 国产精品久久久久永久免费看 | 91精品国产自产在线观看 | 天天爱天天干天天爽 | 免费网站在线观看成人 | 日韩性xxx| 麻豆极品 | 精品福利网站 | 成片免费观看视频999 | 免费一级片观看 | 波多野结衣在线中文字幕 | 亚洲老妇xxxxxx | 久久精品中文视频 | 亚洲一区二区视频在线播放 | 蜜臀久久99精品久久久久久网站 | 日韩影视精品 | 久久九九视频 | 久久久国产精品亚洲一区 | 久久久久亚洲精品国产 | 去看片| 99资源网 | 国产一级在线免费观看 | 蜜臀av夜夜澡人人爽人人 | 在线看黄色av | 人人澡人 | 亚洲精品ww | 狠狠色综合欧美激情 | 97精品国产一二三产区 | 99久热精品 | 亚洲最大av | 日本激情动作片免费看 | 探花在线观看 | 久草在线91 | 香蕉在线观看视频 | 一区二区三区日韩在线观看 | 天天操天天能 | 久久精品91久久久久久再现 | 九九九九免费视频 | 亚洲永久av| 狠狠操精品 | 区一区二在线 | 手机av在线网站 | 婷婷丁香色 | 青草视频免费观看 | 婷婷免费在线视频 | 欧美一级片在线播放 | 欧美一级特黄高清视频 | 日韩欧美xxxx | 国产在线自 | 国产真实在线 | 亚洲精区二区三区四区麻豆 | 天天操天天操天天操天天 | 九九免费精品视频在线观看 | 97在线观看免费 | 日韩三级av | 国产精品不卡在线 |