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

二儀攸分和跨界溯源

開(kāi)發(fā) 前端
這個(gè)世界是紛繁復(fù)雜的,同時(shí)又是符合一些簡(jiǎn)單規(guī)律的。朱子有句名言:千頭萬(wàn)緒,終歸一理。意思是無(wú)論多么混亂的東西,都始終是由一個(gè)簡(jiǎn)單的道理支配著的。

[[356763]]

這個(gè)世界是紛繁復(fù)雜的,同時(shí)又是符合一些簡(jiǎn)單規(guī)律的。朱子有句名言:千頭萬(wàn)緒,終歸一理。意思是無(wú)論多么混亂的東西,都始終是由一個(gè)簡(jiǎn)單的道理支配著的。舉例來(lái)說(shuō),在古老的《易經(jīng)》里便定義了陰陽(yáng)兩個(gè)符號(hào),并賦予了它們豐富而且深刻的內(nèi)涵。在《易經(jīng)》的系辭傳中,有一句著名的話:易有太極,是生兩儀。對(duì)這句話,有不同的理解。“天地起源說(shuō)”是其中一種。根據(jù)這種理解,宇宙最初是混沌的一體,后來(lái)清者為天,濁者為地,這個(gè)形成天地的過(guò)程可以被簡(jiǎn)稱為“二儀攸分”。

我不敢說(shuō)這句話對(duì)描述天地形成有幾分準(zhǔn)確,但憑著多年來(lái)對(duì)軟件的研究,我認(rèn)為它對(duì)軟件世界是很適用的。最早的軟件就是一長(zhǎng)串卡片,連在一起,卡片上的指令住在一個(gè)空間里,是平等的,沒(méi)有特權(quán)差異,沒(méi)有空間劃分。隨著計(jì)算機(jī)的發(fā)展,計(jì)算機(jī)系統(tǒng)里的角色開(kāi)始細(xì)分,每個(gè)角色的特征和位置逐漸固定。于是有了中央化的內(nèi)存和處理器,以及外部的輸入輸出設(shè)備。

 

中央的處理器和內(nèi)存速度很快,外部的輸入輸出設(shè)備速度很慢。讓中央處理器直接與外設(shè)對(duì)話太影響效率了。于是便有了中斷的概念,中央處理器需要什么,下命令給外設(shè),外設(shè)做好了,通過(guò)中斷通知中央處理器:“報(bào)告老大,您吩咐的任務(wù)完成了。”外部設(shè)備不止一個(gè),中斷也有很多種,為了更好的處理中斷,便有了專門用于處理中斷的“控制程序”,這便是操作系統(tǒng)的前身。中斷處理程序的邏輯很敏感,如果出故障就會(huì)導(dǎo)致整個(gè)系統(tǒng)無(wú)法工作。既然它如此重要,那么就應(yīng)該“優(yōu)待”它,讓它享有特權(quán),給它專門的“住所”,加強(qiáng)其住所的防衛(wèi),防止有人擅自闖入。于是便有了專門給中斷處理程序住的空間,也就是所謂的內(nèi)核空間。有了高特權(quán)的內(nèi)核空間后,也就有了低特權(quán)的用戶空間。于是本來(lái)混沌一體不分特權(quán)的軟件世界便分成兩個(gè)部分了。

 

在軟件世界的兩個(gè)空間中,“用戶空間是可見(jiàn)的,很多程序在上面生生不息,屬陽(yáng)。內(nèi)核空間不可見(jiàn),但是承載著上面的應(yīng)用,為應(yīng)用提供服務(wù),厚德載物,本身不發(fā)光,但是卻能反射應(yīng)用的光輝,像月亮,屬陰。”(選自《軟件調(diào)試》卷2)今天,軟件世界的這種基本格局已經(jīng)非常固定,無(wú)論是Windows,還是Linux都是如此。用戶空間和內(nèi)核空間的關(guān)系與現(xiàn)實(shí)世界中公民與政府的公司非常類似。當(dāng)公民需要政府服務(wù)時(shí)要到政府的窗口去辦理,軟件世界中的對(duì)應(yīng)機(jī)制便叫“系統(tǒng)調(diào)用”,意思是要調(diào)用系統(tǒng)的服務(wù)。

[前半部分為科普,后半部分換擋,前方高寒,非geek止步]

受兩大空間劃分的影響,當(dāng)我們調(diào)試軟件時(shí),一般也分為調(diào)試用戶空間代碼的應(yīng)用程序調(diào)試,和調(diào)試內(nèi)核空間代碼的內(nèi)核調(diào)試。相應(yīng)的,調(diào)試器也可以分為應(yīng)用程序調(diào)試器和內(nèi)核調(diào)試器。

