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

記一次 .NET某工業視覺軟件崩潰分析

開發 前端
在我的dump分析之旅中曾遇到過一次相似的生產故障,本篇文章主要還是對訓練營里這位朋友的有求必應吧,不過說實話,多分析幾個像這樣的dump,會極大的提升你的高級調試能力。

一、背景

1. 講故事

前兩天給訓練營里的一位學員分析了一個dump,學員因為弄了一整天也沒找到禍根,被我一下子弄出來了,極度想看看我是怎么分析的?由于在微信上不能一言兩語表盡,干脆寫一篇文章出來詳細的講講吧,哈哈,訓練營里的學員得有求必應哈。。。話不多說,我們一起探索下這個程序的崩潰之路吧。

二、WinDbg分析

1. 為什么會崩潰

這個比較簡單,因為默認會自動定位到崩潰的線程,使用 .ecxr 切到崩潰前的上下文即可,然后使用 k 觀察崩潰點,參考如下:

0:044> .ecxr
rax=0000000000000000 rbx=00000217a6c78f90 rcx=0000000000000000
rdx=0000000000000000 rsi=000000242c46fdd0 rdi=00000217ff1594a0
rip=00007ffdb35eb699 rsp=000000242c46fb40 rbp=000000242c46fc70
 r8=00007ffdb35eb699  r9=00000217ea61fc08 r10=00000000e0434352
r11=0000000000000001 r12=00000217a6c78f90 r13=0000000000000000
r14=0000000000000000 r15=0000000000000000
iopl=0         nv up ei pl nz na pe nc
cs=0033  ss=002b  ds=002b  es=002b  fs=0053  gs=002b             efl=00000202
KERNELBASE!RaiseException+0x69:
00007ffd`b35eb699 0f1f440000      nop     dword ptr [rax+rax]
0:044> k
  *** Stack trace for last set context - .thread/.cxr resets it
 # Child-SP          RetAddr               Call Site
00 00000024`2c46fb40 00007ffd`51bf8c6f     KERNELBASE!RaiseException+0x69
01 00000024`2c46fc20 00007ffd`51890108     clr!UMThunkStubRareDisableWorker+0x3f
02 00000024`2c46fc50 00007ffc`dc826748     clr!UMThunkStub+0x128
03 00000024`2c46fce0 00007ffc`dc827406     MVCAMSDK_X64+0x6748
04 00000024`2c46fd80 00007ffc`dc9d21eb     MVCAMSDK_X64!CameraGrabber_GetCameraDevInfo+0xb96
05 00000024`2c46fe50 00007ffc`dc9d227f     MVCAMSDK_X64!CameraGigeEnumerateDevice+0x167f2b
06 00000024`2c46fe80 00007ffd`b5a07374     MVCAMSDK_X64!CameraGigeEnumerateDevice+0x167fbf
07 00000024`2c46feb0 00007ffd`b5ebcc91     kernel32!BaseThreadInitThunk+0x14
08 00000024`2c46fee0 00000000`00000000     ntdll!RtlUserThreadStart+0x21

從卦中可以看到程序是在clr 的 UMThunkStubRareDisableWorker 函數中故意拋出的異常,接下來觀察下該函數代碼。

extern "C" VOID __stdcall UMThunkStubRareDisableWorker(Thread* pThread, UMEntryThunk* pUMEntryThunk, Frame* pFrame)
    {
        if (!CanRunManagedCode())
        {
            pThread->m_fPreemptiveGCDisabled = 0;
            COMPlusThrowBoot(E_PROCESS_SHUTDOWN_REENTRY);
        }
    }

    BOOL CanRunManagedCode(BOOL fCannotRunIsUserError, HINSTANCE hInst)
    {
        if (g_fForbidEnterEE == TRUE)
            return FALSE;

        if ((g_fEEShutDown & ShutDown_Finalize2) && !GCHeap::GetGCHeap()->IsCurrentThreadFinalizer())
            return FALSE;

        if (g_pPreallocatedOutOfMemoryException == NULL)
            return FALSE;

        return TRUE;
    }

從卦中的代碼看是因為 CanRunManagedCode() 返回false導致的,到內存中觀察這幾個變量即可。

0:044> dp clr!g_fForbidEnterEE L1
00007ffd`5201d548  00000000`00000000

0:044> dp clr!g_fEEShutDown L1
00007ffd`520140b0  00000000`00000007

0:044> dp clr!g_pPreallocatedOutOfMemoryException L1
00007ffd`52013e08  00000217`e4f513d8

看到卦中的幾個變量大概就知道了,原來當前程序正在等待 終結器線程 執行完畢的 EEShutDown 狀態。

2. 真的處于關閉狀態嗎

剛才只是通過變量觀察,接下來我們觀察線程棧來進一步求證,分別切到主線程和終結器線程觀察調用棧,參考如下:

0:000> ~0s;k;~2s;k
win32u!NtUserMsgWaitForMultipleObjectsEx+0x14:
00007ffd`b3dfa104 c3              ret
 # Child-SP          RetAddr               Call Site
