精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

都市激情亚洲欧美| 国产成人l区| 91麻豆精品一二三区在线| 中文字幕中文字幕中文字幕亚洲无线 | 奇米成人av国产一区二区三区| 日本aaa视频| 羞羞视频在线观看一区二区| 亚洲成人tv网| 四虎影院一区二区三区| 91精品中文字幕| 99热这里只有精品8| 日韩在线免费视频观看| 精品国产人妻一区二区三区| 伊人在线视频| av一二三不卡影片| 成人欧美在线观看| 狠狠躁夜夜躁人人爽天天高潮| 欧美日韩水蜜桃| 亚洲大胆人体在线| 天堂在线一区二区三区| 亚洲精品传媒| av电影在线观看不卡| 国产伦精品免费视频| 天天综合网入口| 综合激情一区| 日韩一区二区麻豆国产| 爱情岛论坛vip永久入口| 免费在线超碰| 成人精品电影在线观看| 国产美女精彩久久| 少妇高潮av久久久久久| 亚洲国产国产亚洲一二三| 日韩在线视频观看| 精品无码国产污污污免费网站 | 国产123在线| 激情小说亚洲图片| 日韩精品中文字幕一区| 国产精品嫩草影院8vv8| 91九色在线porn| av午夜精品一区二区三区| 91在线高清视频| 一区二区www| 日本不卡视频一二三区| 日韩av电影手机在线观看| 国内免费精品视频| 亚洲区第一页| 91国内免费在线视频| 中国美女乱淫免费看视频| 一区二区网站| 精品粉嫩超白一线天av| 久久久久亚洲av无码网站| av福利在线导航| 一个色在线综合| 妞干网视频在线观看| 日本在线观看高清完整版| 一区二区三区高清不卡| 国产精品videossex国产高清| av免费在线免费| www.99精品| 国内精品二区| 在线观看毛片视频| 麻豆精品蜜桃视频网站| 国产精品网红福利| 一本色道久久综合熟妇| 精品在线播放免费| 92福利视频午夜1000合集在线观看| 国产精品久久久久久久久久久久久久久久久久| 久久精品国产成人一区二区三区 | 国产午夜精品福利| 日韩激情视频| 老司机在线视频二区| 亚洲欧洲另类国产综合| 2021国产视频| 少妇在线看www| 欧美性做爰猛烈叫床潮| 色18美女社区| 99国产精品久久一区二区三区| 亚洲国产精品久久久久久| 国产乱了高清露脸对白| 精品久久视频| 欧美成人在线免费| 亚洲 欧美 日韩 综合| 日韩av一区二| av激情久久| 欧美日韩在线精品一区二区三区激情综 | 成人高清在线观看| 亚洲色偷精品一区二区三区| 久久婷婷一区二区三区| 一区二区三区视频在线播放| 国产超碰人人模人人爽人人添| 国产精品白丝jk黑袜喷水| 国产精品黄色影片导航在线观看| 一区二区视频免费| 国产成人精品亚洲777人妖| 精品一区二区国产| 日本三级视频在线播放| 亚洲国产成人av网| 簧片在线免费看| 91精品短视频| 主播福利视频一区| 国产奶水涨喷在线播放| 免费久久99精品国产| 国产精品日韩二区| 麻豆网站在线| 日本韩国精品在线| 91九色在线观看视频| av在线播放一区| 亚洲成色777777在线观看影院| av免费播放网站| 野花国产精品入口| 91久久中文字幕| 国产区视频在线| 国产欧美一区二区三区沐欲| 欧美人与动牲交xxxxbbbb| 日韩精品影片| 亚洲精品在线三区| 国产精品 欧美激情| 五月天激情综合网| 久久中国妇女中文字幕| 亚洲黄色激情视频| 成人性生交大片免费看中文| 亚洲成人a**址| 中文字幕人成乱码在线观看| 日韩精品资源二区在线| 四虎影院中文字幕| 麻豆精品在线观看| 三区精品视频观看| 亚洲欧洲美洲av| 亚洲第一视频网站| 精品97人妻无码中文永久在线| 免费人成网站在线观看欧美高清| 你懂的网址一区二区三区| 白白色在线观看| 日韩精品一区二区三区视频播放 | 婷婷六月综合| 国产在线视频一区| 成人综合影院| 在线观看国产91| 天天躁夜夜躁狠狠是什么心态| 一本色道久久综合亚洲精品不卡| 99久久精品免费看国产一区二区三区 | 久久91精品国产91久久久| 97超碰人人模人人人爽人人爱| 国产日本欧美一区二区| jizz欧美激情18| 精品一区二区三区的国产在线观看| 欧美中文字幕在线播放| 五月激情婷婷综合| 天天影视涩香欲综合网| 成熟妇人a片免费看网站| 99精品国产99久久久久久福利| 动漫精品视频| 成人免费网站观看| 日韩电影网在线| 播金莲一级淫片aaaaaaa| 日韩天堂av| 蜜桃视频在线观看91| 都市激情亚洲一区| 亚洲香蕉成人av网站在线观看 | 亚洲成avwww人| 日本少妇性高潮| aa级大片欧美| 欧美性猛交久久久乱大交小说| 欧美色女视频| 成人免费福利视频| 国语对白在线刺激| 亚洲精品久久久久久久久久久| 天堂а√在线中文在线新版| 91亚洲男人天堂| 丁香啪啪综合成人亚洲| 欧美日中文字幕| 91精品视频大全| 欧美男男video| 欧美影院一区二区| 看黄色录像一级片| 国产乱妇无码大片在线观看| 日韩视频免费播放| 欧美色图一区| 91文字幕巨乱亚洲香蕉| 日韩精品美女| 日韩视频免费中文字幕| 亚洲精品97久久中文字幕| 岛国av午夜精品| 亚洲女同二女同志奶水| 成人黄色大片在线观看| 国产精品人人妻人人爽人人牛| 欧美xxxx中国| 精品无人乱码一区二区三区的优势| 性欧美18一19sex性欧美| 久久影院免费观看| 深夜福利在线视频| 亚洲一区二区三区国产| 素人fc2av清纯18岁| 久久精品国产久精国产| 久久黄色片视频| 无需播放器亚洲| 久久久久高清| 日韩免费高清视频网站| 欧美孕妇性xx| 伊人春色在线观看| 亚洲天堂开心观看| 精品国产999久久久免费| 欧美性xxxx极品hd欧美风情| 视频国产一区二区| 久久综合久久综合亚洲| 亚洲av毛片在线观看| 天堂在线一区二区| 免费看成人av| 精品一区二区三区四区五区| 日韩av高清不卡| 国内小视频在线看| 久久伊人精品视频| 成人福利在线| 亚洲精品一二区| 午夜精品久久久久久久91蜜桃| 欧美性受xxxx| 久久久黄色大片| 亚洲不卡一区二区三区| 欧美卡一卡二卡三| 亚洲国产成人自拍| 亚洲图色中文字幕| 老司机一区二区三区| 丰满少妇大力进入| 欧美激情第10页| 亚洲一区二区在线免费观看| 欧美人与拘性视交免费看| 国产亚洲精品久久飘花| 日韩区一区二| 91九色对白| 国产精品3区| 久久久久久国产精品美女| 网友自拍视频在线| 一本色道久久综合亚洲精品小说 | 久久这里只有精品6| 色哟哟无码精品一区二区三区| 精品午夜久久福利影院| 91制片厂毛片| 美女一区二区视频| 手机看片福利日韩| 日韩中文字幕区一区有砖一区| 亚洲高清在线观看一区| 嫩草影视亚洲| 欧美成熟毛茸茸复古| 秋霞影视一区二区三区| 激情伦成人综合小说| 欧美男男freegayvideosroom| 国产精品播放| 日韩大胆成人| 蜜桃网站成人| 区一区二视频| 一区二区三区观看| 国产精品麻豆久久| 国产一二三四五| 韩日成人av| 男人添女人下面高潮视频| 日韩午夜av在线| 92看片淫黄大片一级| 久久综合图片| 亚洲天堂国产视频| 国产福利一区二区三区在线视频| 国产调教打屁股xxxx网站| 福利电影一区二区三区| 国产一级免费片| 91一区在线观看| 成年人视频软件| 亚洲精品国产一区二区精华液| 久久久久久久久久久97| 亚洲国产精华液网站w| 日本黄色小视频在线观看| 中文字幕一区二区三区色视频| 欧美一区免费观看| 亚洲高清中文字幕| 亚洲欧美一区二区三区在线观看 | 2019中文字幕全在线观看| 成人动漫一区| 成人午夜在线视频一区| 风间由美中文字幕在线看视频国产欧美 | 免费av在线一区| 国产免费拔擦拔擦8x高清在线人| 国产99视频精品免视看7| 亚洲资源在线| 加勒比在线一区二区三区观看| 精品国产一区二区三区av片| 日日噜噜夜夜狠狠久久丁香五月| 亚洲第一精品影视| 天天操天天爱天天爽| 国产成人亚洲综合色影视| 黄色国产在线观看| 亚洲欧洲国产日本综合| 日韩精品一区三区| 欧美精品少妇一区二区三区| 欧美综合视频在线| 一本色道久久88亚洲综合88| 在线观看电影av| 国产成人一区二区三区小说 | 国产永久精品大片wwwapp| 国产一区二区黄色| 日韩久久精品网| 欧美午夜性视频| 美女视频网站黄色亚洲| 日本一级片在线播放| 成人精品视频网站| 久操视频在线观看免费| 亚洲r级在线视频| 一级片视频免费| 亚洲成**性毛茸茸| 国产91在线视频蝌蚪| 国产极品jizzhd欧美| 操欧美女人视频| 日本福利视频导航| 日韩国产一区二| 人妻丰满熟妇aⅴ无码| 亚洲日本韩国一区| 亚洲视屏在线观看| 精品视频在线导航| 国产在线拍揄自揄拍视频 | 国产精品国产精品国产专区| 日韩精品在线视频观看| 日本大胆在线观看| 成人美女免费网站视频| 成人激情诱惑| 午夜精品久久久内射近拍高清| 东方欧美亚洲色图在线| 污污的视频在线免费观看| 欧美少妇性性性| 黄网站在线观看| 青草青草久热精品视频在线网站 | 日韩性感在线| 久久国产毛片| 无套内谢大学处破女www小说| 亚洲一区二区影院| 精品人妻一区二区三区浪潮在线 | 国产第一页第二页| 亚洲综合色噜噜狠狠| 91丨porny丨在线中文| 亚洲视频自拍偷拍| 亚洲欧美电影| 欧美日韩一区在线观看视频| 99精品国产福利在线观看免费| 亚洲天堂2024| 精品久久久久人成| 亚洲色图欧美视频| 91精品国产777在线观看| 久久99精品久久久久久欧洲站| 日韩一级片免费视频| 国产成a人无v码亚洲福利| www.av视频| 亚洲精品一区二区三区福利 | 97精品国产福利一区二区三区| 亚洲国产精品三区| 国产精品九色蝌蚪自拍| 91精品人妻一区二区三区果冻| y97精品国产97久久久久久| 2020国产精品小视频| 最新视频 - x88av| 国产成人在线看| 国产精品成人av久久| 日韩av网站电影| 电影久久久久久| 国产成年人在线观看| 国产一区二区电影| 全黄一级裸体片| 欧洲一区在线观看| 秋霞午夜在线观看| 99电影网电视剧在线观看| 精品白丝av| 波多野吉衣中文字幕| 欧美影院精品一区| 宅男在线观看免费高清网站| 国产精品毛片va一区二区三区| 99精品国产福利在线观看免费 | 青草青草久热精品视频在线网站 | 人妻av无码专区| 97久久精品人人澡人人爽| 中文字幕精品视频在线观看| 中文字幕精品国产| 日韩三级av高清片| 成人羞羞国产免费网站| 中文字幕在线一区二区三区| 精品国产99久久久久久宅男i| 97超碰国产精品女人人人爽| re久久精品视频| 亚洲国产精品第一页| 色悠悠久久综合| 一区二区三区伦理| 日本午夜精品电影| 国产成人亚洲精品青草天美| 99热只有这里有精品| www.久久色.com| 欧美中文一区| 午夜福利123| 国产精品私人影院| 亚洲精品一级片| 国产精品成人一区二区| 午夜视频一区| 美国美女黄色片| 亚洲精品国产综合区久久久久久久| 国内欧美日韩| a级黄色片网站| 91亚洲资源网|