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

鏈接兩個(gè)"名字完全一樣"的【動(dòng)態(tài)庫(kù)】,你會(huì)怎么處理?

開(kāi)發(fā) 前端
在Linux應(yīng)用的開(kāi)發(fā)過(guò)程中,直接利用現(xiàn)成的第三方庫(kù)(俗稱:輪子)來(lái)完成自己的業(yè)務(wù)功能,是很常見(jiàn)的事情。

[[425670]]

【目錄】

  • 第一個(gè)動(dòng)態(tài)庫(kù)文件
  • 應(yīng)用程序
  • 第二個(gè)動(dòng)態(tài)庫(kù)文件
  • 錯(cuò)誤做法:直接給它改名
  • 正解:patchelf 工具
  • One More Thing

在Linux應(yīng)用的開(kāi)發(fā)過(guò)程中,直接利用現(xiàn)成的第三方庫(kù)(俗稱:輪子)來(lái)完成自己的業(yè)務(wù)功能,是很常見(jiàn)的事情。

不知道你是否遇到這樣的場(chǎng)景:應(yīng)用程序中需要使用兩個(gè)動(dòng)態(tài)庫(kù)里的不同功能的函數(shù),但是這兩個(gè)動(dòng)態(tài)庫(kù)的作者發(fā)生心靈感應(yīng)了,居然起了完全一樣的動(dòng)態(tài)庫(kù)名字,這該如何是好?

具體來(lái)說(shuō)面對(duì)的問(wèn)題是:在編譯可執(zhí)行程序的時(shí)候,通過(guò)gcc編譯參數(shù)的-lXXX就可以動(dòng)態(tài)鏈接一個(gè)動(dòng)態(tài)庫(kù)。

但是,現(xiàn)在你想鏈接兩個(gè)動(dòng)態(tài)庫(kù),它們的名字是一樣的!!怎么辦?

第一個(gè)動(dòng)態(tài)庫(kù)文件

現(xiàn)在,假設(shè)我們?cè)陂_(kāi)發(fā)一個(gè)機(jī)器人應(yīng)用程序,需要用到一個(gè)第三方動(dòng)態(tài)庫(kù)中的算法。

這個(gè)庫(kù)的源碼很簡(jiǎn)單,如下:

  1. // 第一個(gè)動(dòng)態(tài)庫(kù) 源文件 RobotMath.c: 
  2. double func0(double arg) 
  3.     double ret = arg + arg; 
  4.     return ret; 
  5.  
  6. double func1(double arg1, double arg2) 
  7.     double ret = arg1 + arg2; 
  8.     return ret; 

動(dòng)態(tài)庫(kù)的編譯命令是:

  1. $ gcc -m32 -fPIC --shared -o libRobotMath.so -Wl,--soname,libRobotMath.so RobotMath.c 

以上這些屬性都比較常見(jiàn),請(qǐng)注意其中的 -Wl,--soname,libRobotMath.so,它用來(lái)指定生成的動(dòng)態(tài)庫(kù)的 SONAME,一般用于動(dòng)態(tài)庫(kù)的版本管理中。

為了方便起見(jiàn),這里就不加版本信息了。

執(zhí)行了 gcc 指令之后,就得到了一個(gè)動(dòng)態(tài)庫(kù)文件:libRobotMath.so。

可以通過(guò) patchelf 這個(gè)工具(在Ubuntu系統(tǒng)中,可以通過(guò)apt-get直接安裝),來(lái)查看一下這個(gè)動(dòng)態(tài)庫(kù)文件的 SONAME :

  1. $ patchelf --print-soname libRobotMath.so  
  2. libRobotMath.so        // SONAME 

第2行打印出來(lái)的就是所謂的 SONAME。

你也可以測(cè)試一下,指定其他的 SONAME,例如:

$ gcc -m32 -fPIC --shared -o libRobotMath.so -Wl,--soname,libRobotMath-1.2.3.so RobotMath.c

$ patchelf --print-soname libRobotMath.so

libRobotMath-1.2.3.so // SONAME

