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

計算機大佬讓你徹底了解"深入理解計算機系統"

開發
本文將對鏈接過程做一個講解,了解鏈接的過程,可以幫助你理解計算機系統的底層原理,并解答你平時關于計算機怎樣識別并執行程序的一些疑惑。

前言

當我們點擊Xcode的運行按鈕時,你會注意到在界面頂端的提示欄上會出現“Building”的字樣,緊接著會出現“Linking”的字樣,我們知道Building是編譯過程,那這個Linking(鏈接)是什么過程呢?本文將對鏈接過程做一個講解,了解鏈接的過程,可以幫助你理解計算機系統的底層原理,并解答你平時關于計算機怎樣識別并執行程序的一些疑惑。另外,本文也是后續篇章的基礎,我們會由鏈接的知識延展出Mach-O文件、fishhook原理以及hook objc_msgSend的知識講解。

鏈接的基本概念

鏈接(linking)是將各種代碼和數據片段收集并組合成為一個單一文件的過程,這個文件可被加載(復制)到內存并執行。

鏈接可以執行與編譯時(complie time),也就是源代碼被翻譯成機器代碼時;也可以執行于加載時(load time),也就是在程序被加載器(load-er)加載到內存并執行時;甚至可以執行在運行時(run time),也就是由應用程序來執行。在早期的計算機系統中,鏈接是手動執行的。在現代系統中,鏈接是由叫做連接器(linker)的程序自動執行的。

鏈接的作用

鏈接器使分離編譯成為可能,我們不用將一個大型的應用程序組織為一個巨大的源文件,而是可以把它分解為更小、更好管理的模塊,可以獨立地修改和編譯這些模塊。當我們改變這些模塊中的一個時,只需簡單地重新編譯它,并重新鏈接應用,而不必重新編譯其它文件。

下面的討論基于這樣的環境:一個運行Linux的x86-64系統,使用標準的ELF-64目標文件格式。

編譯器驅動程序

下面的C語言示例程序,由兩個源文件組成,main.c和sum.c。main函數初始化一個整數數組,然后調用sum函數來對數組元素求和。

// sum.c

int sum(int *a, int n) {
int s = 0;
for (int i = 0; i < n; i++) {
s += a[i];
}
return s;
}

// main.c

int array[2] = {1, 2};

int main() {
int val = sum(array, 2);
return val;
}

大多數的編譯系統會提供編譯器驅動程序(compile driver),包含語言預處理器、編譯器、匯編器和鏈接器。首先編譯器驅動程序會對main.c與sum.c文件的源代碼進行翻譯,翻譯過程如下:

其中,main.o稱為可重定位目標文件。

之后,編譯系統會運行鏈接器ld,將main.o和sum.o以及一些必要的系統目標文件組合起來,創建一個可以執行目標文件,這個過程是靜態鏈接,過程如下:

再之后,操作系統會調用加載器(loader),將可執行文件prog中的代碼和數據復制到內存中,然后執行。

靜態鏈接

靜態鏈接器(static linker)以一組可重定位目標文件作為輸入,生成一個完全鏈接的、可以加載和運行的可執行目標文件。輸入的可重定位目標文件由各種不同的代碼和數據節(section)組成,每一節都是一個連續的字節序列。指令在一節中,初始化了的全局變量在另一個節中,而未初始化的變量又在另外一節中。

為了構造可執行文件,鏈接器必須完成兩個重要的任務:

  • 符號解析(symbol resolution)。目標文件定義和引用符號,一個個符號對應一個函數或一個全局變量或一個靜態變量(即C語言中以static屬性聲明的變量)。符號解析的目的是將每個符號引用正好和一個符號定義關聯起來。
  • 重定位(relocation)。編譯器和匯編器生成從地址0開始的代碼和數據節。鏈接器通過把每個符號定義與一個內存位置關聯起來,從而重定位這些節,然后修改所有對這些符號的引用,使它們指向這個內存位置。

目標文件純粹是字節塊的集合,這些塊中,有些包含程序代碼,有些包含數據,而有些則是引導鏈接器和加載器的數據結構。鏈接器將這些塊連接起來,確定被連接塊的運行時位置,并且修改代碼和數據塊中的各種位置。

目標文件