00 00000024`2773f578 00007ffd`b3f40c8e     win32u!NtUserMsgWaitForMultipleObjectsEx+0x14
...
08 00000024`2773f9c0 00007ffd`518828ff     clr!CLREventBase::WaitEx+0xab
09 00000024`2773fa30 00007ffd`51882842     clr!WaitForEndOfShutdown_OneIteration+0xb3
0a 00000024`2773fac0 00007ffd`5171f703     clr!WaitForEndOfShutdown+0x1a
0b 00000024`2773faf0 00007ffd`518243f9     clr!EEShutDown+0xd3
0c 00000024`2773fb40 00007ffd`51823f34     clr!HandleExitProcessHelper+0x29
0d 00000024`2773fb70 00007ffd`51823e14     clr!_CorExeMainInternal+0xf8
0e 00000024`2773fc00 00007ffd`96d7d6ea     clr!CorExeMain+0x14
0f 00000024`2773fc40 00007ffd`96c3ac42     mscoreei!CorExeMain+0xfa
10 00000024`2773fca0 00007ffd`b5a07374     mscoree!CorExeMain_Exported+0x72
11 00000024`2773fcd0 00007ffd`b5ebcc91     kernel32!BaseThreadInitThunk+0x14
12 00000024`2773fd00 00000000`00000000     ntdll!RtlUserThreadStart+0x21

paddle_inference_c!paddle::CreatePaddlePredictor<paddle::AnalysisConfig,3>+0x180be:
00007ffc`d39a1a9e 488b01          mov     rax,qword ptr [rcx] ds:00000217`89df37b0=00007ffcd7791ff0
 # Child-SP          RetAddr               Call Site