以上就是第一個(gè)動(dòng)態(tài)庫(kù),已經(jīng)交代清楚了,下面再來(lái)看一下最簡(jiǎn)單的應(yīng)用程序。

應(yīng)用程序

  1. // 可執(zhí)行程序 源文件: main.c 
  2. extern double func0(double arg); 
  3. extern double func1(double arg1, double arg2); 
  4.  
  5. int main(int argc, char *agv[]) 
  6.     double arg = 1.1; 
  7.     double result0 = func0(arg); 
  8.     printf("result0 = %lf \n", result0); 
  9.  
  10.     double arg1 = 1.1, arg2 = 2.2; 
  11.     double result1 = func1(arg1, arg2); 
  12.     printf("result1 = %lf \n", result1); 
  13.  
  14.     return 0; 

這個(gè)代碼簡(jiǎn)直是幼兒園水平,不多解釋,直接編譯(假設(shè)已經(jīng)把動(dòng)態(tài)庫(kù)復(fù)制到main.c同一個(gè)文件夾中了):

  1. $ gcc -m32 -o main main.c -lRobotMath -L./ -Wl,-rpath=./ 

執(zhí)行:

  1. $ ./main  
  2. result0 = 2.200000  
  3. result1 = 3.300000 

完美!

第二個(gè)動(dòng)態(tài)庫(kù)文件

問(wèn)題來(lái)了:現(xiàn)在應(yīng)用程序還需要實(shí)現(xiàn)另外一個(gè)復(fù)雜的算法,本著偷懶的精神,終于在另外一個(gè)機(jī)器人算法相關(guān)的庫(kù)中找到了這個(gè)算法。

  1. // 第二個(gè)動(dòng)態(tài)庫(kù) 源文件 RobotMath.c: 
  2. double func2(double arg1, double arg2, double arg3) 
  3.     double ret = arg1 * arg2 * arg3; 
  4.     return ret; 
  5.  
  6. // 編譯指令 
  7. $ gcc -m32 -fPIC --shared -o libRobotMath.so -Wl,--soname,libRobotMath.so RobotMath.c 

但是坑爹的是,這個(gè)算法庫(kù)輸出的動(dòng)態(tài)庫(kù)名稱居然也是 libRobotMath.so !

與第一個(gè)算法庫(kù)的文件名同名同姓,看來(lái)這個(gè)名字太招人喜歡了。

如果這個(gè)作者直接起一個(gè)其它的名字,那就啥事都沒(méi)有了。

假如: 名字叫 libRobotUltra.so,那么只需要直接復(fù)制過(guò)來(lái),然后在編譯執(zhí)行程序時(shí),直接鏈接 -lRobotUltra 就可以了。

錯(cuò)誤做法:直接給它改名

既然如此,我們是否可以直接給它改名呢?嘗試一下:

  1. $ mv libRobotMath.so libRobotMath2.so 

然后把libRobotMath2.so復(fù)制到應(yīng)用程序的目錄下,并在main.c中,調(diào)用這個(gè)庫(kù)中的算法函數(shù) func2。

  1. extern double func2(double arg1, double arg2, double arg3); 
  2.  
  3. int main(int argc, char *agv[]) 
  4.     // 之前的其它代碼 
  5.     // ... 
  6.  
  7.     double arg3 = 1.1, arg4 = 2.2, arg5 = 3.3; 
  8.     double result2 = func2(arg3, arg4, arg5); 
  9.     printf("result2 = %lf \n", result2); 
  10.  
  11.     return 0; 

編譯一下試試:

  1. $ gcc -m32 -o main main.c -lRobotMath -lRobotMath2 -L./ -Wl,-rpath=./ 
  2. /tmp/ccDGqFkl.o: In function `main': 
  3. main.c:(.text+0xb4): undefined reference to `func2' 
  4. collect2: error: ld returned 1 exit status 

報(bào)錯(cuò):找不到 func2 這個(gè)函數(shù)。