容易理解,當(dāng)我們使用應(yīng)用程序調(diào)試器調(diào)試應(yīng)用程序時(shí),是無(wú)法調(diào)試內(nèi)核代碼的。反過(guò)來(lái)則未必。

或者說(shuō),使用內(nèi)核調(diào)試器能調(diào)試用戶空間的代碼嗎?

理論上是可以的,因?yàn)閮?nèi)核空間的特權(quán)高,既然已經(jīng)能訪問(wèn)和控制內(nèi)核空間,那么理論也就能訪問(wèn)和控制受內(nèi)核管理的用戶空間。

理論上可以,實(shí)踐中可以么?答案是未必,要看調(diào)試器的能力,也要看調(diào)試者的技術(shù)水平。

舉例來(lái)說(shuō),使用WinDBG來(lái)調(diào)試Windows內(nèi)核時(shí),也可以在用戶空間設(shè)置斷點(diǎn),斷點(diǎn)命中后,可以讀寫變量,或者單步跟蹤。

不過(guò),雖然WinDBG有這個(gè)能力,實(shí)際能做把WinDBG使用到這個(gè)程度的人其實(shí)并不多。在這方面,WinDBG還有一個(gè)非常牛的能力,那就是跨越陰陽(yáng)二界地顯示系統(tǒng)調(diào)用的完整過(guò)程,比如:

 

在上面這幅完美的棧回溯中,下面部分是CPU在用戶空間的執(zhí)行經(jīng)過(guò),從線程的起點(diǎn)開(kāi)始,到AfxWinMain,經(jīng)過(guò)消息循環(huán),然后是OLE的處理文件拖拽邏輯,收到一個(gè)文件后,自己不認(rèn)識(shí),通過(guò)古老的DDE機(jī)制廣播消息尋求幫助,用于廣播消息的SendMessageW函數(shù)發(fā)起系統(tǒng)調(diào)用,進(jìn)入內(nèi)核空間,內(nèi)核空間中的Win32K模塊處理這個(gè)服務(wù)請(qǐng)求,執(zhí)行廣播消息的任務(wù),把消息發(fā)個(gè)一個(gè)個(gè)頂層窗口,遇到一個(gè)“收到消息不回的壞蛋”,卡在那里了。

我第一次看到這樣的完美棧回溯時(shí),我深深被微軟調(diào)試工具的技術(shù)水平所打動(dòng)。

為什么呢?因?yàn)橐缭絻蓚€(gè)空間顯示這個(gè)棧回溯有很多困難。第一個(gè)困難是每個(gè)普通線程都至少有兩個(gè)棧,用戶空間一個(gè),內(nèi)核空間一個(gè),因此,要顯示上面這樣的完美棧回溯,必須要回溯兩個(gè)棧,因?yàn)槠瘘c(diǎn)在內(nèi)核空間,因此,內(nèi)核空間的棧比較好找。但用戶空間的棧位置就不那么好找。

第二個(gè)困難是今天的主流操作系統(tǒng)都是多任務(wù)的,有很多個(gè)用戶空間,要顯示上面的完美棧回溯,必須要找到正確的用戶空間,并且找到這個(gè)空間中的模塊列表,加載用戶空間的模塊。

自從開(kāi)始開(kāi)發(fā)NDB調(diào)試器,我就想讓它也具有“產(chǎn)生完美棧回溯”的能力。為了實(shí)現(xiàn)這個(gè)愿望,我花很多時(shí)間思考,加上很多時(shí)間寫代碼,當(dāng)然還花了很多時(shí)間來(lái)調(diào)試代碼,讓它如預(yù)期的工作。

長(zhǎng)話短說(shuō),解決第一個(gè)困難花了至少三十個(gè)小時(shí)的時(shí)間。最終的成功方案是要經(jīng)歷這幾個(gè)步驟。先通過(guò)內(nèi)核空間的棧回溯,找到CPU做系統(tǒng)調(diào)用時(shí),飛到內(nèi)核空間的起點(diǎn),在x64下,它是使用匯編編寫的entry_SYSCALL_64。在內(nèi)核源碼的syscall_init中,也可以看到這個(gè)證據(jù)。

entry_SYSCALL_64的源代碼位于:F:\bench\linux-5.0.7\arch\x86\entry\entry_64.S在這個(gè)非常值得細(xì)讀的匯編源文件中,有一段很長(zhǎng)的注釋,這段注釋幫了我大忙。

 