00 00000024`27eff080 00007ffc`d39a1a8f     paddle_inference_c!paddle::CreatePaddlePredictor<paddle::AnalysisConfig,3>+0x180be
01 00000024`27eff0b0 00007ffc`d39a1a8f     paddle_inference_c!paddle::CreatePaddlePredictor<paddle::AnalysisConfig,3>+0x180af
02 00000024`27eff0e0 00007ffc`d39a1a8f     paddle_inference_c!paddle::CreatePaddlePredictor<paddle::AnalysisConfig,3>+0x180af
...
0e 00000024`27eff3b0 00007ffc`f20cbbde     paddle_inference_c!PD_PredictorDestroy+0x39
0f 00000024`27eff3e0 00007ffc`f943796a     0x00007ffc`f20cbbde
10 00000024`27eff4b0 00007ffc`f9437930     Sdcb_PaddleInference!Sdcb.PaddleInference.PaddlePredictor.Dispose+0x1a
11 00000024`27eff4e0 00007ffd`518915e6     Sdcb_PaddleInference!Sdcb.PaddleInference.PaddlePredictor.Finalize+0x10
12 00000024`27eff510 00007ffd`5173b6c6     clr!FastCallFinalizeWorker+0x6
13 00000024`27eff540 00007ffd`5173bd73     clr!FastCallFinalize+0x5a
14 00000024`27eff580 00007ffd`5173bcae     clr!MethodTable::CallFinalizer+0xb7
15 00000024`27eff5c0 00007ffd`5173b8e7     clr!CallFinalizer+0x5e
...
1e 00000024`27effa50 00000000`00000000     ntdll!RtlUserThreadStart+0x21

其實到這里邏輯全部清楚了,用戶點擊了關閉程序,但此時終結器線程正在執行,所以執行引擎需要等待它執行完,在這期間是禁止除終結器線程之外的任何線程再對托管方法的調用,一旦有就會拋出異常,畫個簡圖如下:

圖片圖片

3. call托管方法在哪里

在錯誤的時間出現了一個對的人,這是一種意難平,接下來把這個對的人給找出來,即 UMThunkStubRareDisableWorker方法的第二個參數pUMEntryThunk,因為這里面的 m_pManagedTarget 即托管方法的入口點,模型如下:

class UMEntryThunk
{
    private:
    // The start of the managed code
    const BYTE* m_pManagedTarget;

    // This is used for profiling.
    PTR_MethodDesc m_pMD;
}

那如何挖呢?觀察UMThunkStubRareDisableWorker方法匯編代碼即可。

0:044> k
  *** Stack trace for last set context - .thread/.cxr resets it
 # Child-SP          RetAddr               Call Site
00 00000024`2c46fb40 00007ffd`51bf8c6f     KERNELBASE!RaiseException+0x69
01 00000024`2c46fc20 00007ffd`51890108     clr!UMThunkStubRareDisableWorker+0x3f
02 00000024`2c46fc50 00007ffc`dc826748     clr!UMThunkStub+0x128
03 00000024`2c46fce0 00007ffc`dc827406     MVCAMSDK_X64+0x6748
04 00000024`2c46fd80 00007ffc`dc9d21eb     MVCAMSDK_X64!CameraGrabber_GetCameraDevInfo+0xb96
05 00000024`2c46fe50 00007ffc`dc9d227f     MVCAMSDK_X64!CameraGigeEnumerateDevice+0x167f2b
06 00000024`2c46fe80 00007ffd`b5a07374     MVCAMSDK_X64!CameraGigeEnumerateDevice+0x167fbf
07 00000024`2c46feb0 00007ffd`b5ebcc91     kernel32!BaseThreadInitThunk+0x14
08 00000024`2c46fee0 00000000`00000000     ntdll!RtlUserThreadStart+0x21

0:044> uf 00007ffd`51890108
00007ffd`5188ffe0 4154            push    r12
00007ffd`5188ffe2 55              push    rbp
00007ffd`5188ffe3 4883ec78        sub     rsp,78h
00007ffd`5188ffe7 488d6c2420      lea     rbp,[rsp+20h]
00007ffd`5188ffec c6454000        mov     byte ptr [rbp+40h],0
00007ffd`5188fff0 e8abe0ffff      call    clr!GetThread (00007ffd`5188e0a0)
00007ffd`5188fff5 4885c0          test    rax,rax
00007ffd`5188fff8 746f            je      clr!UMThunkStub+0x89 (00007ffd`51890069)  Branch
...
00007ffd`518900f9 4c895548        mov     qword ptr [rbp+48h],r10
00007ffd`518900fd 498bcc          mov     rcx,r12
00007ffd`51890100 498bd2          mov     rdx,r10
00007ffd`51890103 e8288b3600      call    clr!UMThunkStubRareDisableWorker (00007ffd`51bf8c30)

根據x64調用協定,參數是放在 r10 寄存器中,而r10剛好放在 rbp+48h 中,所以挖出這個棧位置即可,簡單計算為。

0:044> ? 00000024`2c46fce0-0x8-0x8-0x8-0x78+0x20
Evaluate expression: 155361672304 = 00000024`2c46fc70

0:044> dp 00000024`2c46fc70+0x48 L1
00000024`2c46fcb8  00000217`ff1594a0

0:044> dp 00000217`ff1594a0 L1
00000217`ff1594a0  00007ffc`f2f49380

0:044> !U 00007ffc`f2f49380
Unmanaged code
00007ffc`f2f49380 e98bbd0500      jmp     00007ffc`f2fa5110
00007ffc`f2f49385 5f              pop     rdi
00007ffc`f2f49386 0f              ???
00007ffc`f2f49387 25e8e35194      and     eax,9451E3E8h
00007ffc`f2f4938c 5e              pop     rsi
00007ffc`f2f4938d 5e              pop     rsi
00007ffc`f2f4938e 1124e8          adc     dword ptr [rax+rbp*8],esp
00007ffc`f2f49391 db5194          fist    dword ptr [rcx-6Ch]
00007ffc`f2f49394 5e              pop     rsi
00007ffc`f2f49395 5e              pop     rsi

0:044> !ip2md 00007ffc`f2fa5110
MethodDesc:   00007ffcf33bd9e8
Method Name:  baslerCamera.MVCam.CameraGrabberFrameCallback(IntPtr, IntPtr, baslerCamera.tSdkFrameHead ByRef, IntPtr)
Class:        00007ffcf33c1c98
MethodTable:  00007ffcf33be828
mdToken:      0000000006000067
Module:       00007ffcf2352f60
IsJitted:     yes
CodeAddr:     00007ffcf2fa5110
Transparency: Critical

從 baslerCamera 來看是一個工業相機,接下來趕緊尋找源代碼,截圖如下:

圖片圖片

圖中的 m_FrameCallback 是一個delegate函數,并通過 CameraGrabber_SetRGBCallback 方法傳給了C++,所以在關閉程序的時候一定要先釋放掉這個 calllback 來和C++撇清關系,否則就會有災難的降臨。

三、總結

在我的dump分析之旅中曾遇到過一次相似的生產故障,本篇文章主要還是對訓練營里這位朋友的有求必應吧,不過說實話,多分析幾個像這樣的dump,會極大的提升你的高級調試能力。

責任編輯:武曉燕 來源: 一線碼農聊技術
相關推薦

2024-05-31 12:56:06

.NET代碼方法

2024-07-12 11:20:34

.NET崩潰視覺程序

2023-06-26 00:12:46

2024-03-28 12:56:36

2022-10-09 10:47:37

NET視覺軟件

2023-03-26 20:24:50

ERP網站系統

2024-03-26 00:44:53

.NETCIM系統

2024-07-09 11:51:20

Windows線程池源碼

2022-10-25 14:17:01

.NET代碼程序

2025-10-29 01:11:00

.NET系統windows

2023-06-29 17:55:00

.NET日志WinDbg

2024-09-14 10:28:56

.NET卡死程序

2024-06-13 17:09:55

2024-06-04 10:54:34

.NET代碼程序

2023-09-27 07:23:10

.NET監控軟件

2023-10-07 13:28:53

.NET軟件賬本

2023-05-15 11:15:50

.NET門診語句

2024-06-06 10:51:15

自動化系統推測

2025-09-02 01:35:00

.NET光學定位軟件

2025-09-05 02:22:00

.NETCRM物流行業
點贊
收藏

51CTO技術棧公眾號

国产精品av在线播放| 亚洲国产精品高清久久久| 亚洲一区二区精品在线| 国产精品视频久久久久久| 婷婷综合激情| 亚洲精品在线免费播放| 欧美午夜性生活| av免费网站在线| 94色蜜桃网一区二区三区| 国产精品一区二区电影| 久久久久成人片免费观看蜜芽| 网友自拍区视频精品| 欧美日韩国产高清一区二区三区| 久久这里只有精品18| 国产精品毛片一区二区三区四区| 国产高清成人在线| 国产精品av电影| 日韩xxxxxxxxx| 亚洲第一天堂| 国产亚洲美女久久| 国产综合内射日韩久| 精品国模一区二区三区| 亚洲国产精品嫩草影院| 午夜精品一区二区三区四区| 免费看国产片在线观看| 精品写真视频在线观看 | 亚洲一区二区乱码| 日韩精品一页| 欧美亚洲一区二区在线观看| 成人免费在线网| 国产精品扒开做爽爽爽的视频| 久久嫩草精品久久久精品| 91在线在线观看| 一区二区美女视频| 日韩不卡一二三区| 97成人精品视频在线观看| 欧美黄色aaa| 成人一区不卡| 亚洲午夜女主播在线直播| 污污污www精品国产网站| 老司机亚洲精品一区二区| 欧美日韩亚洲另类| 992kp快乐看片永久免费网址| 国产夫妻在线| 亚洲成人激情综合网| 日韩精品福利片午夜免费观看| aⅴ在线视频男人的天堂| 91毛片在线观看| 国新精品乱码一区二区三区18| 国产激情视频在线播放| 国产在线一区二区| 成人黄色在线播放| 国产精品久久久久毛片| 九色综合国产一区二区三区| 国产欧美日韩高清| 91片黄在线观看喷潮| 久久成人免费电影| 成人久久精品视频| 99久久亚洲精品日本无码| 国内精品第一页| 91亚洲精品一区| 国产高清第一页| 国产jizzjizz一区二区| 草莓视频一区| 日韩一区二区三区在线观看视频| 不卡电影一区二区三区| 久久青青草原| 99免在线观看免费视频高清| 亚洲婷婷国产精品电影人久久| 免费看啪啪网站| 成人在线观看免费网站| 亚洲黄色性网站| 日本精品久久久久久久久久| 深夜在线视频| 在线日韩国产精品| 黄大色黄女片18第一次| 清纯唯美激情亚洲| 亚洲成年人在线播放| 中日韩精品一区二区三区| 精品午夜久久| 欧美老少配视频| 日韩欧美视频在线免费观看| 久久欧美肥婆一二区| 国产精品免费福利| 国产av无码专区亚洲a∨毛片| 国产91丝袜在线播放0| 久久99精品久久久久久秒播放器| 国产中文字幕在线播放| 最好看的中文字幕久久| 性一交一乱一伧国产女士spa| 在线女人免费视频| 欧美军同video69gay| 久草视频福利在线| 精品美女久久久| 欧美疯狂性受xxxxx另类| 午夜影院免费在线观看| 激情亚洲综合在线| 精品蜜桃传媒| 日韩伦理在线电影| 午夜精品福利一区二区三区蜜桃| 九色porny91| 伊色综合久久之综合久久| 国产婷婷97碰碰久久人人蜜臀| 亚洲天堂精品一区| 亚洲黄网站黄| 成人免费午夜电影| 日本护士...精品国| 亚洲欧美日韩中文字幕一区二区三区| 免费毛片网站在线观看| 四虎影视成人精品国库在线观看| 亚洲国产日韩欧美在线图片 | 人妻中文字幕一区| 日本一区二区成人| 国产精品久久中文字幕| 天堂综合在线播放| 亚洲欧洲在线视频| 久久久久性色av无码一区二区| 日本aⅴ亚洲精品中文乱码| 国产精品乱码| 好吊日视频在线观看| 日本乱人伦aⅴ精品| 波多野结衣有码| 欧美国产综合| 成人网在线视频| 国产高清在线| 日韩人体视频一二区| 91精品国产高清91久久久久久| 久久人体视频| 国产精品久久久久久久午夜| 色综合888| 午夜精品久久一牛影视| 无码人妻一区二区三区精品视频| 国产精品黑丝在线播放| 国产精品久久一区| 九色在线视频| 色呦呦一区二区三区| 污污内射在线观看一区二区少妇 | 国产女女做受ⅹxx高潮| 成人爽a毛片| 欧美黑人极品猛少妇色xxxxx| 一级特黄aaa大片| 欧美激情综合五月色丁香| 人妻精品无码一区二区三区| 精品在线网站观看| 国自产精品手机在线观看视频| 精品国产亚洲一区二区麻豆| 自拍偷自拍亚洲精品播放| 91亚洲免费视频| 日韩综合一区| 成人午夜激情免费视频| 国产激情视频在线| 91精品国产综合久久久蜜臀图片 | 午夜影视日本亚洲欧洲精品| 欧美一级片黄色| 伊人成人在线| 久久青青草原一区二区| 高清电影一区| 日韩专区在线播放| 国产欧美一区二区三区视频在线观看| 亚洲视频一二区| 91福利视频免费观看| 激情国产一区| 久久久综合亚洲91久久98| 日韩电影大全网站| 这里只有精品视频| 91国在线视频| 亚洲综合色成人| 中文字幕天堂网| 亚洲欧美日韩国产一区| 天堂一区二区三区| 久久九九精品视频| 97精品国产97久久久久久免费| 欧洲免费在线视频| 精品视频免费在线| 国产一区二区视频在线观看免费| 成人综合婷婷国产精品久久蜜臀| 国产极品尤物在线| 不卡在线一区二区| 亚洲free嫩bbb| 神马午夜在线视频| 久久精品成人动漫| 你懂的网站在线| 欧美性生活一区| 久久久久久久久久网站| 99re这里都是精品| jizzzz日本| 尹人成人综合网| 日韩中文字幕一区二区| 天堂va欧美ⅴa亚洲va一国产| 91精品国产精品| 色综合久久影院| 亚洲精品mp4| 国产巨乳在线观看| 精品久久久久久久大神国产| 五月天免费网站| 99久久精品国产网站| 五月婷婷六月合| 亚洲福利精品| 亚洲精品日韩成人| 久久国产精品免费精品3p| 国产精品夜间视频香蕉| 日本不卡免费高清视频在线| 久久精品成人动漫| 黄网在线观看| 精品久久久久久久久久久院品网 | 亚洲欧美激情一区| www天堂在线| 欧美日韩一二区| 五月婷婷视频在线| 中文字幕制服丝袜一区二区三区| 亚洲第一黄色网址| 精品影视av免费| 国产激情在线观看视频| 亚洲免费黄色| 激情视频小说图片| 奇米影视亚洲| 欧美一区观看| 欧美理论电影在线精品| 96精品久久久久中文字幕| 日韩高清在线| 欧美在线视频免费观看| 菠萝蜜视频在线观看www入口| 精品国产欧美成人夜夜嗨| 日本天堂在线| 日韩精品在线免费观看| 人妻va精品va欧美va| 91精品国产91久久综合桃花| 最近中文字幕av| 日韩欧美999| 日韩欧美亚洲一区二区三区| 一区二区三区.www| 尤物在线免费视频| 综合电影一区二区三区 | 亚洲午夜影视影院在线观看| 午夜精品一区二区三级视频| 国产精品久久久久影院老司| 欧美激情 一区| 国产日韩欧美综合在线| 中文字幕xxx| 91在线高清观看| 熟妇高潮精品一区二区三区| 99精品国产视频| 2一3sex性hd| 91在线免费视频观看| 亚洲精品在线视频免费观看| 不卡影院免费观看| 污片免费在线观看| 91免费精品国自产拍在线不卡| 在线免费看黄色片| 99视频精品全部免费在线| 亚洲精品中文字幕在线播放| 99精品视频在线观看| 中国黄色a级片| 久久久99精品免费观看不卡| 日韩毛片无码永久免费看| 日本一区二区在线不卡| 蜜桃av免费在线观看| 亚洲三级视频在线观看| 欧美色图一区二区| 亚洲国产综合在线| 国产精品黄色网| 91久久精品国产91性色tv| 成人毛片一区二区三区| 欧美性受极品xxxx喷水| 一级片在线观看视频| 日韩一区二区精品| 黄色片一区二区| 国产视频精品xxxx| 91在线看片| 美女视频久久黄| 91www在线| 国产成人小视频在线观看| jizzjizz少妇亚洲水多| 91免费的视频在线播放| 黄色成人美女网站| 日韩国产一区久久| 天天综合亚洲| 波多野结衣综合网| 蜜臀av性久久久久蜜臀aⅴ流畅 | 中文精品久久久久人妻不卡| 欧美精品 国产精品| 日本精品久久久久| 亚洲视频在线观看免费| 欧美私人网站| 国内精品久久久久| 国产a亚洲精品| 国产精品免费区二区三区观看 | 伊人久久大香线蕉综合影院首页| 岛国一区二区三区高清视频| 亚洲精品播放| 女女百合国产免费网站| 亚洲在线成人| 中文字幕在线视频一区二区| 91丨porny丨在线| 二区三区四区视频| 精品国产福利在线| 国产口爆吞精一区二区| 精品视频一区在线视频| 伊人在线视频| 欧美一区二区大胆人体摄影专业网站| 亚洲欧洲二区| 欧美日韩成人一区二区三区 | 麻豆一区二区| 中文字幕在线中文字幕日亚韩一区| 国产农村妇女毛片精品久久莱园子| 亚洲精品自拍网| 99久久免费视频.com| 国产真实乱在线更新| 欧美性猛交xxxx乱大交| 国产黄a三级三级看三级| 亚洲亚裔videos黑人hd| av中文字幕在线观看第一页| 成人免费视频a| 欧洲三级视频| 夫妻免费无码v看片| 国产福利精品一区二区| 国产又粗又硬视频| 黑人巨大精品欧美一区二区一视频| 在线免费看91| 亚洲欧美制服中文字幕| 51精品在线| 国产福利一区二区三区在线观看| 91日韩在线| 91视频免费版污| 久久夜色精品国产噜噜av| 免费无码毛片一区二区app| 4438x成人网最大色成网站| 啊v在线视频| 国产va免费精品高清在线观看| 开心激情综合| 东北少妇不带套对白| 国产精品一区二区在线播放| 男人av资源站| 欧美久久一区二区| av网站在线播放| 国产精品久久久久不卡| 国产乱码精品一区二区三区四区| 免费欧美一级视频| 久久一日本道色综合| av大全在线观看| 日韩精品视频在线播放| 麻豆国产在线| 精品欧美一区二区精品久久| 在线欧美日韩| 亚洲精品乱码久久| 疯狂欧美牲乱大交777| 天堂中文字幕在线| 日韩暖暖在线视频| 久久不卡国产精品一区二区 | 久久久久亚洲av无码专区喷水| 麻豆精品视频在线观看免费| 最新日韩免费视频| 欧美日韩国产首页在线观看| 色哟哟免费在线观看| 成人福利视频网| 中文字幕免费一区二区| 18禁一区二区三区| 午夜精品123| 日韩电影免费| 国产精品美女无圣光视频| 国产精品91一区二区三区| www.久久久久久久久久久| 亚洲男同1069视频| 亚洲欧美激情国产综合久久久| 欧美激情视频网址| 日韩极品在线| 波多结衣在线观看| 亚洲免费在线播放| 蜜臀av在线观看| 欧美一级淫片播放口| 欧美日韩国产在线观看网站| 亚洲一区二区偷拍| 亚洲国产成人91porn| 日本一卡二卡四卡精品| 国产日韩在线视频| 午夜国产精品视频免费体验区| 亚洲精品乱码久久久久久蜜桃图片| 一本色道久久综合狠狠躁的推荐| av中文在线| 99高清视频有精品视频| 国产精品久久久久久模特| 一二三四国产精品| 精品国精品自拍自在线| 这里有精品可以观看| 一级做a爰片久久| 成人av免费观看| 国产在线观看第一页| 欧美国产第一页| 精品国产a一区二区三区v免费| 波多野结衣网页| 日韩欧美有码在线| 国产精品va在线观看视色| 久久亚裔精品欧美| 狠狠v欧美v日韩v亚洲ⅴ| 久久久精品视频在线| 国产亚洲一区二区精品| 一区二区三区亚洲变态调教大结局| 欧美日韩一区二区在线免费观看| 亚洲欧美另类久久久精品| 四虎在线观看|