但是libRobotMath2.so這個(gè)庫(kù)中明明已經(jīng)有這個(gè)函數(shù)啊,不信你看:

  1. $ readelf -s libRobotMath2.so | grep func2 
  2.      8: 0000052a    69 FUNC    GLOBAL DEFAULT   11 func2 
  3.     51: 0000052a    69 FUNC    GLOBAL DEFAULT   11 func2 

為啥 gcc 還找不到呢?

看來(lái),很粗魯?shù)刂苯咏o第二個(gè)動(dòng)態(tài)庫(kù)文件強(qiáng)行改名,不是解決問(wèn)題的正確思路!

正解:patchelf 工具

還記得在第一個(gè)庫(kù)中,我們使用 patchelf 這個(gè)小工具來(lái)查看動(dòng)態(tài)庫(kù)的 SONAME 嗎?

繼續(xù)用它來(lái)查看下被我們改名后的 libRobotMath2.so:

  1. $ patchelf --print-soname libRobotMath2.so  
  2. libRobotMath.so 

SONAME 依然是原來(lái)的名稱,說(shuō)明通過(guò)mv指令改名,只是改變了外表,并沒(méi)有改變它的內(nèi)心。

如果你熟悉文件系統(tǒng),就會(huì)知道:mv 指令只是修改了庫(kù)文件在 inode 節(jié)點(diǎn)中的名字,而庫(kù)文件實(shí)際內(nèi)容所存儲(chǔ)的 block 存儲(chǔ)空間中,一點(diǎn)都沒(méi)有變化。

動(dòng)態(tài)庫(kù)是一個(gè)ELF格式的文件,操作系統(tǒng)在加載動(dòng)態(tài)庫(kù)的時(shí)候,是根據(jù)ELF格式的標(biāo)準(zhǔn),對(duì)文件的內(nèi)容進(jìn)行一層一層解析的。

可以參考很久之前寫的一篇文章:Linux系統(tǒng)中編譯、鏈接的基石-ELF文件:扒開(kāi)它的層層外衣,從字節(jié)碼的粒度來(lái)探索。

patchelf 這個(gè)工具,就提供了這樣的功能:查看或修改動(dòng)態(tài)庫(kù)文件的內(nèi)部信息,包括:SONAME, 依賴的其他動(dòng)態(tài)庫(kù),rpath 路徑信息等等。

  1. $ patchelf -h 
  2. syntax: patchelf 
  3.   [--set-interpreter FILENAME] 
  4.   [--page-size SIZE] 
  5.   [--print-interpreter] 
  6.   [--print-soname]      Prints 'DT_SONAME' entry of .dynamic section. Raises an error if DT_SONAME doesn't exist 
  7.   [--set-soname SONAME]     Sets 'DT_SONAME' entry to SONAME. 
  8.   [--set-rpath RPATH] 
  9.   [--remove-rpath] 
  10.   [--shrink-rpath] 
  11.   [--print-rpath] 
  12.   [--force-rpath] 
  13.   [--add-needed LIBRARY] 
  14.   [--remove-needed LIBRARY] 
  15.   [--replace-needed LIBRARY NEW_LIBRARY] 
  16.   [--print-needed] 
  17.   [--no-default-lib] 
  18.   [--debug] 
  19.   [--version] 
  20.   FILENAME 

我們可以使用--set-soname這個(gè)參數(shù),來(lái)把它的 SONAME 修改一下:

  1. $ patchelf --set-soname libRobotMath2.so libRobotMath2.so 

第一個(gè) libRobotMath2.so,是設(shè)置的 SONAME 名稱;

第二個(gè) libRobotMath2.so,是指定修改哪一個(gè)動(dòng)態(tài)庫(kù)文件的 SONAME;

修改之后,再檢查一下是否修改正確了:

  1. $ patchelf --print-soname libRobotMath2.so  
  2. libRobotMath2.so 

Bingo!SONAME 已經(jīng)被正確修改了。

再次編譯一下可執(zhí)行程序:

  1. $ gcc -m32 -o main main.c -lRobotMath -lRobotMath2 -L./ -Wl,-rpath=./ 

沒(méi)有報(bào)錯(cuò)!