目標文件有三種形式:

  • 可重定位目標文件。包含二進制代碼和數據,其形式可以在編譯時與其他可重定位目標文件合并起來,創建一個可執行目標文件。
  • 可執行目標文件。包含二進制代碼和數據,其形式可以被直接復制到內存并執行。
  • 共享目標文件。一種特殊類型的可重定位目標文件,可以在加載或者運行時被動態的加載進內存并鏈接。動態庫就是這種形式的。

目標文件的生成方式:

  • 編譯器和匯編器生成可重定位目標文件(包括共享目標文件)。
  • 鏈接器生成可執行目標文件。

目標文件的格式:

  • 在iOS和MacOS-X中,目標文件的格式是Mach-O格式。
  • X86-64 Linux和Unix系統使用可執行可連接格式ELF。

可重定位目標文件

下上展示了一個典型的ELF可重定位目標文件的格式。ELF頭包含很多信息,包括生成該文件的系統的字節大小,字節順序,ELF頭的大小,目標文件的類型,機器類型等等。節頭部表描述了不同節的位置和大小。

加載ELF頭和節頭部表的是節:

  • .text:已編譯程序的機器代碼。
  • .rodata:只讀數據,比如 printf語句中的格式串和開關語句的跳轉表。
  • .data:已初始化的全局和靜態C變量。局部C變量在運行時被保存在棧中,既不出現在,data節中,也不出現在.bss節中
  • .bss:未初始化的全局和靜態C變量,以及所有被初始化為0的全局或靜態變量。在目標文件中這個節不占據實際的空間,它僅僅是一個占位符。目標文件格式區分已初始化和未初始化變量是為了空間效率:在目標文件中,未初始化變量不需要占據任何實際的磁盤空間。運行時,在內存中分配這些變量,初始值為0。
  • .symtab:一個符號表,它存放在程序中定義和引用的函數和全局變量的信息。一些程序員錯誤地認為必須通過-g選項來編譯一個程序,才能得到符號表信息。實際上,每個可重定位目標文件在. symtab中都有一張符號表(除非程序員特意用 STRIP命令去掉它)。然而,和編譯器中的符號表不同, symtab符號表不包含局部變量的條目。
  • .rel.text:一個.text節中位置的列表,當鏈接器把這個目標文件和其他文件組合時,需要修改這些位置。一般而言,任何調用外部函數或者引用全局變量的指令都需要修改。另一方面,調用本地函數的指令則不需要修改。注意,可執行目標文件中并不需要重定位信息,因此通常省略,除非用戶顯式地指示鏈接器包含這些信息。
  • .rel.data:被模塊引用或定義的所有全局變量的重定位信息。一般而言,任何已初始化的全局變量,如果它的初始值是一個全局變量地址或者外部定義函數的地址,都需要被修改。
  • .debug:一個調試符號表,其條目是程序中定義的局部變量和類型定義,程序中定義和引用的全局變量,以及原始的C源文件。只有以-g選項調用編譯器驅動程序時,才會得到這張表。
  • .line:原始C源程序中的行號和.text節中機器指令之間的映射。只有以-g選項調用編譯器驅動程序時,才會得到這張表。
  • .strtab:一個字符串表,其內容包括. symtab和, debug節中的符號表,以及節頭部中的節名字。字符串表就是以nu11結尾的字符串的序列。

符號和符號表

每個可重定位目標模塊(目標文件)m都有一個符號表,它包含m定義和引用的符號的信息。在鏈接器的上下文中,有三種不同的符號:

  • 由模塊m定義并能被其它模塊引用的全局符號。這些符號對應于非靜態的C函數和全局變量。
  • 由其它模塊定義并被模塊m引用的全局符號。這些符號稱為外部符號,對應于在其它模塊中定義的非靜態C函數和全局變量。
  • 只被模塊m定義和引用的局部符號。它們對應于帶static屬性的C函數和全局變量。這些符號在模塊m中任何位置都可見,但是不能被其它模塊引用。

.symtab中的符號表不包含非靜態程序變量的任何符號,這些程序變量符號在棧中被管理,鏈接器對此類符號不感興趣。

如何解析多重定義的全局符號

鏈接器的輸入是一組可重定位目標模塊。每個模塊定義一組符號,有些是局部的(只對定義該符號的模塊可見),有些是全局的(對其他模塊也可見)。如果多個模塊定義同名的全局符號,會發生什么呢?下面是 Linux編譯系統采用的方法。