更重要的是,在這個(gè)匯編函數(shù)中,它保存了一個(gè)所謂的硬件幀,通過(guò)不斷壓棧,在棧上形成形成了一個(gè)pt_regs結(jié)構(gòu)體。

 

這個(gè)pt_regs結(jié)構(gòu)體里面包含了關(guān)鍵的寄存器信息,特別是我需要的用戶空間棧指針rsp。

類比一下,這個(gè)結(jié)構(gòu)體相當(dāng)于Windows下的陷阱幀(KTRAP_FRAME),這又應(yīng)了朱子的話:千頭萬(wàn)緒,終歸一理。

在征戰(zhàn)這一關(guān)時(shí),我的NDB發(fā)揮了很大作用,比如我在entry_SYSCALL_64入口設(shè)置斷點(diǎn),成功命中,這讓我可以清楚觀察CPU從用戶空間飛到內(nèi)核空間后剛剛著陸后的精確狀態(tài),每個(gè)寄存器的取值。

  1. rax=00000000000000e4 rbx=0000000000000001rcx=00007ffdc513099a // RIP 
  2. rdx=00007f9b9dec9e10 rsi=00007f9b9dec9e10rdi=0000000000000001 
  3. rip=ffffffffa3e00010 rsp=00007f9b9dec9db8rbp=00007f9b9dec9dc0 
  4.  r8=0000000000000000  r9=00007f9b9dec9e10 r10=00007f9b9dec9db0 
  5. r11=0000000000000286 r12=00007f9b9dec9e10r13=0000000000000000 
  6. r14=00007f9b9dec9e10 r15=00007f9b9dec9e20 
  7. iopl=0         nv up di ng nz na po nc 
  8. cs=0010 ss=0018  ds=0000  es=0000 fs=0000  gs=0000             efl=00010086 
  9. lk!entry_SYSCALL_64: 
  10. ffffffff`a3e00010 0f01f8        invlpg eaxds:0010:00007ffd`c512d080=00126362 

其中rcx寄存器的值便是用戶空間的程序指針,因?yàn)楦鶕?jù)SYSCALL指令的定義,CPU會(huì)把rip保存到rcx,即上面注釋中說(shuō)的:

64-bit SYSCALL saves rip to rcx使用NDB反匯編這個(gè)值-2(減2是為了看到已經(jīng)執(zhí)行過(guò)的syscall指令)便可以看到用戶空間發(fā)起系統(tǒng)調(diào)用的指令:

  1. u 007ffdc5130998 
  2. 00007ffd`c5130998 0f05             syscall 
  3. 00007ffd`c513099a 415c             pop    r12d 
  4. 00007ffd`c513099c 5d               pop     rbp 
  5. 00007ffd`c513099d c3               ret 
  6. 00007ffd`c513099e a860             test    al,0x60 
  7. 00007ffd`c51309a0 7438             jz      00007ffdc51309da 
  8. 00007ffd`c51309a2 4863c7           movsxd  rax,edi 
  9. 00007ffd`c51309a5 488d0dd4c6ffff   lea    rcx,[00007ffdc512d080] 

順便說(shuō)一下,使用匯編語(yǔ)言編寫的entry_SYSCALL_64函數(shù)準(zhǔn)備pt_regs結(jié)構(gòu)體的目的是為了給使用C語(yǔ)言編寫的do_syscall_64函數(shù)準(zhǔn)備參數(shù)。后者的第二個(gè)參數(shù)便是指向pt_regs結(jié)構(gòu)體的指針,即:

  1. __visible void do_syscall_64(unsigned long nr, struct pt_regs *regs) 

下面是準(zhǔn)備調(diào)用C語(yǔ)言函數(shù)前的寄存器上下文:

和棧數(shù)據(jù):

 

對(duì)于這個(gè)棧數(shù)據(jù),不常做底層調(diào)試的同行可能滿臉問(wèn)號(hào)。對(duì)于我來(lái)說(shuō),幾乎每個(gè)字節(jié)都非常親切,像老朋友一樣,因?yàn)樗鼈兌紓€(gè)性鮮明,16位的段選擇子也住著64位的大房子(^-^)。

對(duì)于第二個(gè)困難,解決的難度更大,主要的步驟如下。

首先要通過(guò)per-cpu區(qū)找到當(dāng)前任務(wù)指針,也就是current指針,參見(jiàn)我的上一篇文章。然后要通過(guò)current指針找到當(dāng)前任務(wù)的地址空間描述,也就是mm_struct。然后找到mm_struct中的VMA鏈表,再遍歷這個(gè)鏈表,篩選出其中的一個(gè)個(gè)so模塊描述。