執(zhí)行一下:

  1. $ ./main  
  2. result0 = 2.200000  
  3. result1 = 3.300000  
  4. result2 = 7.986000 

問(wèn)題解決了!

One More Thing

什么?你說(shuō)這樣的問(wèn)題是千年等一回?是為賦新詞強(qiáng)說(shuō)愁?那說(shuō)明走過(guò)的路還不是足夠的長(zhǎng)。

記得大概是2015年的時(shí)候,開(kāi)發(fā)一個(gè)網(wǎng)關(guān),在硬件出來(lái)之前需要在Ubuntu (x86)平臺(tái)上進(jìn)行模擬。

為了便于跨平臺(tái),選擇了 glib 庫(kù),但是對(duì)其中的小部分源碼進(jìn)行了二次開(kāi)發(fā)。

但是Ubuntu的桌面系統(tǒng)是基于GTK的(底層使用的就是glib庫(kù)),也就是說(shuō)操作系統(tǒng)在啟動(dòng)時(shí)已經(jīng)加載了系統(tǒng)目錄下的 glib庫(kù)。

那么我們的應(yīng)用程序在編譯時(shí),的確可以鏈接到自己二次開(kāi)發(fā)的glib庫(kù)(放在本地文件夾),但是在執(zhí)行時(shí),一直加載不成功,就是因?yàn)閯?dòng)態(tài)庫(kù)的名字沖突問(wèn)題導(dǎo)致的。

最后沒(méi)辦法,只好利用 patchelf 工具,對(duì)動(dòng)態(tài)庫(kù)的名稱,包括 SONAME 進(jìn)行改寫,這樣才解決問(wèn)題。

本文轉(zhuǎn)載自微信公眾號(hào)「IOT物聯(lián)網(wǎng)小鎮(zhèn)」,可以通過(guò)以下二維碼關(guān)注。轉(zhuǎn)載本文請(qǐng)聯(lián)系IOT物聯(lián)網(wǎng)小鎮(zhèn)公眾號(hào)。

 

責(zé)任編輯:武曉燕 來(lái)源: IOT物聯(lián)網(wǎng)小鎮(zhèn)
相關(guān)推薦

2014-06-05 11:25:10

2024-02-28 08:10:15

Linux靜態(tài)庫(kù)動(dòng)態(tài)庫(kù)

2023-11-23 08:30:16

2022-12-07 08:47:28

2010-08-18 17:06:02

DB2數(shù)據(jù)庫(kù)編譯

2020-11-13 07:16:09

線程互斥鎖死循環(huán)

2016-11-10 19:10:09

唯品會(huì)雙11

2012-03-21 10:15:48

RIM越獄

2012-06-14 09:48:11

OpenStackLinux

2022-11-24 12:22:39

2011-02-28 10:38:13

Windows 8

2012-12-20 10:17:32

IT運(yùn)維

2012-03-07 17:24:10

戴爾咨詢

2017-08-25 15:08:24

深度學(xué)習(xí)機(jī)器人

2009-06-12 15:26:02

2021-10-20 20:02:47

字符變量函數(shù)

2021-07-14 10:00:28

數(shù)據(jù)庫(kù)SQL查詢Linux

2015-08-25 09:52:36

云計(jì)算云計(jì)算產(chǎn)業(yè)云計(jì)算政策

2021-05-20 08:37:32

multiprocesPython線程

2015-07-15 09:29:27

UI設(shè)計(jì)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