在編譯時,編譯器向匯編器輸出每個全局符號,或者是強( strong)或者是弱(weak),而匯編器把這個信息隱含地編碼在可重定位目標文件的符號表里。函數和已初始化的全局變量是強符號,未初始化的全局變量是弱符號。

根據強弱符號的定義,Linux鏈接器使用下面的規則來處理多重定義的符號名

  • 規則1:不允許有多個同名的強符號。
  • 規則2:如果有一個強符號和多個弱符號同名,那么選擇強符號。
  • 規則3:如果有多個弱符號同名,那么從這些弱符號中任意選擇一個。

靜態庫

迄今為止,我們都是假設鏈接器讀取一組可重定位目標文件,并把它們鏈接起來,輸出一個可執行目標文件。實際上,所有的編譯系統都提供一種機制,將所有相關的目標模塊打包成一個單獨的文件,稱為靜態庫。靜態庫可以用做鏈接器的輸入,當鏈接器構造一個輸出的可執行目標文件時,它只復制靜態庫里被應用程序引用的目標模塊,這就減少了可執行文件在磁盤和內存中的大小。在Linux系統中,靜態庫由后綴.a標識。

重定位

一旦鏈接器完成了符號解析這一步,就把代碼中的每個符號引用和正好一個符號定義(即它的一個輸入目標模塊中的一個符號表條目)關聯起來。此時,鏈接器就知道它的輸入目標模塊中的代碼節和數據節的確切大小。現在就可以開始重定位步驟了,在這個步驟中,將合并輸入模塊,并為每個符號分配運行時地址。重定位由兩步組成:

  • 重定位節和符號定義。在這一步中,鏈接器將所有相同類型的節合并為同一類型的新的聚合節。例如,來自所有輸入模塊的.data節被全部合并成一個節,這個節成為輸出的可執行目標文件的.data節。然后,鏈接器將運行時內存地址賦給新的聚合節,賦給輸人模塊定義的每個節,以及賦給輸人模塊定義的每個符號。當這一步完成時,程序中的每條指令和全局變量都有唯一的運行時內存地址了。
  • 重定位節中的符號引用。在這一步中,鏈接器修改代碼節和數據節中對每個符號的引用,使得它們指向正確的運行時地址。要執行這一步,鏈接器依賴于可重定位目標模塊中稱為重定位條目(relocation entry)的數據結構。

當匯編器生成一個目標模塊時,它并不知道數據和代碼最終將放在內存中的什么位置,它也并不知道這個模塊引用的任何外部定義的函數或者全局變量的位置。所以,無論何時匯編器遇到對最終位置的目標引用,它就會生成一個重定位條目,告訴鏈接器在將目標文件合并成可執行目標文件時如何修改這個引用。

可執行目標文件 與 加載可執行目標文件

見《深入理解計算機系統》

動態鏈接共享庫

靜態庫由一些缺點:靜態庫需要定期維護和更新;每個程序都會使用一些通用的標準函數,在運行時,這些函數的代碼會被復制到每個運行進程的文本段中,在一個運行上百個進行的典型系統上,這是對內存資源的浪費。

共享庫(shared library)是致力于解決靜態庫缺陷的一個現代創新產物。共享庫是一個目標模塊,在運行或加載時,可以加載到任意內存地址,并和一個在內存中的程序鏈接起來。這個過程稱為動態鏈接,是由一個叫做動態鏈接器(dynamic linker)的程序來執行的。在Linux系統中,共享庫通常由.so后綴標識。

共享庫以兩種不同的方式來共享的。首先,在任何給定的文件系統中,對于一個庫只有一個.so文件。所有引用該哭的可執行目標文件共享這個.so文件中的代碼和數據,而不是像靜態庫的內容那樣被復制和嵌入到引用它們的可執行文件中。其次,在內存中,一個共享庫的.text節的一個副本可以被不同的正在運行的進程共享。


責任編輯:未麗燕 來源: 今日頭條
相關推薦

2014-04-10 09:40:51

System 360計算機計算機系統

2018-10-08 14:10:46

2020-07-02 08:17:12

存儲IO

2023-10-27 07:47:37

計算機內存模型

2017-07-14 15:40:28

2020-08-12 14:18:33

計算機Linux互聯網

2012-09-12 09:59:26

云計算超級計算機數據中心

2021-01-27 14:18:17

量子計算傳統計算量子機器

2021-02-20 20:55:06

USB接口總線

2012-06-20 10:40:36

量子計算機