找到這些so模塊描述后,還需要把這些描述報(bào)告給調(diào)試引擎,讓調(diào)試引擎來(lái)加載用戶空間的模塊。

找到用戶空間的棧和加載了用戶空間的模塊后,再觀察棧回溯,便可以看到希望的曙光了。比如下面是11月21日時(shí)看到的場(chǎng)景:

 

已經(jīng)看到libc和著名的ld模塊,這給我很大鼓勵(lì)。

仔細(xì)觀察上面這個(gè)棧回溯,容易看出libc中的函數(shù)名很不精確,用調(diào)試器分析,發(fā)現(xiàn)使用的libc符號(hào)文件缺少對(duì)棧回溯至關(guān)重要的幀信息。深究原因,讓人暈倒。與Windows下的符號(hào)文件不同,Linux(以Ubuntu為例)的gcc編譯時(shí)如果有-g選項(xiàng),則會(huì)產(chǎn)生調(diào)試符號(hào),與執(zhí)行信息放在一個(gè)文件中。

包含符號(hào)信息的文件比較大,所以一般會(huì)通過(guò)所謂的strip過(guò)程產(chǎn)生一個(gè)消減符號(hào)的產(chǎn)品文件和一個(gè)用于調(diào)試的符號(hào)文件。比如使用下面這樣的objcopy命令便可以產(chǎn)生一個(gè)專門用作調(diào)試的符號(hào)文件:

  1. gedu@gedu-VirtualBox:~/labs/gemalloc$ readelf --debug-dump=frames gemalloc.dbg 
  2. section '.eh_frame' has the NOBITS type - its contents are unreliable. 

用下面兩條命令則可以產(chǎn)生一個(gè)適于發(fā)布到產(chǎn)品環(huán)境的不帶符號(hào)版本:

  1. gedu@gedu-VirtualBox:~/labs/gemalloc$ cp gemalloc gemalloc.prd 
  2. gedu@gedu-VirtualBox:~/labs/gemalloc$ objcopy --strip-debug  gemalloc.prd 

觀察文件大小,是有明顯差異的:

 

調(diào)試時(shí),我們一般使用符號(hào)文件。因?yàn)榇蠖鄶?shù)符號(hào)信息是放在符號(hào)文件中的。注意,這里是說(shuō)大多數(shù),并不是全部。比如幀信息,因?yàn)榘l(fā)生異常時(shí)做棧展開(kāi)也需要,所以幀信息是放在產(chǎn)品文件中的。既然幀信息對(duì)于調(diào)試和正常執(zhí)行都需要,按說(shuō)應(yīng)該兩個(gè)文件都有一份,但事實(shí)上不是,至少上面截圖中使用的libc符號(hào)文件里不包含幀信息,節(jié)的頭仍在,但是標(biāo)志位里有NOBITS標(biāo)志,代表這個(gè)節(jié)的數(shù)據(jù)是不可靠的,解析時(shí)會(huì)失敗。

比如,使用readelf命令來(lái)顯示上面產(chǎn)生符號(hào)文件的幀信息,會(huì)得到如下提示:

  1. gedu@gedu-VirtualBox:~/labs/gemalloc$ readelf --debug-dump=frames gemalloc.dbg 
  2. section '.eh_frame' has the NOBITS type - its contents are unreliable. 

再附加個(gè)截圖吧:

 