av福利导福航大全在线| 国产精品九九九九| 日韩av中文字幕一区| 欧美日韩国产色| 视频一区二区三| 国产人妻精品一区二区三区| 亚洲精品美女91| 久久精品国产99国产精品澳门| 一级全黄裸体片| 粉嫩一区二区三区| 亚洲激情中文1区| 日韩av高清| 狠狠躁夜夜躁av无码中文幕| 视频在线观看91| 久久久亚洲国产| 国精产品久拍自产在线网站| 精品人人人人| 欧美一区二区三区在线观看| www黄色av| 毛片网站在线看| 国产精品日产欧美久久久久| 国产精品有限公司| 国产丝袜在线视频| 日韩激情视频在线观看| 国内精品久久久久伊人av| 黄色香蕉视频在线观看| 国产亚洲一卡2卡3卡4卡新区| 欧美videos中文字幕| 色婷婷成人在线| 欧美大片免费观看网址| 亚洲午夜私人影院| 日韩中文字幕亚洲精品欧美| 福利视频在线导航| 久久精品一区二区三区不卡牛牛| 国产精选一区二区| 午夜老司机福利| 国内精品国产成人| 成人h片在线播放免费网站| 国产三级av片| 在线亚洲欧美| 性日韩欧美在线视频| 久草中文在线视频| 欧美激情偷拍| 欧美成人一二三| 日韩在线中文字幕视频 | 3d蒂法精品啪啪一区二区免费| 欧美 日韩 精品| 香蕉久久国产| 欧美一级片在线播放| 日韩欧美国产亚洲| 亚洲美女网站| 88xx成人精品| 国产性猛交╳xxx乱大交| 国产一区二区三区成人欧美日韩在线观看 | 亚洲精品综合| 97在线观看视频| av大片免费在线观看| 在线亚洲国产精品网站| 欧美怡红院视频一区二区三区| 日韩网红少妇无码视频香港| 91久久亚洲| 热久久这里只有精品| 日韩三级一区二区| 青娱乐精品视频在线| 国产精品中文字幕久久久| 91 中文字幕| 国产一区二区三区四| 99国产视频| 视频二区在线观看| 久久久久久久久久久久久夜| 日韩三级电影| 午夜羞羞小视频在线观看| 亚洲国产精品人人做人人爽| 一二三四视频社区在线| 天堂av在线网| 欧美丰满高潮xxxx喷水动漫| 色姑娘综合天天| 欧美激情久久久久久久久久久| 日韩精品中文字幕在线| 蜜桃av乱码一区二区三区| 91欧美大片| 欧美日韩成人精品| av网站中文字幕| 久久福利资源站| 粉嫩av四季av绯色av第一区| 香蕉国产在线视频| 亚洲国产精品精华液2区45| 喜爱夜蒲2在线| 天堂av中文在线观看| 欧美三级电影在线看| 亚洲三级在线视频| 国产99亚洲| 久久国产加勒比精品无码| 日韩精品一区二区三区国语自制| 天堂成人免费av电影一区| 91视频国产精品| 香蕉久久一区二区三区| 18成人在线观看| 国产91在线免费| 欧美videos粗暴| 日韩成人av在线| 国产精品国产精品88| 黄色亚洲大片免费在线观看| 国产精品 欧美在线| 国产高清在线免费| 国产欧美一区二区三区沐欲| 好色先生视频污| 你懂得影院夜精品a| 欧美哺乳videos| 免费成人深夜蜜桃视频| 一区二区国产精品| 91在线播放国产| 成人亚洲综合天堂| 黄色精品在线看| 国产精品嫩草69影院| 日韩精品免费| 国产成人91久久精品| 成人高潮片免费视频| 国产精品麻豆网站| 99久久久无码国产精品6| 亚洲网址在线观看| 久久精品国产视频| 成人黄色三级视频| 91丨九色丨尤物| 久久综合久久网| 91精品短视频| 另类美女黄大片| 亚洲中文一区二区三区| 91色.com| 亚洲 欧美 日韩 国产综合 在线 | 国产视频久久| 国产精品久久久久久久久婷婷 | 日韩二区三区| 亚洲一区二区三区四区五区中文 | 成人短视频下载| 黄色网在线视频| 韩国三级大全久久网站| 色黄久久久久久| 亚洲影视一区二区| 国产精品五月天| 浓精h攵女乱爱av| 国产亚洲一卡2卡3卡4卡新区 | 欧美韩国日本一区| 色诱视频在线观看| 国产欧美日韩免费观看| 欧美在线激情网| 青青草观看免费视频在线| 懂色aⅴ精品一区二区三区蜜月| 艳妇乳肉豪妇荡乳xxx| 亚洲欧洲一级| 久热这里只精品99re8久| 精精国产xxx在线视频app| 亚洲成人三级在线| 97免费在线观看视频| 91麻豆精东视频| 一本久道综合色婷婷五月| 九九精品在线| 国产精品视频在线播放| 日韩黄色影院| 制服.丝袜.亚洲.中文.综合| 日韩高清dvd碟片| 懂色av一区二区三区免费看| 亚洲一区二区三区av无码| 卡通动漫精品一区二区三区| 91爱视频在线| 国产高清视频在线| 91精品国产综合久久福利| 内射一区二区三区| 成人国产在线观看| 无码aⅴ精品一区二区三区浪潮| 九九久久婷婷| 91亚洲国产精品| www.九色在线| 在线看日韩欧美| 99久久亚洲精品日本无码| 亚洲动漫第一页| 亚洲一区视频在线播放| 国产一区二区按摩在线观看| www.在线观看av| 国产精品三级| 成人精品一区二区三区| av电影在线免费| 中文字幕不卡在线视频极品| 99视频免费看| 色综合天天视频在线观看| 69夜色精品国产69乱| 成人视屏免费看| 99视频在线视频| 欧美视频成人| 午夜精品福利一区二区| 日本免费一区二区三区视频| 欧美一级大片在线免费观看| 久操视频在线播放| 国产视频一区在线| 国产超碰人人模人人爽人人添| 欧美日韩激情视频8区| 国产精品18在线| 337p粉嫩大胆色噜噜噜噜亚洲| 色噜噜狠狠永久免费| 欧美破处大片在线视频| 日韩av影视| 国产成人一二| 成人免费看黄网站| 亚洲精品在线影院| 97人人爽人人喊人人模波多| 日本高清中文字幕在线| 亚洲精品视频免费| www.com在线观看| 欧美视频在线一区二区三区| 欧美日韩中文视频| 成人欧美一区二区三区黑人麻豆| 亚洲欧美在线不卡| 丁香六月综合激情| 伊人成人222| 日韩黄色免费电影| 日韩av片在线看| 欧美私人啪啪vps| 一区二区三区日韩视频| 欧美日韩国产免费观看视频| 精品免费二区三区三区高中清不卡| 精品午夜视频| 国产日韩欧美中文在线播放| av电影一区| 97视频在线观看亚洲| 久久久123| 另类色图亚洲色图| 欧美三级理伦电影| 在线观看免费高清视频97| 中文字幕一区二区中文字幕| 亚洲精品毛片一区二区三区| 亚洲成a人片在线不卡一二三区| 天天爽天天爽天天爽| 久久精品人人做人人综合| 特级西西人体4444xxxx| 成人av网在线| 色哟哟无码精品一区二区三区| 国内成+人亚洲+欧美+综合在线| 午夜久久久精品| 奇米四色…亚洲| 亚洲一二三区av| 热久久国产精品| 蜜臀av免费观看| 美洲天堂一区二卡三卡四卡视频 | 国产极品美女在线| 中文字幕日韩欧美一区二区三区| 欧美黄色高清视频| 久久久精品一品道一区| 粉嫩av蜜桃av蜜臀av| 91麻豆成人久久精品二区三区| 亚洲啪av永久无码精品放毛片 | 国产精品中出一区二区三区| 视频亚洲一区二区| 国产精品久久久久久久天堂第1集 国产精品久久久久久久免费大片 国产精品久久久久久久久婷婷 | 国产精彩视频在线观看| 亚洲一二三四在线观看| 久久久综合久久| 亚欧色一区w666天堂| 亚洲精品1区2区3区| 一本久久综合亚洲鲁鲁五月天| 四虎精品永久在线| 色综合网站在线| 在线播放一级片| 欧美一区日本一区韩国一区| 国产福利资源在线| 亚洲精品97久久| 精品无吗乱吗av国产爱色| 中文字幕亚洲无线码a| 黄色免费网站在线观看| 欧美激情伊人电影| www.成人影院| 91精品久久久久久久久久入口 | gogo久久| 日本中文字幕久久看| 69堂免费精品视频在线播放| 成人www视频在线观看| 中文字幕区一区二区三| 欧美高清性xxxxhd| 国产精品99视频| 97超碰在线人人| 男人操女人的视频在线观看欧美| 亚洲三级在线观看视频| 波多野结衣中文字幕一区二区三区| 日韩视频一区在线观看| 国产精品久久久久毛片| 亚洲大尺度美女在线| 国产香蕉视频在线看| 美女黄色丝袜一区| 精品丝袜在线| 成人午夜小视频| 女同另类激情重口| 中文字幕精品一区日韩| 亚洲国产专区校园欧美| 91最新在线观看| 国产不卡免费视频| 97人妻人人揉人人躁人人| 一区二区三区 在线观看视频| 国产尤物在线视频| 欧美一区二区三区视频在线 | 中文字幕九色91在线| 国产精品蜜臀| 国产中文字幕91| 日韩影视高清在线观看| 欧美xxxx吸乳| 日本在线不卡视频| 中国黄色a级片| 亚洲一区视频在线| 在线观看免费视频a| 日韩精品视频在线观看免费| 大地资源网3页在线观看| 欧洲日本亚洲国产区| 超碰97久久国产精品牛牛| 亚洲午夜在线观看| 欧美专区18| 国产一级免费片| 亚洲欧美日韩成人高清在线一区| 伊人手机在线视频| 日韩欧美二区三区| 美女黄视频在线观看| 国产成人小视频在线观看| 国产成人精品福利| 中文字幕日韩精品无码内射| 蜜桃av一区二区三区电影| av男人的天堂av| 色噜噜狠狠色综合中国| 姝姝窝人体www聚色窝| 超碰97人人做人人爱少妇| 成人黄色免费观看| 欧美在线视频二区| 亚洲综合精品四区| 艳妇乳肉豪妇荡乳xxx| 亚洲自拍偷拍麻豆| 精品人妻一区二区三区浪潮在线| 日韩最新中文字幕电影免费看| 亚洲伦理影院| 日产精品一线二线三线芒果| 蜜桃av一区| 中文字幕国产专区| 欧美性猛交xxxx乱大交蜜桃| 天天综合天天色| 91精品国产成人| 欧美电影在线观看完整版| 国产91沈先生在线播放| 国产成人精品亚洲777人妖| 国产av 一区二区三区| 欧美一区二区成人| 自拍亚洲图区| 99超碰麻豆| 亚洲二区免费| 亚洲中文字幕一区| 欧美色另类天堂2015| 欧美偷拍视频| 国产成人短视频| 色中色综合网| 中文字幕在线视频一区二区| 一区二区激情小说| 秋霞欧美在线观看| 2020国产精品视频| 女厕嘘嘘一区二区在线播放| 欧美一级黄色影院| 国产精品剧情在线亚洲| 国产wwwxxx| 国内精品免费午夜毛片| 伊人春色精品| 午夜两性免费视频| 亚洲欧美日韩小说| 蜜臀久久精品久久久久| 欧美孕妇毛茸茸xxxx| 欧美日韩第一| 人妻体体内射精一区二区| 亚洲国产视频一区二区| 亚洲av毛片成人精品| 国产激情999| 亚洲女同另类| av无码av天天av天天爽| 91国内精品野花午夜精品 | 久久久久久久91| 亚洲精品aaaaa| 日韩成人精品视频在线观看| 亚洲精品一二三四区| 亚洲区小说区图片区| 国产精品美女无圣光视频| 911精品美国片911久久久| 91传媒理伦片在线观看| 欧美性猛交xxxx免费看久久久| 91在线看片| 国产乱码精品一区二区三区日韩精品| 99av国产精品欲麻豆| 免费成人深夜天涯网站| 欧美不卡123| jizz亚洲女人高潮大叫| 野外做受又硬又粗又大视频√| 国产日韩欧美一区二区三区乱码| 99久久久久久久| 日韩av123| 狠狠色狠狠色综合日日tαg| 国产手机在线观看| 日韩精品一区国产麻豆| 国产日本久久| a级黄色一级片| 日韩美女啊v在线免费观看|