2018-07-05 09:25:07

系統存儲層次

2012-03-31 11:12:19

計算機好文章

2025-05-12 00:00:15

2024-04-02 11:39:40

二進制儲存器網絡

2015-09-30 11:22:19

計算機大數據

2023-10-11 18:30:39

Web系統程序

2009-07-01 09:03:39

Linux綠壩操作系統

2009-07-04 09:38:07

2019-09-10 12:58:03

電腦編程語言硬件

2021-06-16 11:13:49

曙光
點贊
收藏

51CTO技術棧公眾號

超碰在线免费97| 国产免费黄视频| 天天做天天干天天操| 777电影在线观看| 精品一区二区三区久久久| 欧美日本在线视频中文字字幕| youjizz.com国产| 怡红院成人在线| 一区二区三区四区在线免费观看 | 久久精品国产精品亚洲精品色| 国产黄色片av| 视频一区二区中文字幕| 久久99亚洲热视| 成年人在线免费看片| 日韩中文字幕在线一区| 欧美性受xxxx黑人xyx| 久久久久久久久久伊人| 精品99又大又爽又硬少妇毛片| 国产一区二区在线看| 日韩暖暖在线视频| 免费中文字幕在线观看| 久久精品国产68国产精品亚洲| 精品国产自在久精品国产| 最近中文字幕一区二区| 麻豆网站免费在线观看| 亚洲精品国产a| 亚洲国产午夜伦理片大全在线观看网站| 最新不卡av| 国产熟女高潮一区二区三区| 小说区图片区亚洲| 在线观看视频91| 无码人妻丰满熟妇区96| 色呦呦在线免费观看| 亚洲国产成人午夜在线一区 | 要久久爱电视剧全集完整观看 | 热久久美女精品天天吊色| 九九热精彩视频| 一个色综合网| 久久精品久久久久久| 永久免费毛片在线观看| 免费成人av| 亚洲精品资源在线| 无套内谢大学处破女www小说| 成人av动漫| 欧美tickling网站挠脚心| 不用播放器的免费av| 日韩一区精品| 欧美视频中文字幕| 美女网站视频黄色| 97精品国产99久久久久久免费| 色婷婷综合久久久| 99热成人精品热久久66| 国产高清不卡| 色8久久精品久久久久久蜜| 久久9精品区-无套内射无码| 小视频免费在线观看| 中文字幕区一区二区三| 久久久夜精品| 欧洲美女7788成人免费视频| 国产三级av片| 久久久久久网| 日本久久久久久久久| 黄色一级视频免费看| 久久青草久久| 国产乱肥老妇国产一区二 | 首页综合国产亚洲丝袜| 国产经典一区二区| 国产亚洲久一区二区| 久久国产精品第一页| 91日本在线视频| 高潮一区二区三区乱码| 9人人澡人人爽人人精品| 久久精品国产一区二区三区日韩| 午夜福利视频一区二区| 久久久久久一二三区| 图片区小说区区亚洲五月| 午夜视频在线| 亚洲综合另类小说| 97成人在线观看视频| 亚洲精品555| 4438x亚洲最大成人网| 欧美一级片在线免费观看| 欧美精品中文| 中国日韩欧美久久久久久久久| 永久免费看mv网站入口亚洲| 国产一二三av| 欧美1区视频| 91高清免费视频| 亚洲图片在线播放| 成人永久免费视频| 欧美自拍资源在线| 黄网站app在线观看| 亚洲mv在线观看| www.久久91| 久久久久影视| 日韩综合视频在线观看| 日本少妇在线观看| 青青草91视频| 国产亚洲自拍偷拍| 欧美96在线| 精品国产鲁一鲁一区二区张丽| 久久撸在线视频| 极品尤物一区| 久久久国产成人精品| 日本天堂网在线| 国产一区不卡视频| 日本午夜精品一区二区三区| 神马午夜伦理不卡| 欧美日韩综合色| av鲁丝一区鲁丝二区鲁丝三区| 93在线视频精品免费观看| 国模私拍视频一区| aaa级黄色片| 国产精品亲子伦对白| 国产成人精品视频免费看| 日韩成人在线观看视频| 伊人久久大香线蕉av一区二区| 中文在线观看免费网站| 国产乱对白刺激视频不卡| 午夜精品电影在线观看| 欧美大片免费观看网址| 亚洲国产精品人人爽夜夜爽| 成人在线观看小视频| 奇米影视7777精品一区二区| 精品国产综合久久| 日本aa在线| 91精品国产综合久久香蕉麻豆| 无码少妇精品一区二区免费动态| 国产精品毛片在线看| 国产91精品入口17c| 嫩草香蕉在线91一二三区| 91国偷自产一区二区开放时间 | 午夜精品久久久久久久99| 国产精品福利电影一区二区三区四区| 精品国产免费av| 大桥未久女教师av一区二区| 欧美激情a在线| 国产三级伦理片| 亚洲日本va在线观看| 亚洲精品20p| 久久免费av| 国产精品视频久| 77777影视视频在线观看| 欧美亚洲国产bt| 五月婷六月丁香| 日韩精品国产欧美| 日本一区二区三区视频在线观看 | 97av自拍| 任你弄在线视频免费观看| 日韩欧美电影在线| 久久综合激情网| 成人性生交大片免费看中文 | а√天堂8资源在线| 精品99一区二区| 男人的天堂一区| 91色综合久久久久婷婷| 国模吧无码一区二区三区| 美国成人xxx| 欧洲美女7788成人免费视频| 国产三级电影在线| 欧美日韩精品专区| 欧美 日韩 国产 一区二区三区 | 成人18视频| 波多野结衣在线观看| 日韩精品在线电影| 日韩手机在线视频| 国产精品天美传媒| 肉色超薄丝袜脚交| 尤物网精品视频| 欧美久久在线| 亚洲精品第一| 国模精品视频一区二区| 男人天堂网在线观看| 欧美色图在线观看| 极品盗摄国产盗摄合集| 成人网页在线观看| 日本成人中文字幕在线| 国产精品成人a在线观看| 成人h在线播放| 中文字幕在线视频网站| 色婷婷综合久久久久中文字幕1| 国产原创中文av| 亚洲电影一级黄| 97在线观看免费视频| 国产美女在线精品| 中国丰满人妻videoshd | 精品国产www| 亚洲国产乱码最新视频 | 香蕉成人伊视频在线观看| 国产三级视频网站| 国内精品国产三级国产a久久| 青青青青在线视频| 欧美三级伦理在线| 国产91视觉| 国产极品久久久久久久久波多结野| 久久躁狠狠躁夜夜爽| 亚洲欧美日韩动漫| 91精品国产综合久久久久久久 | 精品免费一区二区三区| 在线观看日本网站| 伊人开心综合网| 国内精品卡一卡二卡三| 成人性视频免费网站| 国产成人美女视频| 国产精品久久久久毛片大屁完整版| 中文字幕欧美日韩一区二区| 牛牛视频精品一区二区不卡| 91久久久久久久一区二区| 久久电影tv| 久久乐国产精品| 国产视频一区二区| 一本一道久久a久久精品逆3p | 99久久久精品免费观看国产蜜| 欧美在线aaa| 丝袜诱惑亚洲看片| www国产精品内射老熟女| 中文精品电影| 一区二区在线中文字幕电影视频 | 最新不卡av| 欧美综合另类| 日本不卡在线播放| 日韩精品丝袜美腿| 精品久久久久久一区| 亚洲性视频在线| 亚洲a区在线视频| 婷婷激情成人| 国产精品一区二区三| 国产免费视频传媒| 成功精品影院| 99久热re在线精品视频| 国产精品诱惑| 国产精品久久久久高潮| 黑人巨大精品| 欧美亚洲国产精品| 超碰高清在线| 国内精品久久久久影院 日本资源| 超碰最新在线| 久久久999国产精品| 欧美一区二区三区| 日韩在线播放一区| 精品视频一二三| 一区二区成人av| 992tv免费直播在线观看| 一道本无吗dⅴd在线播放一区 | 欧美精品在线免费观看| 免费大片在线观看www| 最近2019年好看中文字幕视频| 触手亚洲一区二区三区| 在线免费看av不卡| 在线播放毛片| 久久精品国产一区| 婷婷丁香在线| 国产综合在线看| 日本不卡网站| 国产精品大陆在线观看| 国产精品字幕| 成人性生交大片免费看视频直播 | 亚洲国产精品热久久| 天堂在线视频网站| 日韩经典第一页| 狠狠v欧美ⅴ日韩v亚洲v大胸| 最近2019中文免费高清视频观看www99 | 日韩精品――中文字幕| 大荫蒂欧美视频另类xxxx| 亚洲s码欧洲m码国产av| 欧美亚洲一区三区| 99国产成人精品| 欧美精品一区二区三区很污很色的| 日本黄色不卡视频| 一色桃子一区二区| 性欧美猛交videos| 奇门遁甲1982国语版免费观看高清| 蜜桃视频成人m3u8| 91在线免费观看网站| 嫩草国产精品入口| 亚洲图片都市激情| 欧美日韩国产亚洲一区| 少妇高潮喷水久久久久久久久久| 免费在线观看成人| 在线中文字日产幕| 国产清纯白嫩初高生在线观看91| 91n在线视频| 午夜国产精品影院在线观看| 久久久精品毛片| 欧美一级一级性生活免费录像| 欧美视频在线观看一区二区三区| 亚洲人成亚洲人成在线观看| 国产区在线看| 久久久精品中文字幕麻豆发布| 思思久久精品视频| zzijzzij亚洲日本少妇熟睡| 国产18无套直看片| 亚洲制服丝袜在线| 久久这里只有精品9| 日韩午夜在线影院| 成人影院免费观看| 久久久久久久久久久亚洲| 欧美精选视频一区二区| 91福利视频导航| 国产一区二区三区探花| 人妻av无码专区| 麻豆国产精品官网| 青青草成人免费视频| 亚洲日本电影在线| 国产成人麻豆免费观看| 精品久久久三级丝袜| a√资源在线| 国产91av在线| 午夜电影一区| 伊人av成人| 麻豆成人精品| 日本护士做爰视频| 亚洲精品日韩专区silk| 在线观看日批视频| 精品香蕉一区二区三区| 女人天堂av在线播放| 成人黄色大片在线免费观看| 国产欧美日韩免费观看| 久久久久久www| 国产福利一区二区三区视频在线| 懂色av粉嫩av浪潮av| 欧美午夜女人视频在线| 亚洲老妇色熟女老太| 久久影视电视剧免费网站| 日韩高清不卡| 色婷婷精品国产一区二区三区| 一本一道久久综合狠狠老精东影业| 国产又粗又猛又爽又黄| 亚洲色图视频网| 中文字幕在线日亚洲9| 亚洲午夜久久久影院| 麻豆免费在线| 久久精品人成| 亚洲裸体俱乐部裸体舞表演av| 色哟哟网站在线观看| 亚洲精品国产视频| 国产丝袜在线视频| 久久成人18免费网站| 懂色av色香蕉一区二区蜜桃| 一区二区精品在线| 蜜臀av一级做a爰片久久| a资源在线观看| 欧美私人免费视频| 欧美a在线看| 亚洲在线观看视频网站| 欧美精品97| 精品国产一二区| 亚洲午夜激情网页| 人妻视频一区二区三区| 欧美亚洲视频在线观看| 亚洲精品一级二级三级| 成年人在线看片| 欧美国产97人人爽人人喊| 一区二区国产欧美| 久久6精品影院| 国产精品极品国产中出| 男人操女人逼免费视频| 91美女蜜桃在线| 中文字幕第99页| 日韩在线观看免费网站| 91国产一区| 草草视频在线免费观看| 91伊人久久大香线蕉| av图片在线观看| 最近中文字幕日韩精品| 国产一区二区| 国产精品又粗又长| 国产视频一区二区三区在线观看| 中国女人一级一次看片| 久久精品91久久香蕉加勒比| 精品视频一二| 欧美日韩一道本| 欧美激情一区二区三区四区| 国产乱淫片视频| 国外色69视频在线观看| 久久99青青| 999久久久精品视频| 亚洲国产精品久久艾草纯爱| 欧美成熟毛茸茸| 91精品中国老女人| 亚洲福利国产| 一级肉体全黄裸片| 日韩精品一区二| 日韩电影av| 公共露出暴露狂另类av| 91丝袜呻吟高潮美腿白嫩在线观看| 日韩精选在线观看| 久久99热这里只有精品国产| 国产永久精品大片wwwapp| 黄色片免费网址| 色老汉一区二区三区| 污污片在线免费视频| 日韩精品福利视频| 丁香婷婷综合色啪| 中文字幕乱码人妻二区三区| 久久青草福利网站| 欧美r级电影| 播金莲一级淫片aaaaaaa| 欧美一区二区三区啪啪| 色香欲www7777综合网|