以下是readelf程序的有關(guān)源代碼:

  1. if(section->sh_type == SHT_NOBITS) 
  2.    { 
  3.     /* There is no point in dumping the contents of a debugging section 
  4.        which has the NOBITS type - the bits in thefile will be random. 
  5.        This can happen when a file containing a.eh_frame section is 
  6.        stripped with the --only-keep-debug commandline option.  */ 
  7.     printf (_("section '%s' has the NOBITS type - its contents are unreliable.\n"), 
  8.             print_name); 
  9.     return 0; 

怎么解決這個(gè)問(wèn)題呢?就是要讓NDB為一個(gè)模塊加載兩個(gè)符號(hào)文件。細(xì)節(jié)從略。

過(guò)了這一個(gè)難關(guān)后,便可以看到更好一些的棧回溯了。libc的函數(shù)名變得很精確。

 

仔細(xì)觀察上面的結(jié)果,美中不足的是最后三行,有兩行重復(fù)clone函數(shù),最后一行沒(méi)有給出函數(shù)名,也沒(méi)有顯示出代表root的返回地址為0特征。

他山之石可以攻玉。使用gdb來(lái)做對(duì)比較實(shí)驗(yàn),看到的是:

  1. (gdb) bt 
  2. #0  thread_func (arg=0x9) at gemalloc.c:289 
  3. #1  0x00007ffff68216ba in start_thread(arg=0x7fffc6ffd700) 
  4.     at pthread_create.c:333 
  5. #2  0x00007ffff655741d in clone () 
  6.     at../sysdeps/unix/sysv/linux/x86_64/clone.S:109 

看來(lái)clone函數(shù)確實(shí)是線程的起點(diǎn)。gdb成功在起點(diǎn)處停車。可是ndb沒(méi)有。

給調(diào)試器上調(diào)試器,調(diào)試NDB。仔細(xì)跟蹤負(fù)責(zé)解析符號(hào)的ndw模塊。

跟蹤發(fā)現(xiàn),ndw可以順利找到clone函數(shù)的幀信息,即:

  1. 000146e80000000000000014 00000000 CIE 
  2.   Version:               1 
  3.   Augmentation:          "zR" 
  4.   Code alignment factor: 1 
  5.   Data alignment factor: -8 
  6.   Return address column: 16 
  7.   Augmentation data:     1b 
  8.   DW_CFA_def_cfa: r7 (rsp) ofs 8 
  9.   DW_CFA_offset: r16 (rip) at cfa-8 

DW_CFA_undefined:r16 (rip)

上面的DW_XX是DWARF標(biāo)準(zhǔn)里定義的棧回溯指令,可以理解為腳本語(yǔ)言。NDW內(nèi)部的解釋器順利執(zhí)行了前兩條語(yǔ)句:

  1. DW_CFA_def_cfa: r7 (rsp) ofs 8 
  2.   DW_CFA_offset: r16 (rip) at cfa-8 

但是在執(zhí)行第三條語(yǔ)句時(shí),懵圈了。

DW_CFA_undefined:r16 (rip)

我在跟蹤這條語(yǔ)句對(duì)應(yīng)的解釋器代碼時(shí),以為遇到了不認(rèn)識(shí)的指令,推測(cè)是版本兼容導(dǎo)致的。

反復(fù)跟蹤和思索了很久,我終于領(lǐng)悟到了,這個(gè)undefined并不是我最初想的那樣。它的含義不是說(shuō)它是一條未定義的指令,而是要把它的操作數(shù),也就是后面的rip寄存器設(shè)置為“未定義”狀態(tài)。

某種程度來(lái)說(shuō),棧回溯就是在回滾寄存器的狀態(tài),而這個(gè)

DW_CFA_undefined:r16 (rip)

就是要把rip寄存器的狀態(tài)回滾到“未定義狀態(tài)”。也就是讓它進(jìn)入一個(gè)不知道為何值的狀態(tài)。

在NDW的老代碼中,對(duì)于這個(gè)情況,會(huì)把rip回滾到它的當(dāng)前值(也就是不回滾),于是就出現(xiàn)了上面的clone函數(shù)的父函數(shù)還是clone函數(shù)的現(xiàn)象。

閱讀libc中clone函數(shù)的源代碼,可以找到這個(gè)DW_CFA_undefined指令的來(lái)源,是某位同行故意手工加入的。

 

代碼中的注釋很有意思:故意加了這個(gè)undefined來(lái)標(biāo)記到了最外層的棧幀,非常明顯地!其實(shí)不加就挺好的。Anyway,也是用心良苦。

閉目思索,這里用的undefined也非常具有哲學(xué)意味。很多時(shí)候我們?cè)趯ふ以搭^,可是最終的源頭到底在哪里呢?我們找到的源頭也未必就是真的源頭。真的源頭常常是未知的,也就是undefined。比如2020年的新冠病毒,人類能找到真的源頭么?至少到今天,還是undefined。

如此想來(lái),這種在線程源頭標(biāo)記為undefined的方法還真是意義非凡。

找到根源之后,我直接把這種undefined的回滾處理成回滾到0,問(wèn)題便解決了,夢(mèng)寐以求的完美棧回溯出現(xiàn)在眼前。

 

 

 

 

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

 

責(zé)任編輯:武曉燕 來(lái)源: 格友
相關(guān)推薦

2016-11-28 10:23:49

DELL

2015-05-06 09:37:28

Infor云計(jì)算Infor Cloud

2020-10-15 14:10:51

網(wǎng)絡(luò)攻擊溯源

2014-08-05 17:13:33

華為

2017-02-08 10:00:29

大數(shù)據(jù)hadoopHDFS

2009-12-08 11:20:59

互聯(lián)網(wǎng)

2013-05-20 09:48:54

隨時(shí)在線云計(jì)算大數(shù)據(jù)旋風(fēng)

2011-12-06 16:40:45

二維碼快拍二維碼靈動(dòng)快拍

2021-09-03 15:16:48

芯片谷歌蘋果

2015-06-18 10:45:31

英特爾

2017-06-02 10:13:01

互聯(lián)網(wǎng)

2013-09-16 11:32:53

H3C金融跨界

2009-07-01 14:40:14

2015-10-19 17:13:08

ThinkPad

2015-08-07 14:44:51

2020-10-05 22:00:59

深度學(xué)習(xí)編程人工智能

2015-10-30 11:05:07

Testin王軍

2016-11-21 09:13:07

大數(shù)據(jù)智能制造

2022-08-22 10:29:16

APT溯源反溯源APT攻擊

2016-02-24 17:26:22

智慧教育展覽會(huì)
點(diǎn)贊
收藏

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

欧洲一区二区av| 另类专区欧美蜜桃臀第一页| 亚洲电影第1页| 人妻有码中文字幕| 日本韩国在线视频爽| 成人在线视频首页| 国产精品久久久久久久av电影| 乌克兰美女av| 影音先锋在线视频| 久久久久久久久免费| 亚洲自拍偷拍区| 欧美videossex极品| 久久密一区二区三区| 精品国产伦一区二区三区观看体验| 欧美久久久久久蜜桃| 亚洲国产成人精品女人久久久 | 日韩欧美一区二区三区在线视频| 偷拍与自拍一区| 日本一区二区三区在线视频| 国产福利视频导航| 日韩黄色免费电影| 亚洲18私人小影院| 国产精品久久久久久久精| 国产欧美日韩视频在线| 精品国产免费人成电影在线观看四季| 国产成人一区二区三区别| 成年人在线视频| 99久久精品情趣| 91九色露脸| 91亚洲欧美激情| 91无套直看片红桃在线观看| 26uuu亚洲电影在线观看| 国产欧美日韩麻豆91| 国产精品一区二区欧美黑人喷潮水 | 久久国产免费观看| 日韩国产专区| 在线观看国产精品91| 一本加勒比北条麻妃| 久草精品视频| 亚洲爱爱爱爱爱| 五月天六月丁香| 成人在线视频国产| 欧美日韩国产片| 91制片厂毛片| 成人午夜sm精品久久久久久久| 中文字幕免费不卡| 麻豆成人av| 神马久久久久| 26uuu另类欧美| 久久综合久久综合这里只有精品| 小泽玛利亚一区二区三区视频| 成人在线国产| 在线中文字幕日韩| 亚洲理论片在线观看| 久久97视频| 国产午夜精品美女视频明星a级| 激情 小说 亚洲 图片: 伦| 欧美亚洲韩国| 91国产免费看| 亚洲免费黄色网| www久久久| 在线观看91av| 日本中文字幕有码| av不卡一区二区| 亚洲精品av在线播放| 玖玖爱在线精品视频| 一区二区导航| 在线观看不卡av| 欧美做爰啪啪xxxⅹ性| 欧美a级片一区| 97精品在线视频| 久久久久99精品成人片三人毛片| 亚洲成人三区| 欧美激情综合亚洲一二区| 中文字幕久久亚洲| 中文字幕1234区| 一本色道69色精品综合久久| 亚洲国产天堂网精品网站| 国产夫妻性爱视频| 欧美日韩中文一区二区| 久久精品国产91精品亚洲| 99视频只有精品| 夜夜嗨av一区二区三区网站四季av| 亚洲视频精品在线| 伊人久久久久久久久久久久久久| 亚洲人成网站77777在线观看| 91精品国产91久久久久久一区二区| 欧美黄色一级片视频| 日韩福利影视| 亚洲电影免费观看高清完整版在线 | 成人性生交视频免费观看| 91超碰在线免费| 日本韩国精品一区二区在线观看| 阿v天堂2017| 不卡亚洲精品| 亚洲精品在线网站| 欧美午夜激情影院| 午夜日韩视频| 国产精品久久久久久久久免费| 日韩精品一区二区亚洲av| 男女男精品网站| 国产伦视频一区二区三区| 久久国产精品高清一区二区三区| 久久伊人蜜桃av一区二区| 一区二区三区久久网| 波多野结衣中文在线| 欧美精品三级日韩久久| 狠狠人妻久久久久久综合蜜桃| 精品亚洲精品| 久久中文精品视频| 黄色片网站在线免费观看| 国产伦精品一区二区三区免费迷 | 极品美女一区二区三区| 九九热精品视频国产| 中文字幕av网站| 99久久精品99国产精品| 2欧美一区二区三区在线观看视频| 国产一区二区三区高清视频| 国产爆初菊在线观看免费视频网站 | av在线免费网站| 日本道精品一区二区三区 | 久久精品波多野结衣| 肉丝袜脚交视频一区二区| 国产高清不卡av| 男人天堂久久久| 91激情在线视频| 欧美日本国产在线| 国产毛片久久久久久久| 亚洲欧美色图| 国产日产亚洲精品| 国产中文在线观看| 欧美日韩视频免费播放| 中文字幕99页| 欧美精品一卡| 91久久精品www人人做人人爽| 老牛影视av牛牛影视av| 亚洲乱码国产乱码精品精可以看 | 欧美大电影免费观看| 精品久久久久久最新网址| 全程偷拍露脸中年夫妇| 国内外成人在线视频| 亚洲日本一区二区三区在线不卡| 成人影院在线观看| 欧美日韩精品三区| 网爆门在线观看| 蜜臀精品久久久久久蜜臀| 日韩欧美亚洲区| 成人天堂yy6080亚洲高清| 亚洲欧洲在线免费| 91丝袜一区二区三区| 91浏览器在线视频| 成人一级片网站| 精品久久不卡| 国产精品色午夜在线观看| 成人性爱视频在线观看| 欧美午夜电影在线播放| 欧美午夜激情影院| 国产资源精品在线观看| 日本黄网站色大片免费观看| 亚洲国产视频二区| 国产+成+人+亚洲欧洲| 天堂网在线播放| 一本一本大道香蕉久在线精品 | 国产特级淫片高清视频| 日本成人a网站| 国产成人一区二区| 欧美另类极品| 欧美精品一区二区久久久| 97人人澡人人爽人人模亚洲| 国产亚洲欧洲997久久综合 | 狠狠色丁香久久婷婷综| 麻豆传媒网站在线观看| **爰片久久毛片| 91po在线观看91精品国产性色| 精品久久久无码中文字幕| 亚洲一区二区在线观看视频| 91丝袜在线观看| 老司机免费视频久久| 五月天色一区| 91久久精品无嫩草影院| 亲子乱一区二区三区电影 | 亚洲图中文字幕| 91极品身材尤物theporn| 一区二区三区自拍| 不卡一区二区在线观看| 久久精品国产秦先生| 国产一区 在线播放| 久久最新网址| 成人亚洲欧美一区二区三区| 1区2区3区在线| 中文字幕日韩电影| 亚洲国产www| 欧美综合天天夜夜久久| 欧美激情国产精品免费| 久久老女人爱爱| 少妇性l交大片7724com| 久久精品系列| 日产精品久久久久久久蜜臀| 神马香蕉久久| 95av在线视频| 精品视频在线一区二区在线| 欧美黄色成人网| 成人影院免费观看| 亚洲精品国产精品自产a区红杏吧 亚洲精品国产精品乱码不99按摩 亚洲精品国产精品久久清纯直播 亚洲精品国产精品国自产在线 | 免费一级suv好看的国产网站| 91av精品| 欧美精品一区二区三区在线四季| 僵尸再翻生在线观看免费国语| 亚洲аv电影天堂网| 亚洲中文字幕一区二区| 欧美日韩精品二区| 亚洲色婷婷一区二区三区| 国产日韩欧美麻豆| 国产精品一区二区人妻喷水| 精品一区二区三区免费播放| 国产福利一区视频| 国内在线观看一区二区三区| 色综合电影网| 最新精品国偷自产在线| 成人区精品一区二区| 国产第一亚洲| 国产精品成人国产乱一区| av午夜在线观看| 欧美精品免费在线| 91在线视频| 国产亚洲欧洲高清一区| 无码国精品一区二区免费蜜桃| 欧美性猛交xxxxx水多| 青娱乐免费在线视频| 亚洲欧洲在线观看av| 日韩一级片在线免费观看| 久久久精品tv| 加勒比一区二区| 26uuu国产日韩综合| 国产日韩视频一区| 丁香天五香天堂综合| 免费黄视频在线观看| 国产一区二区三区久久悠悠色av | 大片免费在线观看| 中文字幕欧美日韩| 成人在线免费观看| 亚洲天天在线日亚洲洲精| 男人久久精品| 亚洲精品影视在线观看| 香蕉视频911| 亚洲精品视频免费在线观看| 欧美天堂在线视频| 亚洲的天堂在线中文字幕| 国产综合在线播放| 亚洲福利在线播放| 手机av免费在线观看| 亚洲第一av在线| 视频国产一区二区三区| 亚洲精品一区二区三区不| 青青草视频在线免费观看| 亚洲欧洲国产一区| 国产精品一二三区视频| 中文亚洲视频在线| 黄色免费在线看| 欧美另类交人妖| 国产偷倩在线播放| 午夜在线视频观看日韩17c| 亚洲国产精品久久久久婷婷老年 | 亚洲男同gay网站| 美女啪啪无遮挡免费久久网站| 青青免费在线视频| 国产亚洲欧美日韩美女| 亚洲成人影院麻豆| 欧美成人剧情片在线观看| 丁香花在线高清完整版视频| 97久久伊人激情网| 第四色男人最爱上成人网| 国产精品一区电影| 玖玖玖电影综合影院| 国产精品亚洲不卡a| 在线一级成人| 免费国产成人看片在线| 亚洲第一黄色| 在线免费观看视频黄| 国产一区二区调教| 欧美成人三级伦在线观看| 国产亲近乱来精品视频| 国模无码国产精品视频| 欧美日韩在线影院| 艳妇乳肉豪妇荡乳av无码福利| 精品国产乱码久久久久久天美| 99鲁鲁精品一区二区三区| 午夜成人免费视频| 国产美女www| 欧美v亚洲v综合ⅴ国产v| 亚洲欧美日韩成人在线| 俺去啦;欧美日韩| 成人免费网站观看| 国产裸体写真av一区二区| 99热这里只有精品首页 | 亚洲人成电影网站色mp4| 精品无码免费视频| 在线看不卡av| 欧美一区二区三区激情| 亚洲性猛交xxxxwww| 91高清在线观看视频| 日本精品久久久久久久| 国产精品国产亚洲精品| 欧美日韩喷水| 国模 一区 二区 三区| 另类小说色综合| 不卡的av在线播放| 看黄色录像一级片| 欧美性极品xxxx娇小| 韩国中文字幕hd久久精品| 中文字幕亚洲激情| 免费观看一级欧美片| 成人区精品一区二区| 999视频精品| 一本色道无码道dvd在线观看| 久色成人在线| 手机看片福利日韩| 91丨porny丨户外露出| 免费中文字幕日韩| 欧亚一区二区三区| 日本不卡免费播放| 成人无号精品一区二区三区| 黄频视频在线观看| 久久婷婷丁香| 朝桐光av一区二区三区| 一区二区三区精密机械公司| 国产美女精品视频国产| 在线视频国产日韩| 欧美大片免费| 久久精品中文字幕一区二区三区 | 在线观看精品视频| 日韩国产欧美一区二区三区| 韩国无码一区二区三区精品| 亚洲最新在线观看| 国产三级三级在线观看| 最新中文字幕亚洲| 123成人网| 五月婷婷一区| 美美哒免费高清在线观看视频一区二区| 国产精品人人爽人人爽| 久久亚洲影视婷婷| 好看的av在线| 亚洲欧美在线磁力| 特黄毛片在线观看| 免费精品视频一区二区三区| 国产欧美另类| 久久久亚洲av波多野结衣| 欧美日韩另类视频| 性高潮久久久久久久久久| 亚洲18私人小影院| 精品一区免费| 国产一二三四在线视频| 国产欧美一区二区在线观看| 无码人妻丰满熟妇奶水区码| 亚洲欧美日本另类| av激情成人网| 一区二区视频在线观看| 韩国三级在线一区| 真实国产乱子伦对白在线| 精品乱码亚洲一区二区不卡| 国内激情视频在线观看| 久久婷婷开心| 蜜桃精品视频在线观看| 免费一级suv好看的国产网站| 午夜久久久影院| 日韩av免费观影| 国产精品久久久久久久美男| 91麻豆国产自产在线观看亚洲| 无码人妻精品一区二区三区在线| 久久99久国产精品黄毛片色诱| 黄色污在线观看| 91国在线观看| 国产激情在线| 久久99精品国产一区二区三区| 综合一区av| 蜜桃色一区二区三区| 欧美性感美女h网站在线观看免费 欧美性xxxx在线播放 | 亚洲一本二本| 久久人妻少妇嫩草av无码专区| 成人欧美一区二区三区视频网页| 亚洲国产成人无码av在线| 最近2019年手机中文字幕| 国产一区一区| 久久精品免费一区二区| 中文字幕第一区| 国产91免费在线观看| 国产成人免费av| 亚洲欧美综合| 亚洲天堂网在线观看| 国产嫩草在线视频| 日韩不卡av| 国产不卡视频在线观看| 91久久国产综合久久91| 久久香蕉频线观| 制服丝袜日韩| 亚洲国产精品狼友在线观看| 欧美色国产精品| 美女露胸视频在线观看| 在线观看免费91| 久久日韩精品一区二区五区|