久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > asp.net >内容正文

asp.net

编译调试 .NET Core 5.0 Preview 并分析 Span 的实现原理

發布時間:2023/12/4 asp.net 35 豆豆
生活随笔 收集整理的這篇文章主要介紹了 编译调试 .NET Core 5.0 Preview 并分析 Span 的实现原理 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

很久沒有寫過 .NET Core 相關的文章了,目前關店在家休息所以有些時間寫一篇新的????。這次的文章主要介紹如何在 Linux 上編譯調試最新的 .NET Core 5.0 Preview 與簡單分析 Span 的實現原理。微軟從 .NET Core 5.0 開始把 GIT 倉庫 coreclr 與 corefx 合并移動到了 runtime 倉庫,原有倉庫僅用于維護 .NET Core 3.x,你可以從以下地址查看最新的源代碼:

https://github.com/dotnet/runtime

為了方便重現,接下來的編譯調試會使用 docker 與 ubuntu 18.04 鏡像(盡管微軟提供了編譯專用的鏡像但并不適合調試分析),步驟會與之前的博客介紹的 1.1,書籍介紹的 2.1 有一些不同。

如果你覺得閱讀這篇文章有困難,可以參考我之前發布的 .NET Core 源代碼分析系列或者書籍《.NET Core 底層入門》,書籍的購買鏈接在文章最后。

編譯 .NET Core 5.0 Preview

本文編譯的版本是 0d607a757372e3ecc8e942141d7f586a98694e42

創建 docker 容器

執行以下命令即可創建一個 ubuntu 18.04 的 docker 容器,注意創建時需要使用 --privileged 參數,否則無法使用 lldb 或者 gdb 調試程序。

docker run -it --privileged ubuntu:18.04

安裝 cmake

.NET Core 5.0 要求的 cmake 版本非常高,我們需要添加第三方源來安裝新版本的 cmake:

apt-get update apt-get install apt-transport-https ca-certificates gnupg software-properties-common wget -O - https://apt.kitware.com/keys/kitware-archive-latest.asc 2>/dev/null | apt-key add - apt-add-repository 'deb https://apt.kitware.com/ubuntu/ bionic main' apt-get update

安裝依賴的類庫與工具

這個步驟與之前版本的 .NET Core 相同:

apt-get install git wget locales locales-all vim apt-get install cmake llvm-3.9 clang-9 libunwind8 libunwind8-dev gettext libicu-dev liblttng-ust-dev libcurl4-openssl-dev libssl-dev libnuma-dev libkrb5-dev

下載 .NET Core 源代碼并編譯

這個步驟也與之前的 .NET Core 相同,但因為 corefx 合并到了同一個倉庫中,執行以下步驟以后會同時編譯 corefx 的 dll 文件。注意這個步驟編譯的是 Debug 版本的運行時,方便后面的調試。

git clone https://github.com/dotnet/runtime cd runtime ./build.sh

編譯完成后你可以在 artifacts 文件夾下找到編譯結果。

使用 .NET Core 5.0 Preview 執行 Hello World 程序

接下來我們會看如何使用自己編譯的 .NET Core 執行一個 Hello World 程序,.NET Core 5.0 會同時編譯出 dotnet 程序,我們可以使用它代替 corerun 來簡化運行步驟(不需要像以前的版本一樣手動復制 corefx 的 dll或者設置?CORE_ROOT?環境變量)。但因為 runtime 倉庫中不包括 sdk(sdk 在 sdk 倉庫中,這次懶得編譯),我們仍然需要另外安裝一個官方的 .NET Core 用于創建與編譯 Hello World 程序。

安裝官方的 .NET Core 3.1 SDK

wget -q https://packages.microsoft.com/config/ubuntu/19.04/packages-microsoft-prod.deb -O packages-microsoft-prod.deb dpkg -i packages-microsoft-prod.deb apt-get update apt-get install dotnet-sdk-3.1

創建與編譯 Hello World 程序

mkdir /console cd /console dotnet new console dotnet build

執行 Hello World 程序

因為使用了 .NET Core 3.1 的 SDK 編譯,我們還需要修改?程序名.runtimeconfig.json?中的運行時版本號,否則會出現版本號不一致而執行失敗的問題。

cd /console/bin/Debug/netcoreapp3.1 vi console.runtimeconfig.json

需要修改兩處:

  • runtimeOptions.tfm?修改到?netcoreapp5.0

  • runtimeOptions.framework.version?修改到?5.0.0

修改完以后使用以下命令即可執行:

/runtime/artifacts/bin/testhost/netcoreapp5.0-Linux-Debug-x64/dotnet console.dll

如果看到 Hello World 輸出就代表執行成功了。

調試 .NET Core 5.0 Preview

在 linux 上調試 .NET Core 一般使用 lldb (gdb 也可以但是沒有 SOS 插件支持),SOS 插件的源代碼被搬到了 diagnostics 倉庫,所以我們還需要下載編譯這個倉庫的源代碼。

下載編譯 diagnostics 倉庫 (LLDB SOS 插件)

安裝 LLDB 與 LLDB 的開發文件:

apt-get install clang llvm lldb liblldb-3.9-dev

下載編譯 diagnostics 倉庫:

git clone https://github.com/dotnet/diagnostics cd diagnostics ./build.sh

編譯成功后你可以在?/diagnostics/artifacts/bin/Linux.x64.Debug/libsosplugin.so?找到 SOS 插件的 dll 文件。

使用 LLDB 調試 .NET Core

SOS 插件需要在執行到達 LoadLibraryExW 后才可以正常使用,使用 LLDB 的 -o 參數可以省略每次調試的時候都要做的準備工作:

cd /console/bin/Debug/netcoreapp3.1 lldb \-o "plugin load /diagnostics/artifacts/bin/Linux.x64.Debug/libsosplugin.so" \-o "process launch -s" \-o "process handle -s false SIGUSR1 SIGUSR2" \-o "b LoadLibraryExW" \-o "c" \-o "br del 1" \-o "sos Help" \/runtime/artifacts/bin/testhost/netcoreapp5.0-Linux-Debug-x64/dotnet console.dll

執行以后會停在 LoadLibraryExW 并打印出 SOS 插件的幫助,接下來我們可以使用 SOS 插件給托管函數下斷點:

sos bpmd console.dll console.Program.Main

然后使用 c 命令繼續執行程序,直到觸發斷點:

c

到達斷點(JIT 編譯后的托管函數 Main)以后我們可以使用 SOS 插件打印這個托管函數編譯出來的匯編內容:

sos u $rip

如果到此都沒有問題,那么接下來我們可以開始分析 Span 的實現原理了。

Span 與 Memory 簡介

Span 與 Memory 是微軟推出的,用于表示某段子內容的數據類型,它們的主要目的是為了減少內存分配與復制,例如取 "abcdefg" 的子字符串 "def",傳統的方法 (Substring) 會分配一個長度為 3 的新字符串然后復制 "def" 過去,但 Span 與 Memory 可以直接使用原有的對象、子內容的開始位置與子內容的長度來表示一段子內容。在其他語言中也有類似 Span 與 Memory 的概念,例如 go 中的 slice,c 中指針與長度的結合 (例如?struct char_view { char* ptr, size_t size; }),與 c++ 中的?string_view?和?span?類型。

Span 與 Memory 的區別在于,Memory 是一個普通的類型,只保存?原有的對象、子內容的開始地址?與?子內容的長度,在內存中的表現可以參考下圖:

Memory 與很早就存在的 ArraySegment 實質上是一樣的,只是支持更多的類型,它們都不需要運行時或者編譯器的額外支持。

Span 則特殊很多,它保存了子內容的開始地址與長度(不保存原始對象的地址),使得它不需要計算開始地址并且允許指向托管對象以外的內容 (例如從 stackalloc 分配)。Span 在內存中的表現可以參考下圖:

Span 是一個?ref struct?類型 (這個類型可以說是專門為 Span 發明的),ref struct?只能保存在于棧上或者作為其他?ref struct?的成員 (最終來說只能保存在于棧上),Span 只能存在于棧上主要有以下原因:

  • GC 處理 Span 對象的成本很高,所以不應該大范圍使用

  • Span 的讀寫是非原子的(兩個指針大小),如果允許在堆上就有可能被多個線程同時訪問

  • Span 可以由 stackalloc 生成,而 Span 自身并不會標記來源是托管對象還是??臻g

因為 Span 需要運行時的額外支持,在 .NET Framework 與 Mono 上使用的 Span (從 Nuget 包安裝的) 實際上與 Memory 一樣,只有在 .Net Core 上才有以上的特性。

此外,因為部分對象的內容不可修改 (例如 string),所以還有配套的?ReadOnlySpan?與?ReadOnlyMemory,它們除了在編譯器層面上限制修改以外,與原類型沒有什么區別。

調試分析 Span 的實現原理

接下來我們可以調試一個示例程序,簡單分析 Span 在運行時中的實現原理 (這次分析不涉及到 JIT 部分,雖然 JIT 部分很少)。

以下是示例程序的代碼:

using System;namespace console {class Program{static void Main(string[] args){Span<byte> span = new byte[10] { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 };span = span.Slice(5, 2);GC.Collect();Console.WriteLine(span.Length);}} }

使用 LLDB 查看生成的匯編代碼

編譯示例程序與執行 LLDB 的命令請參考前面的內容,執行后可以使用以下命令給托管函數?Main?下斷點然后執行到斷點,并查看匯編代碼:

sos bpmd console.dll console.Program.Main c sos u $rip

輸出如下:

(lldb) sos bpmd console.dll console.Program.Main Adding pending breakpoints... (lldb) c Process 6460 resuming JITTED console!console.Program.Main(System.String[]) Setting breakpoint: breakpoint set --address 0x00007FFF7BB352D0 [console.Program.Main(System.String[])] Process 6460 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 3.1frame #0: 0x00007fff7bb352d0 -> 0x7fff7bb352d0: pushq %rbp0x7fff7bb352d1: pushq %r130x7fff7bb352d3: subq $0x48, %rsp0x7fff7bb352d7: vzeroupper (lldb) sos u $rip Normal JIT generated code console.Program.Main(System.String[]) ilAddr is 00007FFFF18BB250 pImport is 00005576894771F0 Begin 00007FFF7BB352D0, size bc/console/Program.cs @ 9: >>> 00007fff7bb352d0 55 push rbp 00007fff7bb352d1 4155 push r13 00007fff7bb352d3 4883ec48 sub rsp, 0x48 00007fff7bb352d7 c5f877 vzeroupper 00007fff7bb352da 488d6c2450 lea rbp, [rsp + 0x50] 00007fff7bb352df 4c8bef mov r13, rdi 00007fff7bb352e2 488d7db0 lea rdi, [rbp - 0x50] 00007fff7bb352e6 b910000000 mov ecx, 0x10 00007fff7bb352eb 33c0 xor eax, eax 00007fff7bb352ed f3ab rep stosd dword ptr es:[rdi], eax 00007fff7bb352ef 498bfd mov rdi, r13 00007fff7bb352f2 48897df0 mov qword ptr [rbp - 0x10], rdi 00007fff7bb352f6 48bfe05fd87bff7f0000 movabs rdi, 0x7fff7bd85fe0 00007fff7bb35300 be0a000000 mov esi, 0xa 00007fff7bb35305 e8063fe079 call 0x7ffff5939210 (JitHelp: CORINFO_HELP_NEWARR_1_VC) 00007fff7bb3530a 488945d8 mov qword ptr [rbp - 0x28], rax 00007fff7bb3530e 48bf2894e07bff7f0000 movabs rdi, 0x7fff7be09428 00007fff7bb35318 e8b396e079 call 0x7ffff593e9d0 (JitHelp: CORINFO_HELP_FIELDDESC_TO_STUBRUNTIMEFIELD) 00007fff7bb3531d 488945d0 mov qword ptr [rbp - 0x30], rax 00007fff7bb35321 488b7dd8 mov rdi, qword ptr [rbp - 0x28] 00007fff7bb35325 488b75d0 mov rsi, qword ptr [rbp - 0x30] 00007fff7bb35329 e8829f307a call 0x7ffff5e3f2b0 (System.Runtime.CompilerServices.RuntimeHelpers.InitializeArray(System.Array, System.RuntimeFieldHandle), mdToken: 0000000006003730) 00007fff7bb3532e 488b7dd8 mov rdi, qword ptr [rbp - 0x28] 00007fff7bb35332 e8f9ecffff call 0x7fff7bb34030 (System.Span`1[[System.Byte, System.Private.CoreLib]].op_Implicit(Byte[]), mdToken: 00000000060012B1) 00007fff7bb35337 488945c0 mov qword ptr [rbp - 0x40], rax 00007fff7bb3533b 488955c8 mov qword ptr [rbp - 0x38], rdx 00007fff7bb3533f c5fa6f45c0 vmovdqu xmm0, xmmword ptr [rbp - 0x40] 00007fff7bb35344 c5fa7f45e0 vmovdqu xmmword ptr [rbp - 0x20], xmm0/console/Program.cs @ 10: 00007fff7bb35349 488d7de0 lea rdi, [rbp - 0x20] 00007fff7bb3534d be05000000 mov esi, 0x5 00007fff7bb35352 ba02000000 mov edx, 0x2 00007fff7bb35357 e844edffff call 0x7fff7bb340a0 (System.Span`1[[System.Byte, System.Private.CoreLib]].Slice(Int32, Int32), mdToken: 00000000060012BE) 00007fff7bb3535c 488945b0 mov qword ptr [rbp - 0x50], rax 00007fff7bb35360 488955b8 mov qword ptr [rbp - 0x48], rdx 00007fff7bb35364 c5fa6f45b0 vmovdqu xmm0, xmmword ptr [rbp - 0x50] 00007fff7bb35369 c5fa7f45e0 vmovdqu xmmword ptr [rbp - 0x20], xmm0/console/Program.cs @ 11: 00007fff7bb3536e e845b3ffff call 0x7fff7bb306b8 (System.GC.Collect(), mdToken: 0000000006000361)/console/Program.cs @ 12: 00007fff7bb35373 488d7de0 lea rdi, [rbp - 0x20] 00007fff7bb35377 e87cecffff call 0x7fff7bb33ff8 (System.Span`1[[System.Byte, System.Private.CoreLib]].get_Length(), mdToken: 00000000060012AC) 00007fff7bb3537c 8bf8 mov edi, eax 00007fff7bb3537e e8a5fcffff call 0x7fff7bb35028 (System.Console.WriteLine(Int32), mdToken: 0000000006000089)/console/Program.cs @ 13: 00007fff7bb35383 90 nop 00007fff7bb35384 488d65f8 lea rsp, [rbp - 0x8] 00007fff7bb35388 415d pop r13 00007fff7bb3538a 5d pop rbp 00007fff7bb3538b c3 ret

我們可以看到 00007fff7bb35305 處的指令從托管堆分配了數組,00007fff7bb35329 處的指令初始化了數組內容,00007fff7bb35332 處的指令生成了第一個 span 對象,00007fff7bb35357 處的指令生成了第二個 span 對象。你可以從每一段匯編代碼上標記的文件名與行數找到對應的 C# 代碼。

分析棧上的內容

接下來我們會分析棧上的內容,包括數組的地址與 span 的內容等。

注意棧上會保存臨時變量和不使用的參數,這是因為之前的編譯沒有使用 Release 配置,你可以使用 Release 配置編譯再按這里的步驟試試有什么不同 (可能會更難理解一些),使用 Release 配置時請關閉分層編譯,使用?export COMPlus_TieredCompilation=0?即可關閉。

首先我們來看看分配數組之前棧上 (當前幀) 有什么內容:

(lldb) b 0x00007fff7bb35305 Breakpoint 4: address = 0x00007fff7bb35305 # 分配數組的指令 (lldb) c Process 6460 resuming Process 6460 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 4.1frame #0: 0x00007fff7bb35305 -> 0x7fff7bb35305: callq 0x7ffff5939210 ; JIT_NewArr1VC_MP_FastPortable at jithelpers.cpp:25600x7fff7bb3530a: movq %rax, -0x28(%rbp)0x7fff7bb3530e: movabsq $0x7fff7be09428, %rdi ; imm = 0x7FFF7BE094280x7fff7bb35318: callq 0x7ffff593e9d0 ; JIT_GetRuntimeFieldStub at jithelpers.cpp:3635 (lldb) p/x $rsp (unsigned long) $2 = 0x00007fffffffd220 # 棧頂 (lldb) p/x $rbp (unsigned long) $3 = 0x00007fffffffd270 # 幀底 (lldb) p $rbp - $rsp (unsigned long) $4 = 80 # 當前幀大小 (lldb) memory read -s 1 -c 80 0x00007fffffffd220 0x7fffffffd220: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ # 本地變量使用的空間 0x7fffffffd230: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ # 本地變量使用的空間 0x7fffffffd240: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ # 本地變量使用的空間 0x7fffffffd250: 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 ................ # 本地變量使用的空間 0x7fffffffd260: b0 d5 00 54 ff 7f 00 00 00 00 00 00 00 00 00 00 ...T............ # rbp-0x10 是 args 參數,rbp-0x8 是上一幀 r13 的值

接下來我們看看原始數組的地址與數組的內容,數組的本地變量 (臨時變量) 會保存到?$rbp-0x28,我們可以直接看這個地址中的內容。

(lldb) b 0x00007fff7bb3532e Breakpoint 5: address = 0x00007fff7bb3532e # 初始化數組后的指令 (lldb) c Process 6460 resuming Process 6460 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 5.1frame #0: 0x00007fff7bb3532e -> 0x7fff7bb3532e: movq -0x28(%rbp), %rdi0x7fff7bb35332: callq 0x7fff7bb340300x7fff7bb35337: movq %rax, -0x40(%rbp)0x7fff7bb3533b: movq %rdx, -0x38(%rbp) (lldb) p/x $rbp-0x28 (unsigned long) $6 = 0x00007fffffffd248 (lldb) memory read -s 1 -c 8 0x00007fffffffd248 0x7fffffffd248: 70 ed 00 54 ff 7f 00 00 p..T.... (lldb) dumpobj 7fff5400ed70 # SOS 插件提供的命令,用于輸出托管對象信息 Name: System.Byte[] MethodTable: 00007fff7bd85fe0 EEClass: 00007fff7bd85f30 Size: 34(0x22) bytes Array: Rank 1, Number of elements 10, Type Byte Content: .......... Fields: None (lldb) memory read -s 1 -c 26 0x7fff5400ed70 # 顯示數組對象的內容 0x7fff5400ed70: e0 5f d8 7b ff 7f 00 00 0a 00 00 00 00 00 00 00 ._.{............ # 0~8 是類型信息,8~16 是長度 0x7fff5400ed80: 01 02 03 04 05 06 07 08 09 0a .......... # 16~26 是數組內容

接下來我們可以繼續執行,然后看看各個 Span 的內容:

(lldb) b 0x00007fff7bb3536e Breakpoint 6: address = 0x00007fff7bb3536e (lldb) c Process 6460 resuming Process 6460 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 6.1frame #0: 0x00007fff7bb3536e -> 0x7fff7bb3536e: callq 0x7fff7bb306b80x7fff7bb35373: leaq -0x20(%rbp), %rdi0x7fff7bb35377: callq 0x7fff7bb33ff80x7fff7bb3537c: movl %eax, %edi (lldb) memory read -s 1 -c 16 $rbp-0x40 0x7fffffffd230: 80 ed 00 54 ff 7f 00 00 0a 00 00 00 00 00 00 00 ...T............ # 第一個 span (臨時變量) 的開始地址與長度 (lldb) memory read -s 1 -c 16 $rbp-0x50 0x7fffffffd220: 85 ed 00 54 ff 7f 00 00 02 00 00 00 00 00 00 00 ...T............ # 第二個 span (臨時變量) 的開始地址與長度 (lldb) memory read -s 1 -c 16 $rbp-0x20 0x7fffffffd250: 85 ed 00 54 ff 7f 00 00 02 00 00 00 00 00 00 00 ...T............ # 本地變量 span 中的開始地址與長度

從輸出中我們可以看到,第一個 span 的地址是 0x7fff5400ed80,這剛好是數組地址 0x7fff5400ed70 加上類型信息 (8) 與長度 (8) 以后的值,
也就是數組的內容,使用以下命令可以查看這個 span 指向的內容:

(lldb) memory read -s 1 -c 10 0x7fff5400ed80 0x7fff5400ed80: 01 02 03 04 05 06 07 08 09 0a ..........

而第二個 span 的地址 0x7fff5400ed85 則是第一個 span 的地址加 5,并且長度為 2,使用以下命令可以查看這個 span 指向的內容:

(lldb) memory read -s 1 -c 2 0x7fff5400ed85 0x7fff5400ed85: 06 07 ..

最后再看看棧上 (當前幀) 的內容:

(lldb) memory read -s 1 -c 80 0x00007fffffffd220 0x7fffffffd220: 85 ed 00 54 ff 7f 00 00 02 00 00 00 00 00 00 00 ...T............ # 本地變量 span 中的開始地址與長度 0x7fffffffd230: 80 ed 00 54 ff 7f 00 00 0a 00 00 00 00 00 00 00 ...T............ # 第一個 span (臨時變量) 的開始地址與長度 0x7fffffffd240: 98 ed 00 54 ff 7f 00 00 70 ed 00 54 ff 7f 00 00 ...T....p..T.... # 用于初始化數組的句柄,原始數組對象 (臨時變量) 0x7fffffffd250: 85 ed 00 54 ff 7f 00 00 02 00 00 00 00 00 00 00 ...T............ # 第二個 span (臨時變量) 的開始地址與長度 0x7fffffffd260: b0 d5 00 54 ff 7f 00 00 00 00 00 00 00 00 00 00 ...T............ # args 參數與上一幀 r13 的值

查看托管函數對應 GC 信息中的各個 Slot

GC 信息是 .NET 運行時查找各個線程中托管函數的本地變量 (根對象) 時使用的信息,因為 GC 信息的編碼非常復雜,這里不會介紹如何解碼 GC 信息,
而是下斷點來看各個 Slot 的內容,從掃描到標記的調用鏈跟蹤 (backtrace) 如下:

* frame #0: 0x00007ffff5cb0fcf libcoreclr.so`WKS::gc_heap::mark_object_simple(po=0x00007fffffffa460) at gc.cpp:19675frame #1: 0x00007ffff5cb6fe8 libcoreclr.so`WKS::GCHeap::Promote(ppObject=0x00007fffffffd230, sc=0x00007fffffffc9c0, flags=1) at gc.cpp:36730frame #2: 0x00007ffff5808fe8 libcoreclr.so`PromoteCarefully(fn=(libcoreclr.so`WKS::GCHeap::Promote(Object**, ScanContext*, unsigned int) at gc.cpp:36666), ppObj=0x00007fffffffd230, sc=0x00007fffffffc9c0, flags=1)(Object**, ScanContext*, unsigned int), Object**, ScanContext*, unsigned int) at siginfo.cpp:4874frame #3: 0x00007ffff5918c4a libcoreclr.so`GcEnumObject(pData=0x00007fffffffc710, pObj=0x00007fffffffd230, flags=1) at gcenv.ee.common.cpp:167frame #4: 0x00007ffff5a87abc libcoreclr.so`GcInfoDecoder::ReportStackSlotToGC(this=0x00007fffffffab38, spOffset=-80, spBase=GC_FRAMEREG_REL, gcFlags=1, pRD=0x00007fffffffb5c0, flags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc710)(void*, OBJECTREF*, unsigned int), void*) at gcinfodecoder.cpp:1848frame #5: 0x00007ffff5a88381 libcoreclr.so`GcInfoDecoder::ReportSlotToGC(this=0x00007fffffffab38, slotDecoder=0x00007fffffffa8d0, slotIndex=0, pRD=0x00007fffffffb5c0, reportScratchSlots=true, inputFlags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc710)(void*, OBJECTREF*, unsigned int), void*) at gcinfodecoder.h:679frame #6: 0x00007ffff5a8666d libcoreclr.so`GcInfoDecoder::ReportUntrackedSlots(this=0x00007fffffffab38, slotDecoder=0x00007fffffffa8d0, pRD=0x00007fffffffb5c0, inputFlags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc710)(void*, OBJECTREF*, unsigned int), void*) at gcinfodecoder.cpp:1034frame #7: 0x00007ffff5a85d28 libcoreclr.so`GcInfoDecoder::EnumerateLiveSlots(this=0x00007fffffffab38, pRD=0x00007fffffffb5c0, reportScratchSlots=false, inputFlags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc710)(void*, OBJECTREF*, unsigned int), void*) at gcinfodecoder.cpp:983frame #8: 0x00007ffff570225a libcoreclr.so`EECodeManager::EnumGcRefs(this=0x0000555555822680, pRD=0x00007fffffffb5c0, pCodeInfo=0x00007fffffffb3f0, flags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc710, relOffsetOverride=4294967295)(void*, OBJECTREF*, unsigned int), void*, unsigned int) at eetwain.cpp:5150frame #9: 0x00007ffff5919462 libcoreclr.so`GcStackCrawlCallBack(pCF=0x00007fffffffb1c0, pData=0x00007fffffffc710) at gcenv.ee.common.cpp:283frame #10: 0x00007ffff580e52f libcoreclr.so`Thread::MakeStackwalkerCallback(this=0x0000555555838aa0, pCF=0x00007fffffffb1c0, pCallback=(libcoreclr.so`GcStackCrawlCallBack(CrawlFrame*, void*) at gcenv.ee.common.cpp:201), pData=0x00007fffffffc710, uFramesProcessed=5)(CrawlFrame*, void*), void*, unsigned int) at stackwalk.cpp:886frame #11: 0x00007ffff580e77b libcoreclr.so`Thread::StackWalkFramesEx(this=0x0000555555838aa0, pRD=0x00007fffffffb5c0, pCallback=(libcoreclr.so`GcStackCrawlCallBack(CrawlFrame*, void*) at gcenv.ee.common.cpp:201), pData=0x00007fffffffc710, flags=34048, pStartFrame=0x0000000000000000)(CrawlFrame*, void*), void*, unsigned int, Frame*) at stackwalk.cpp:966frame #12: 0x00007ffff580f337 libcoreclr.so`Thread::StackWalkFrames(this=0x0000555555838aa0, pCallback=(libcoreclr.so`GcStackCrawlCallBack(CrawlFrame*, void*) at gcenv.ee.common.cpp:201), pData=0x00007fffffffc710, flags=34048, pStartFrame=0x0000000000000000)(CrawlFrame*, void*), void*, unsigned int, Frame*) at stackwalk.cpp:1049frame #13: 0x00007ffff5ceeadb libcoreclr.so`ScanStackRoots(pThread=0x0000555555838aa0, fn=(libcoreclr.so`WKS::GCHeap::Promote(Object**, ScanContext*, unsigned int) at gc.cpp:36666), sc=0x00007fffffffc9c0)(Object**, ScanContext*, unsigned int), ScanContext*) at gcenv.ee.cpp:146frame #14: 0x00007ffff5cee7ab libcoreclr.so`GCToEEInterface::GcScanRoots(fn=(libcoreclr.so`WKS::GCHeap::Promote(Object**, ScanContext*, unsigned int) at gc.cpp:36666), condemned=2, max_gen=2, sc=0x00007fffffffc9c0)(Object**, ScanContext*, unsigned int), int, int, ScanContext*) at gcenv.ee.cpp:182frame #15: 0x00007ffff5cfa3d9 libcoreclr.so`GCScan::GcScanRoots(fn=(libcoreclr.so`WKS::GCHeap::Promote(Object**, ScanContext*, unsigned int) at gc.cpp:36666), condemned=2, max_gen=2, sc=0x00007fffffffc9c0)(Object**, ScanContext*, unsigned int), int, int, ScanContext*) at gcscan.cpp:155frame #16: 0x00007ffff5c9f701 libcoreclr.so`WKS::gc_heap::mark_phase(condemned_gen_number=2, mark_only_p=NO) at gc.cpp:21062frame #17: 0x00007ffff5c9b479 libcoreclr.so`WKS::gc_heap::gc1() at gc.cpp:16713frame #18: 0x00007ffff5cab832 libcoreclr.so`WKS::gc_heap::garbage_collect(n=2) at gc.cpp:18345frame #19: 0x00007ffff5c90dea libcoreclr.so`WKS::GCHeap::GarbageCollectGeneration(this=0x0000555555793aa0, gen=2, reason=reason_induced) at gc.cpp:38188frame #20: 0x00007ffff5cdd3bb libcoreclr.so`WKS::GCHeap::GarbageCollectTry(this=0x0000555555793aa0, generation=2, low_memory_p=NO, mode=2) at gc.cpp:37524frame #21: 0x00007ffff5cde614 libcoreclr.so`WKS::GCHeap::GarbageCollect(this=0x0000555555793aa0, generation=2, low_memory_p=false, mode=2) at gc.cpp:37458frame #22: 0x00007ffff58be151 libcoreclr.so`GCInterface::Collect(generation=-1, mode=2) at comutilnative.cpp:986frame #23: 0x00007fff7bb55853frame #24: 0x00007fff7bb55788frame #25: 0x00007fff7bb553c3frame #26: 0x00007ffff5a965f3 libcoreclr.so`CallDescrWorkerInternal at unixasmmacrosamd64.inc:862frame #27: 0x00007ffff589cc9c libcoreclr.so`CallDescrWorkerWithHandler(pCallDescrData=0x00007fffffffd5a8, fCriticalCall=NO) at callhelpers.cpp:70frame #28: 0x00007ffff589da1c libcoreclr.so`MethodDescCallSite::CallTargetWorker(this=0x00007fffffffd6e0, pArguments=0x00007fffffffd680, pReturnValue=0x0000000000000000, cbReturnValue=0) at callhelpers.cpp:546frame #29: 0x00007ffff56ee983 libcoreclr.so`MethodDescCallSite::Call(this=0x00007fffffffd6e0, pArguments=0x00007fffffffd680) at callhelpers.h:459frame #30: 0x00007ffff5ac1c64 libcoreclr.so`RunMainInternal(pParam=0x00007fffffffd950) at assembly.cpp:1487frame #31: 0x00007ffff5ac1989 libcoreclr.so`RunMain(this=0x00007fffffffd858, pParam=0x00007fffffffd950)::$_1::operator()(Param*) const::'lambda'(Param*)::operator()(Param*) const at assembly.cpp:1559frame #32: 0x00007ffff5abf1f9 libcoreclr.so`RunMain(this=0x00007fffffffd940, __EXparam=0x00007fffffffd950)::$_1::operator()(Param*) const at assembly.cpp:1561frame #33: 0x00007ffff5abf019 libcoreclr.so`RunMain(pFD=0x00007fff7bd5c368, numSkipArgs=1, piRetVal=0x00007fffffffda4c, stringArgs=0x00007fffffffdf20) at assembly.cpp:1561frame #34: 0x00007ffff5abf4a2 libcoreclr.so`Assembly::ExecuteMainMethod(this=0x00005555557d4d70, stringArgs=0x00007fffffffdf20, waitForOtherThreads=YES) at assembly.cpp:1671frame #35: 0x00007ffff56e8a6b libcoreclr.so`CorHost2::ExecuteAssembly(this=0x000055555578eb40, dwAppDomainId=1, pwzAssemblyPath=u"/console/bin/Release/netcoreapp3.1/console.dll", argc=0, argv=0x0000000000000000, pReturnValue=0x00007fffffffe100) at corhost.cpp:460frame #36: 0x00007ffff568822a libcoreclr.so`::coreclr_execute_assembly(hostHandle=0x000055555578eb40, domainId=1, argc=0, argv=0x0000000000000000, managedAssemblyPath="/console/bin/Release/netcoreapp3.1/console.dll", exitCode=0x00007fffffffe100) at unixinterface.cpp:407frame #37: 0x00007ffff67dfd8a libhostpolicy.so`___lldb_unnamed_symbol100$$libhostpolicy.so + 810frame #38: 0x00007ffff67e022d libhostpolicy.so`___lldb_unnamed_symbol101$$libhostpolicy.so + 45frame #39: 0x00007ffff67e095b libhostpolicy.so`corehost_main + 203frame #40: 0x00007ffff6a4b73c libhostfxr.so`___lldb_unnamed_symbol204$$libhostfxr.so + 1740frame #41: 0x00007ffff6a49ea1 libhostfxr.so`___lldb_unnamed_symbol202$$libhostfxr.so + 641frame #42: 0x00007ffff6a444f3 libhostfxr.so`hostfxr_main_startupinfo + 147frame #43: 0x00005555555623b7 dotnet`___lldb_unnamed_symbol114$$dotnet + 791frame #44: 0x0000555555562b90 dotnet`___lldb_unnamed_symbol115$$dotnet + 128frame #45: 0x00007ffff6ca3b97 libc.so.6`__libc_start_main + 231frame #46: 0x0000555555557810 dotnet`___lldb_unnamed_symbol9$$dotnet + 41

GcInfoDecoder::EnumerateLiveSlots?是枚舉 Slot 的函數,GcInfoDecoder::ReportSlotToGC?是處理各個 Slot 的函數 (包括寄存器與棧),GcInfoDecoder::ReportStackSlotToGC?是處理棧上 (引用類型或 ref 類型) 本地變量的函數。

我們可以在?這個位置?下斷點,然后查看解析出的各個 Slot 的信息:

(lldb) b gcinfodecoder.h:679 Breakpoint 8: where = libcoreclr.so`GcInfoDecoder::ReportSlotToGC(GcSlotDecoder&, unsigned int, REGDISPLAY*, bool, unsigned int, void (*)(void*, OBJECTREF*, unsigned int), void*) + 396 at gcinfodecoder.h:679, address = 0x00007ffff5a8836c (lldb) c Process 6460 resuming Process 6460 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 8.1frame #0: 0x00007ffff5a8836c libcoreclr.so`GcInfoDecoder::ReportSlotToGC(this=0x00007fffffffab28, slotDecoder=0x00007fffffffa8c0, slotIndex=0, pRD=0x00007fffffffb5b0, reportScratchSlots=true, inputFlags=0, pCallBack=(libcoreclr.so`GcEnumObject(void*, OBJECTREF*, unsigned int) at gcenv.ee.common.cpp:148), hCallBack=0x00007fffffffc700)(void*, OBJECTREF*, unsigned int), void*) at gcinfodecoder.h:679676 GcStackSlotBase spBase = pSlot->Slot.Stack.Base;677 if( reportScratchSlots || !IsScratchStackSlot(spOffset, spBase, pRD) )678 { -> 679 ReportStackSlotToGC(680 spOffset,681 spBase,682 pSlot->Flags, (lldb) p *pSlot (const GcSlotDesc) $12 = {Slot = {RegisterNumber = 4294967216Stack = (SpOffset = -80, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_INTERIOR }

這個 Slot 代表?$rbp-80?($rbp-0x50) 處有引用類型或 ref 類型的本地變量,在前面的內容中我們已經知道?$rbp-0x50?儲存了第二個 span 對象,此外標志?GC_SLOT_INTERIOR?代表本地變量是對象中間的內存地址,而不是對象開頭(對象頭之后類型信息之前)的內存地址,這個標志會對 GC 標記與重定位對象產生很大的影響,微軟官方稱這樣的變量為?Interior Pointer。

繼續執行?c?與?p *pSlot?可以看到其他 Slot 的內容:

# $rbp-0x40, 即第一個 span 對象 (const GcSlotDesc) $13 = {Slot = {RegisterNumber = 4294967232Stack = (SpOffset = -64, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_INTERIOR } # $rbp-0x20, 即本地變量 span (const GcSlotDesc) $14 = {Slot = {RegisterNumber = 4294967264Stack = (SpOffset = -32, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_INTERIOR } # $rbp-0x30, 用于初始化數組的句柄 (const GcSlotDesc) $15 = {Slot = {RegisterNumber = 4294967248Stack = (SpOffset = -48, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_BASE } # $rbp-0x28, 原始數組對象 (const GcSlotDesc) $16 = {Slot = {RegisterNumber = 4294967256Stack = (SpOffset = -40, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_BASE } # $rbp-0x10, args 參數 (const GcSlotDesc) $17 = {Slot = {RegisterNumber = 4294967280Stack = (SpOffset = -16, Base = GC_FRAMEREG_REL)}Flags = GC_SLOT_BASE }

標志?GC_SLOT_BASE?代表是普通的引用類型變量,指向對象的開始地址。

GC 掃描 Span 對象時的處理

接下來我們看看 GC 掃描 Span 對象時會做什么處理,盡管在上述例子中棧上保留了原始數組的地址,使用 Release 模式編譯時可能會出現不保留的情況,因此 .NET Core 的運行時支持根據對象中間的地址找到對象的開始地址 (在前幾年已經實現了),重新運行程序并使用以下命令可以給標記對象存活的函數下斷點:

(lldb) b GCHeap::Promote Breakpoint 10: 2 locations.

繼續執行到達斷點以后我們可以從?ppObject?得到標記對象地址的地址,這里的對象地址是第二個 span 對象中保存的開始地址,同時 flags 為 1 即?GC_CALL_INTERIOR?代表地址為對象中間的地址:

(lldb) b GCHeap::Promote Breakpoint 2: 2 locations. (lldb) c Process 6636 resuming Process 6636 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 2.1frame #0: 0x00007ffff5cb6dc3 libcoreclr.so`WKS::GCHeap::Promote(ppObject=0x00007fffffffd220, sc=0x00007fffffffc9b0, flags=1) at gc.cpp:3666936666 {36667 THREAD_NUMBER_FROM_CONTEXT;36668 #ifndef MULTIPLE_HEAPS -> 36669 const int thread = 0;36670 #endif //!MULTIPLE_HEAPS3667136672 uint8_t* o = (uint8_t*)*ppObject; (lldb) p/x *((long*)0x00007fffffffd220) (long) $0 = 0x00007fff5400ed85

因為地址在對象中間,.NET Core 運行時需要先找到對象的開始地址才能標記對象存活 (標記存活的位是類型信息的最低位),處理的代碼如下 (文件):

#ifdef INTERIOR_POINTERS if (flags & GC_CALL_INTERIOR) {if ((o < hp->gc_low) || (o >= hp->gc_high)){return;}if ( (o = hp->find_object (o, hp->gc_low)) == 0){return;}} #endif //INTERIOR_POINTERS

這里會先判斷地址是否在托管堆中 (如果是 stackalloc 生成的就不在),然后使用?gc_heap::find_object?來找到對象的開始地址,find_object?會先找到中間地址在 Brick 表對應的 Brick,然后找到該 Brick 對應范圍中的第一個托管對象,然后一個個掃描托管對象判斷地址屬于哪個托管對象,如果找到屬于的托管對象則使用該對象的開始地址,這是一個比較昂貴的操作。關于 Brick 表可以參考我之前寫的文章。

GC 重定位 Span 對象時的處理

接下來我們看看 GC 是怎么重定位 Span 對象的,先退出 LLDB 然后執行以下命令設置環境變量,這個環境變量可以強制每次 GC 的時候都啟用壓縮:

export COMPlus_gcForceCompact=1

然后再執行 LLDB,給?GCHeap::Relocate?下斷點并執行到斷點:

(lldb) b GCHeap::Relocate Breakpoint 2: 2 locations. (lldb) c Process 6676 resuming Process 6676 stopped * thread #1, name = 'dotnet', stop reason = breakpoint 2.2frame #0: 0x00007ffff5cb4633 libcoreclr.so`WKS::GCHeap::Relocate(ppObject=0x00007fffffffd220, sc=0x00007fffffffb810, flags=1) at gc.cpp:3674136738 {36739 UNREFERENCED_PARAMETER(sc);36740 -> 36741 uint8_t* object = (uint8_t*)(Object*)(*ppObject);3674236743 THREAD_NUMBER_FROM_CONTEXT;36744 (lldb) p/x *((long*)0x00007fffffffd220) (long) $0 = 0x00007fff5400ed85

同樣的,ppObject?是標記對象地址的地址,flags 為 1 即?GC_CALL_INTERIOR。具體處理代碼如下:

if ((flags & GC_CALL_INTERIOR) && gc_heap::settings.loh_compaction) {if (!((object >= hp->gc_low) && (object < hp->gc_high))){return;}if (gc_heap::loh_object_p (object)){pheader = hp->find_object (object, 0);if (pheader == 0){return;}ptrdiff_t ref_offset = object - pheader;hp->relocate_address(&pheader THREAD_NUMBER_ARG);*ppObject = (Object*)(pheader + ref_offset);return;} }{pheader = object;hp->relocate_address(&pheader THREAD_NUMBER_ARG);*ppObject = (Object*)pheader; }

因為壓縮階段已經把對象內容移動了,重定位階段只需要修改地址到移動后的地址,不管地址是在對象開頭還是在對象中間,
對于小對象并不需要檢查標記是否帶有?GC_CALL_INTERIOR,直接找到對應的 Plug (relocate_address?會再次判斷地址是否在托管堆中),
獲取 Plug 中保存的偏移值,然后讓地址減去該偏移值即可。而大對象則需要使用?find_object?來先定位對象的開始地址,以提升處理效率。

至此我們可以發現,因為 .NET 可以只根據 Span 找到原始對象并實現標記與重定位,所以 Span 原理上是可以保存在堆上的,但這需要犧牲一定性能支持線程安全與放棄 stackalloc (或者分離到另一個類型),所以微軟沒有選擇這么做。

參考鏈接

  • https://github.com/dotnet/runtime

  • https://github.com/dotnet/runtime/blob/master/docs/workflow/building/coreclr/linux-instructions.md

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/libraries/System.Private.CoreLib/src/System/Span.cs

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/libraries/System.Private.CoreLib/src/System/ReadOnlySpan.cs

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/libraries/System.Private.CoreLib/src/System/Memory.cs

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/libraries/System.Private.CoreLib/src/System/ReadOnlyMemory.cs

  • https://raw.githubusercontent.com/dotnet/runtime/0d607a757372e3ecc8e942141d7f586a98694e42/src/coreclr/src/gc/gc.cpp

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/coreclr/src/vm/gcinfodecoder.cpp

  • https://github.com/dotnet/runtime/blob/0d607a757372e3ecc8e942141d7f586a98694e42/src/coreclr/src/inc/gcinfodecoder.h

  • https://docs.microsoft.com/en-us/archive/msdn-magazine/2018/january/csharp-all-about-span-exploring-a-new-net-mainstay

  • https://www.cnblogs.com/zkweb/p/6625049.html

寫在最后

在這里打個小廣告,我與檸檬????編寫的書籍《.NET Core 底層入門》在一月份出版了,出版社是北京航空航天大學出版社,你可以查看以下網站,找到內容介紹與購買鏈接:

https://netcoreimpl.github.io

或者直接訪問京東的購買鏈接

https://item.jd.com/12796746.html

最后傳播一下正能量,最近這段時間大家都不容易,我目前也沒有收入來源,但我們仍然需要擺正心態,相信祖國,支持政府一同抗擊疫情。
中國加油????????!武漢加油????????!國有戰,召必回,戰必勝????????!

總結

以上是生活随笔為你收集整理的编译调试 .NET Core 5.0 Preview 并分析 Span 的实现原理的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

www成人国产高清内射 | 国产av无码专区亚洲a∨毛片 | 国产成人精品久久亚洲高清不卡 | 内射巨臀欧美在线视频 | a国产一区二区免费入口 | 亚洲一区二区三区 | 特大黑人娇小亚洲女 | 在线观看国产一区二区三区 | 给我免费的视频在线观看 | 久久视频在线观看精品 | 无码av最新清无码专区吞精 | 欧美性猛交内射兽交老熟妇 | 日韩人妻系列无码专区 | 51国偷自产一区二区三区 | 高清不卡一区二区三区 | 国产精品.xx视频.xxtv | 国产精品久久久久久无码 | 国内老熟妇对白xxxxhd | 无码av免费一区二区三区试看 | 国产熟妇另类久久久久 | 精品国产青草久久久久福利 | 国产亚洲视频中文字幕97精品 | 国产香蕉97碰碰久久人人 | 亚洲精品成人av在线 | 亚洲经典千人经典日产 | 无码人中文字幕 | 精品国产国产综合精品 | 欧美 日韩 人妻 高清 中文 | 国产成人精品一区二区在线小狼 | 国产精品福利视频导航 | 国产成人综合色在线观看网站 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲成在人网站无码天堂 | 久久国内精品自在自线 | 亚洲 高清 成人 动漫 | 国产国产精品人在线视 | 亚洲第一无码av无码专区 | 亚洲s色大片在线观看 | av人摸人人人澡人人超碰下载 | 精品日本一区二区三区在线观看 | 国产精品沙发午睡系列 | 日韩精品无码一区二区中文字幕 | 久久久久久九九精品久 | 日韩视频 中文字幕 视频一区 | 在线播放亚洲第一字幕 | 欧美freesex黑人又粗又大 | 久久久中文字幕日本无吗 | 色婷婷欧美在线播放内射 | 色爱情人网站 | 欧美日韩一区二区综合 | 人妻aⅴ无码一区二区三区 | 又大又黄又粗又爽的免费视频 | 久激情内射婷内射蜜桃人妖 | 日韩av无码一区二区三区不卡 | 小鲜肉自慰网站xnxx | 亚洲精品一区二区三区在线 | 中文精品无码中文字幕无码专区 | 成人女人看片免费视频放人 | 亚洲欧洲无卡二区视頻 | 国产深夜福利视频在线 | 色欲久久久天天天综合网精品 | 日本精品久久久久中文字幕 | 奇米影视7777久久精品 | 欧美日本日韩 | 东京一本一道一二三区 | 乱人伦人妻中文字幕无码久久网 | 性啪啪chinese东北女人 | 99在线 | 亚洲 | 成人亚洲精品久久久久 | www国产精品内射老师 | 丰满肥臀大屁股熟妇激情视频 | www国产亚洲精品久久网站 | 亚洲天堂2017无码中文 | 国产手机在线αⅴ片无码观看 | 啦啦啦www在线观看免费视频 | 亚洲一区二区三区四区 | 国产av一区二区精品久久凹凸 | 老熟妇乱子伦牲交视频 | 亚洲精品中文字幕久久久久 | 激情国产av做激情国产爱 | 亚洲日本va中文字幕 | 久久久久亚洲精品男人的天堂 | 午夜性刺激在线视频免费 | 美女黄网站人色视频免费国产 | 久久国产自偷自偷免费一区调 | 国产又爽又猛又粗的视频a片 | 99久久人妻精品免费二区 | 久久久久久a亚洲欧洲av冫 | 色综合视频一区二区三区 | 久久精品国产日本波多野结衣 | √天堂资源地址中文在线 | 久久国产精品偷任你爽任你 | 99久久久国产精品无码免费 | 国内老熟妇对白xxxxhd | 欧美成人免费全部网站 | 无码任你躁久久久久久久 | 亚洲人成网站色7799 | 亚洲中文字幕av在天堂 | 人妻aⅴ无码一区二区三区 | 久久五月精品中文字幕 | 日韩人妻少妇一区二区三区 | 黑人大群体交免费视频 | 国产精品人人爽人人做我的可爱 | 好爽又高潮了毛片免费下载 | 久久午夜无码鲁丝片 | 国产人妖乱国产精品人妖 | 午夜时刻免费入口 | 红桃av一区二区三区在线无码av | 好男人www社区 | 性生交片免费无码看人 | 无码av最新清无码专区吞精 | 色噜噜亚洲男人的天堂 | 国产亚洲人成a在线v网站 | 亚洲中文无码av永久不收费 | 97夜夜澡人人爽人人喊中国片 | 亚洲日本va午夜在线电影 | 影音先锋中文字幕无码 | 日日干夜夜干 | 激情内射亚州一区二区三区爱妻 | 亚洲日韩精品欧美一区二区 | 国产69精品久久久久app下载 | 日本一区二区更新不卡 | 亚洲综合无码一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 少妇被粗大的猛进出69影院 | 国产激情艳情在线看视频 | 国产又爽又黄又刺激的视频 | 国产人妻久久精品二区三区老狼 | 狠狠色色综合网站 | 欧美成人免费全部网站 | a在线亚洲男人的天堂 | 精品久久久无码人妻字幂 | 欧美兽交xxxx×视频 | 精品无码国产一区二区三区av | 2020最新国产自产精品 | 久久精品丝袜高跟鞋 | 又湿又紧又大又爽a视频国产 | 精品国产国产综合精品 | 日本欧美一区二区三区乱码 | 正在播放东北夫妻内射 | 久久久国产一区二区三区 | 久久亚洲精品中文字幕无男同 | 最近的中文字幕在线看视频 | 最近中文2019字幕第二页 | 人妻尝试又大又粗久久 | 台湾无码一区二区 | 亚洲国产av精品一区二区蜜芽 | 国产在线精品一区二区高清不卡 | 中文字幕人妻无码一区二区三区 | 亚洲精品欧美二区三区中文字幕 | 性欧美牲交xxxxx视频 | 成人av无码一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | 欧洲熟妇精品视频 | 国精品人妻无码一区二区三区蜜柚 | 亚洲国产精品久久久久久 | 亚洲精品中文字幕久久久久 | 国产办公室秘书无码精品99 | 欧美人与动性行为视频 | 欧美一区二区三区视频在线观看 | 99久久精品无码一区二区毛片 | 无码精品国产va在线观看dvd | 国产日产欧产精品精品app | 国产亚洲欧美在线专区 | 欧美熟妇另类久久久久久多毛 | 一本色道久久综合狠狠躁 | 人人澡人摸人人添 | 国产精品第一国产精品 | 欧美老妇与禽交 | 97精品国产97久久久久久免费 | 蜜臀aⅴ国产精品久久久国产老师 | 欧洲熟妇精品视频 | 亚洲一区二区三区偷拍女厕 | 青春草在线视频免费观看 | 国产精品丝袜黑色高跟鞋 | 午夜无码人妻av大片色欲 | 亚洲啪av永久无码精品放毛片 | 精品欧洲av无码一区二区三区 | 人妻aⅴ无码一区二区三区 | а√天堂www在线天堂小说 | 精品少妇爆乳无码av无码专区 | 成人毛片一区二区 | 免费看少妇作爱视频 | 国产精品-区区久久久狼 | 最新国产乱人伦偷精品免费网站 | 亚洲精品成人av在线 | 人人爽人人澡人人人妻 | 99久久婷婷国产综合精品青草免费 | 中文字幕日韩精品一区二区三区 | 久久人人爽人人人人片 | 国产福利视频一区二区 | 亚洲精品午夜国产va久久成人 | 一本大道伊人av久久综合 | 激情五月综合色婷婷一区二区 | 国产人妻精品午夜福利免费 | 无码人中文字幕 | 少妇被粗大的猛进出69影院 | 99精品无人区乱码1区2区3区 | 精品国产av色一区二区深夜久久 | 国内精品人妻无码久久久影院蜜桃 | 国产做国产爱免费视频 | 麻豆果冻传媒2021精品传媒一区下载 | 日本丰满护士爆乳xxxx | 欧美熟妇另类久久久久久不卡 | 久久久久久国产精品无码下载 | 亚洲综合另类小说色区 | 中文字幕日韩精品一区二区三区 | 国产精品毛片一区二区 | 国产人妻精品一区二区三区不卡 | 久久人人爽人人爽人人片av高清 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲国产精品美女久久久久 | 久久婷婷五月综合色国产香蕉 | 人人爽人人爽人人片av亚洲 | 奇米影视7777久久精品人人爽 | 妺妺窝人体色www婷婷 | 67194成是人免费无码 | 又大又硬又黄的免费视频 | 又紧又大又爽精品一区二区 | 国产精品无码成人午夜电影 | 撕开奶罩揉吮奶头视频 | 十八禁视频网站在线观看 | 爽爽影院免费观看 | 欧美怡红院免费全部视频 | 男女猛烈xx00免费视频试看 | 亚洲精品中文字幕久久久久 | 大乳丰满人妻中文字幕日本 | 国产精品高潮呻吟av久久4虎 | 最近中文2019字幕第二页 | 日本大香伊一区二区三区 | 国产明星裸体无码xxxx视频 | 无码帝国www无码专区色综合 | 亚洲精品中文字幕乱码 | 噜噜噜亚洲色成人网站 | 青春草在线视频免费观看 | 人妻aⅴ无码一区二区三区 | 少妇邻居内射在线 | 免费播放一区二区三区 | 中文字幕无码免费久久9一区9 | 午夜无码人妻av大片色欲 | 久久综合色之久久综合 | 亚洲综合另类小说色区 | 日本va欧美va欧美va精品 | 亚洲中文字幕久久无码 | 欧美xxxxx精品 | 成人免费视频在线观看 | 久久婷婷五月综合色国产香蕉 | 日本大香伊一区二区三区 | 国产9 9在线 | 中文 | 国产人妖乱国产精品人妖 | 国产精品久久久久久亚洲毛片 | 国产av无码专区亚洲a∨毛片 | 国产在线一区二区三区四区五区 | 精品无码国产一区二区三区av | 国产午夜精品一区二区三区嫩草 | 18精品久久久无码午夜福利 | 欧美丰满少妇xxxx性 | 国产真实夫妇视频 | av香港经典三级级 在线 | 欧美人与禽猛交狂配 | 沈阳熟女露脸对白视频 | 国产熟妇另类久久久久 | 久久久久久久女国产乱让韩 | 一本久道久久综合婷婷五月 | 99久久久无码国产aaa精品 | 久久国产精品二国产精品 | 精品久久综合1区2区3区激情 | 精品国产福利一区二区 | 欧美性生交活xxxxxdddd | 国产美女精品一区二区三区 | 女人色极品影院 | 天堂а√在线地址中文在线 | 伊人久久大香线蕉av一区二区 | 亚洲区欧美区综合区自拍区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产情侣作爱视频免费观看 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国产精品爱久久久久久久 | 精品久久久久香蕉网 | 国产深夜福利视频在线 | 东京热无码av男人的天堂 | 欧美成人高清在线播放 | 国产激情综合五月久久 | 久9re热视频这里只有精品 | 亚洲 欧美 激情 小说 另类 | 青草视频在线播放 | 99久久精品日本一区二区免费 | 国产在线一区二区三区四区五区 | 国产xxx69麻豆国语对白 | 欧美日韩亚洲国产精品 | 亚洲成av人影院在线观看 | av无码不卡在线观看免费 | 国产精品毛片一区二区 | 国产乱人无码伦av在线a | 撕开奶罩揉吮奶头视频 | 国产精品亚洲综合色区韩国 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲精品一区国产 | 亚洲成在人网站无码天堂 | 欧洲熟妇色 欧美 | 黑人玩弄人妻中文在线 | 伊在人天堂亚洲香蕉精品区 | 国产av一区二区三区最新精品 | 午夜福利试看120秒体验区 | 澳门永久av免费网站 | 人人妻人人澡人人爽精品欧美 | 色诱久久久久综合网ywww | 亚洲欧美综合区丁香五月小说 | 色欲综合久久中文字幕网 | 久久久亚洲欧洲日产国码αv | 欧美 亚洲 国产 另类 | 人人妻人人澡人人爽欧美精品 | 亚洲色在线无码国产精品不卡 | 国产成人综合在线女婷五月99播放 | 久久人妻内射无码一区三区 | 国产麻豆精品一区二区三区v视界 | 2019午夜福利不卡片在线 | 网友自拍区视频精品 | 大地资源网第二页免费观看 | 欧美阿v高清资源不卡在线播放 | 欧美日韩人成综合在线播放 | 午夜精品一区二区三区的区别 | 久久人妻内射无码一区三区 | 最新国产乱人伦偷精品免费网站 | 亚洲国产成人a精品不卡在线 | 亚洲爆乳大丰满无码专区 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 亚洲大尺度无码无码专区 | 成 人 网 站国产免费观看 | 国产亚洲日韩欧美另类第八页 | 国产精品亚洲一区二区三区喷水 | 综合人妻久久一区二区精品 | 国产精品无码mv在线观看 | 日本爽爽爽爽爽爽在线观看免 | 久精品国产欧美亚洲色aⅴ大片 | 精品午夜福利在线观看 | 欧美黑人性暴力猛交喷水 | 午夜不卡av免费 一本久久a久久精品vr综合 | 无码人妻黑人中文字幕 | 亚洲欧洲日本综合aⅴ在线 | 亚洲日韩中文字幕在线播放 | 国产成人无码专区 | 中文精品久久久久人妻不卡 | 丰满岳乱妇在线观看中字无码 | 久久99精品久久久久婷婷 | 欧美精品国产综合久久 | 亚洲国产精品久久久天堂 | 男人扒开女人内裤强吻桶进去 | 久久久久久九九精品久 | 久久精品国产99精品亚洲 | 亚洲精品综合一区二区三区在线 | 精品无码国产一区二区三区av | 成人免费视频一区二区 | 波多野结衣乳巨码无在线观看 | 亚洲午夜无码久久 | 国产卡一卡二卡三 | 欧美乱妇无乱码大黄a片 | 亚洲成a人片在线观看无码 | 久久综合给久久狠狠97色 | 日日麻批免费40分钟无码 | 国产美女精品一区二区三区 | 高潮毛片无遮挡高清免费视频 | 好屌草这里只有精品 | 漂亮人妻洗澡被公强 日日躁 | 双乳奶水饱满少妇呻吟 | 国产在线一区二区三区四区五区 | 国产精品自产拍在线观看 | 天天拍夜夜添久久精品大 | 久久亚洲精品中文字幕无男同 | 无码国产色欲xxxxx视频 | 色欲av亚洲一区无码少妇 | 亚洲经典千人经典日产 | 亚洲中文字幕无码中字 | 成人欧美一区二区三区黑人免费 | 天天拍夜夜添久久精品 | 强开小婷嫩苞又嫩又紧视频 | 激情内射日本一区二区三区 | 亚洲成av人片在线观看无码不卡 | 岛国片人妻三上悠亚 | 久久亚洲a片com人成 | 久久久精品欧美一区二区免费 | 正在播放老肥熟妇露脸 | 在线亚洲高清揄拍自拍一品区 | 奇米影视7777久久精品人人爽 | 国内丰满熟女出轨videos | 亚洲阿v天堂在线 | a在线亚洲男人的天堂 | 国产精品免费大片 | 婷婷综合久久中文字幕蜜桃三电影 | 亚洲日韩av片在线观看 | 国产精品亚洲а∨无码播放麻豆 | 国产av人人夜夜澡人人爽麻豆 | 国产成人无码午夜视频在线观看 | 久久久婷婷五月亚洲97号色 | 女人被爽到呻吟gif动态图视看 | 97无码免费人妻超级碰碰夜夜 | 久久久久久久人妻无码中文字幕爆 | 久久亚洲精品中文字幕无男同 | 中文精品久久久久人妻不卡 | 国产高潮视频在线观看 | 中文字幕+乱码+中文字幕一区 | 成人无码影片精品久久久 | 天堂一区人妻无码 | 少妇性l交大片 | 一本加勒比波多野结衣 | 俄罗斯老熟妇色xxxx | 国产午夜视频在线观看 | 初尝人妻少妇中文字幕 | 日韩欧美中文字幕公布 | 嫩b人妻精品一区二区三区 | 久久久中文字幕日本无吗 | 成人免费无码大片a毛片 | 日日碰狠狠丁香久燥 | 久久99精品国产.久久久久 | 亚洲一区二区三区在线观看网站 | 国产午夜亚洲精品不卡 | 狠狠cao日日穞夜夜穞av | 东北女人啪啪对白 | 欧美老妇交乱视频在线观看 | 国产精品igao视频网 | 日日摸夜夜摸狠狠摸婷婷 | 国产热a欧美热a在线视频 | 无人区乱码一区二区三区 | 国内精品人妻无码久久久影院蜜桃 | 全黄性性激高免费视频 | 日本一卡2卡3卡四卡精品网站 | 午夜时刻免费入口 | 99久久人妻精品免费二区 | 国产乱人无码伦av在线a | 成人片黄网站色大片免费观看 | 熟妇人妻无乱码中文字幕 | 无码人妻丰满熟妇区毛片18 | 久久国内精品自在自线 | 亚洲熟女一区二区三区 | 一区二区三区高清视频一 | 亚洲国产精品久久久天堂 | 极品嫩模高潮叫床 | 18精品久久久无码午夜福利 | 未满小14洗澡无码视频网站 | 精品亚洲韩国一区二区三区 | 人人妻人人澡人人爽精品欧美 | 三上悠亚人妻中文字幕在线 | 男人扒开女人内裤强吻桶进去 | 国产香蕉97碰碰久久人人 | 熟女体下毛毛黑森林 | 3d动漫精品啪啪一区二区中 | 欧美自拍另类欧美综合图片区 | 一本无码人妻在中文字幕免费 | 全球成人中文在线 | 欧美乱妇无乱码大黄a片 | 中文精品无码中文字幕无码专区 | 无码中文字幕色专区 | 亚洲 欧美 激情 小说 另类 | 国产乱人伦偷精品视频 | 成人影院yy111111在线观看 | 成人无码视频在线观看网站 | 国产亚洲欧美在线专区 | 在线看片无码永久免费视频 | 国产精品久久久午夜夜伦鲁鲁 | 日本乱人伦片中文三区 | 国产午夜无码视频在线观看 | 国产97在线 | 亚洲 | 美女黄网站人色视频免费国产 | 欧美 日韩 亚洲 在线 | 国产人妻精品一区二区三区 | 久热国产vs视频在线观看 | 国产精品欧美成人 | 国产成人无码区免费内射一片色欲 | 亚洲综合无码一区二区三区 | 亚洲国产精品一区二区美利坚 | 欧美午夜特黄aaaaaa片 | 欧美熟妇另类久久久久久不卡 | 欧美丰满熟妇xxxx | 天干天干啦夜天干天2017 | 一区二区三区高清视频一 | 无码精品国产va在线观看dvd | 99久久婷婷国产综合精品青草免费 | 欧美大屁股xxxxhd黑色 | 97久久国产亚洲精品超碰热 | 久久人人爽人人爽人人片ⅴ | 四虎国产精品免费久久 | √天堂中文官网8在线 | 国产农村乱对白刺激视频 | 国产熟女一区二区三区四区五区 | 啦啦啦www在线观看免费视频 | 六十路熟妇乱子伦 | 国产成人精品三级麻豆 | 久久99国产综合精品 | 国产精品va在线观看无码 | 亚洲无人区一区二区三区 | 国产麻豆精品一区二区三区v视界 | 蜜臀av无码人妻精品 | 亚洲人成人无码网www国产 | 无码国内精品人妻少妇 | 在线成人www免费观看视频 | 免费看男女做好爽好硬视频 | 东京无码熟妇人妻av在线网址 | 一本久久a久久精品亚洲 | 国产极品美女高潮无套在线观看 | 日本va欧美va欧美va精品 | 97夜夜澡人人双人人人喊 | 国产无av码在线观看 | 中文毛片无遮挡高清免费 | 精品厕所偷拍各类美女tp嘘嘘 | 乱码av麻豆丝袜熟女系列 | 欧美性色19p | 久久综合网欧美色妞网 | 扒开双腿吃奶呻吟做受视频 | 中文字幕无码视频专区 | 国产成人无码av一区二区 | 国产精品人人爽人人做我的可爱 | 内射白嫩少妇超碰 | 亚洲欧洲中文日韩av乱码 | 亚洲熟妇色xxxxx欧美老妇 | 精品日本一区二区三区在线观看 | 伊人色综合久久天天小片 | 中文字幕 亚洲精品 第1页 | 波多野42部无码喷潮在线 | 午夜丰满少妇性开放视频 | 欧美阿v高清资源不卡在线播放 | 久久精品国产一区二区三区 | 国产精品无码成人午夜电影 | 亚洲精品午夜无码电影网 | 精品无人区无码乱码毛片国产 | 亚洲精品国产精品乱码视色 | 夜先锋av资源网站 | 无码人妻丰满熟妇区五十路百度 | 中国女人内谢69xxxxxa片 | 露脸叫床粗话东北少妇 | 色情久久久av熟女人妻网站 | 97久久精品无码一区二区 | 国产免费观看黄av片 | 色偷偷人人澡人人爽人人模 | 欧美日韩一区二区三区自拍 | 国产成人精品必看 | 99精品视频在线观看免费 | aa片在线观看视频在线播放 | 巨爆乳无码视频在线观看 | 女人被爽到呻吟gif动态图视看 | 色偷偷人人澡人人爽人人模 | 中文字幕人成乱码熟女app | 久久午夜无码鲁丝片秋霞 | 精品国产一区av天美传媒 | 人妻少妇被猛烈进入中文字幕 | 精品偷自拍另类在线观看 | 欧美激情一区二区三区成人 | 国产另类ts人妖一区二区 | 少妇激情av一区二区 | 国产精品香蕉在线观看 | 呦交小u女精品视频 | 国产农村乱对白刺激视频 | 亚洲色无码一区二区三区 | 欧美国产日韩久久mv | 人妻插b视频一区二区三区 | 一本一道久久综合久久 | 亚洲精品久久久久久一区二区 | 欧美人与物videos另类 | 高清无码午夜福利视频 | 欧美 日韩 人妻 高清 中文 | 亚洲 欧美 激情 小说 另类 | 亚洲综合伊人久久大杳蕉 | 乱码午夜-极国产极内射 | 亚洲精品鲁一鲁一区二区三区 | 5858s亚洲色大成网站www | 久久精品国产大片免费观看 | 午夜精品久久久久久久 | 日本肉体xxxx裸交 | 小sao货水好多真紧h无码视频 | 国产精品久久久久久亚洲影视内衣 | 黄网在线观看免费网站 | 东京一本一道一二三区 | aa片在线观看视频在线播放 | 国产精品久久久一区二区三区 | 99精品国产综合久久久久五月天 | 久久精品人妻少妇一区二区三区 | 亚洲自偷精品视频自拍 | 色欲综合久久中文字幕网 | 少妇无码吹潮 | 久久亚洲国产成人精品性色 | 亚洲七七久久桃花影院 | 人妻插b视频一区二区三区 | 国产做国产爱免费视频 | 好屌草这里只有精品 | 男人扒开女人内裤强吻桶进去 | 国产在线精品一区二区三区直播 | 成在人线av无码免观看麻豆 | 99麻豆久久久国产精品免费 | 久久精品人人做人人综合试看 | 免费中文字幕日韩欧美 | 精品国精品国产自在久国产87 | 熟妇人妻无码xxx视频 | 久久国内精品自在自线 | 国产成人精品无码播放 | 亚洲熟熟妇xxxx | 欧美人与牲动交xxxx | 老司机亚洲精品影院无码 | 亚洲一区二区三区国产精华液 | 无码播放一区二区三区 | 久久精品中文字幕大胸 | av人摸人人人澡人人超碰下载 | 亚洲精品国产精品乱码不卡 | 日产精品高潮呻吟av久久 | 激情内射日本一区二区三区 | 又大又紧又粉嫩18p少妇 | 内射老妇bbwx0c0ck | 国产精品久免费的黄网站 | 亚洲码国产精品高潮在线 | 免费观看的无遮挡av | 亚洲中文字幕无码中字 | 99er热精品视频 | 成人精品天堂一区二区三区 | 日韩人妻无码中文字幕视频 | 少妇无码吹潮 | 夫妻免费无码v看片 | 亚洲欧洲中文日韩av乱码 | 久久精品中文字幕一区 | 国产成人精品优优av | 欧美第一黄网免费网站 | 男人扒开女人内裤强吻桶进去 | 久久久久人妻一区精品色欧美 | 久久久精品国产sm最大网站 | 久久人人爽人人人人片 | 中文字幕无码人妻少妇免费 | 奇米影视7777久久精品 | 国产精品多人p群无码 | 国产亚洲精品久久久久久久久动漫 | 日本va欧美va欧美va精品 | 99久久久国产精品无码免费 | 久久99精品国产麻豆 | 亚洲熟熟妇xxxx | 5858s亚洲色大成网站www | 天干天干啦夜天干天2017 | 久久99热只有频精品8 | 天下第一社区视频www日本 | 久9re热视频这里只有精品 | 国产午夜视频在线观看 | 丰满少妇熟乱xxxxx视频 | 伊人久久大香线焦av综合影院 | 久久视频在线观看精品 | 免费观看激色视频网站 | 亚洲最大成人网站 | 无码毛片视频一区二区本码 | 国产午夜精品一区二区三区嫩草 | 国内精品久久久久久中文字幕 | 国产xxx69麻豆国语对白 | 日韩少妇内射免费播放 | 牲欲强的熟妇农村老妇女视频 | 久久午夜无码鲁丝片秋霞 | 日本在线高清不卡免费播放 | 内射巨臀欧美在线视频 | 玩弄中年熟妇正在播放 | 丰腴饱满的极品熟妇 | 国产av久久久久精东av | 久久zyz资源站无码中文动漫 | 亚洲精品成人福利网站 | 成人av无码一区二区三区 | 免费乱码人妻系列无码专区 | 国产极品美女高潮无套在线观看 | 亚洲狠狠婷婷综合久久 | 久久人人97超碰a片精品 | 欧美性猛交xxxx富婆 | 我要看www免费看插插视频 | 免费国产成人高清在线观看网站 | 国内精品一区二区三区不卡 | 国产乱码精品一品二品 | 国产偷抇久久精品a片69 | 无码人妻av免费一区二区三区 | 国产又粗又硬又大爽黄老大爷视 | 色婷婷综合激情综在线播放 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 大乳丰满人妻中文字幕日本 | 4hu四虎永久在线观看 | 丰满少妇女裸体bbw | 少妇人妻大乳在线视频 | 高清无码午夜福利视频 | 免费观看激色视频网站 | 久久99热只有频精品8 | 亚洲国产精品美女久久久久 | 欧美亚洲日韩国产人成在线播放 | 丰满岳乱妇在线观看中字无码 | 麻豆成人精品国产免费 | 精品偷自拍另类在线观看 | 日本护士xxxxhd少妇 | 国产精品国产三级国产专播 | 久久国产精品精品国产色婷婷 | 国产热a欧美热a在线视频 | 少妇被黑人到高潮喷出白浆 | 四虎4hu永久免费 | 欧美日韩综合一区二区三区 | 国产熟妇高潮叫床视频播放 | 国产艳妇av在线观看果冻传媒 | 人人超人人超碰超国产 | 国产又粗又硬又大爽黄老大爷视 | 欧美zoozzooz性欧美 | 亚洲码国产精品高潮在线 | 中文无码成人免费视频在线观看 | 性生交大片免费看l | 男女作爱免费网站 | 精品偷拍一区二区三区在线看 | 久久五月精品中文字幕 | 中文精品无码中文字幕无码专区 | 又粗又大又硬又长又爽 | 天天综合网天天综合色 | 麻豆精品国产精华精华液好用吗 | 国产凸凹视频一区二区 | 无码av最新清无码专区吞精 | 成人无码精品一区二区三区 | 免费人成网站视频在线观看 | 国产精品亚洲а∨无码播放麻豆 | 亚洲区欧美区综合区自拍区 | 亚洲成av人片在线观看无码不卡 | 99久久人妻精品免费二区 | 亚洲自偷精品视频自拍 | 成熟女人特级毛片www免费 | 伊人色综合久久天天小片 | 成人精品一区二区三区中文字幕 | 日产精品高潮呻吟av久久 | 日日麻批免费40分钟无码 | 色婷婷综合激情综在线播放 | 在线精品国产一区二区三区 | 亚洲熟女一区二区三区 | 一本色道久久综合亚洲精品不卡 | 搡女人真爽免费视频大全 | 无码吃奶揉捏奶头高潮视频 | 久久aⅴ免费观看 | 国产深夜福利视频在线 | 国产激情无码一区二区 | 日日碰狠狠躁久久躁蜜桃 | 日韩欧美群交p片內射中文 | 亚洲人成影院在线无码按摩店 | 欧美日韩一区二区综合 | 亚洲成熟女人毛毛耸耸多 | 性生交大片免费看l | 国产激情一区二区三区 | 99久久无码一区人妻 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 少妇厨房愉情理9仑片视频 | 国产在线精品一区二区高清不卡 | 亚洲一区二区三区在线观看网站 | 人妻少妇精品无码专区动漫 | 55夜色66夜色国产精品视频 | 久久天天躁狠狠躁夜夜免费观看 | 久久精品国产大片免费观看 | 国产成人av免费观看 | 青草青草久热国产精品 | 欧美阿v高清资源不卡在线播放 | 欧美性猛交xxxx富婆 | 日本丰满护士爆乳xxxx | 亚洲欧洲无卡二区视頻 | 国产精品无码成人午夜电影 | 国产免费久久精品国产传媒 | 中文字幕无线码免费人妻 | av小次郎收藏 | 亚洲中文字幕久久无码 | 久久精品国产99久久6动漫 | 国产99久久精品一区二区 | 无码国产激情在线观看 | 麻豆国产丝袜白领秘书在线观看 | 国产麻豆精品一区二区三区v视界 | 国产成人午夜福利在线播放 | 永久黄网站色视频免费直播 | 亚洲狠狠色丁香婷婷综合 | 伊人色综合久久天天小片 | 国产精品人人爽人人做我的可爱 | 麻豆国产人妻欲求不满谁演的 | 人妻少妇精品视频专区 | 国产在热线精品视频 | 国产人妻精品一区二区三区 | 国产xxx69麻豆国语对白 | 国产特级毛片aaaaaaa高清 | 四虎4hu永久免费 | 国产午夜视频在线观看 | √天堂中文官网8在线 | 女人高潮内射99精品 | 中文字幕无码av波多野吉衣 | 5858s亚洲色大成网站www | 丰满肥臀大屁股熟妇激情视频 | 日日鲁鲁鲁夜夜爽爽狠狠 | 欧美freesex黑人又粗又大 | 欧美午夜特黄aaaaaa片 | 国产电影无码午夜在线播放 | 久久97精品久久久久久久不卡 | 亚洲天堂2017无码中文 | 亚洲高清偷拍一区二区三区 | 人人妻人人澡人人爽欧美一区九九 | 蜜臀av在线观看 在线欧美精品一区二区三区 | 乌克兰少妇性做爰 | 无码人妻av免费一区二区三区 | 欧美日韩精品 | 亚洲无人区一区二区三区 | 丰满少妇熟乱xxxxx视频 | 亚洲国产成人a精品不卡在线 | 亚洲日韩精品欧美一区二区 | 亚洲爆乳无码专区 | 久久久久久久人妻无码中文字幕爆 | 日产精品99久久久久久 | 精品久久久无码中文字幕 | 欧美人妻一区二区三区 | 强开小婷嫩苞又嫩又紧视频 | 久久亚洲精品成人无码 | 中文亚洲成a人片在线观看 | a在线观看免费网站大全 | 亚洲精品综合五月久久小说 | 麻豆成人精品国产免费 | 久久久久亚洲精品中文字幕 | 久久99精品久久久久久动态图 | 免费男性肉肉影院 | 好爽又高潮了毛片免费下载 | 波多野结衣一区二区三区av免费 | 午夜福利试看120秒体验区 | 日日橹狠狠爱欧美视频 | 男女猛烈xx00免费视频试看 | 国产激情一区二区三区 | 久久久国产精品无码免费专区 | 亚洲国产精华液网站w | 55夜色66夜色国产精品视频 | 中文字幕av无码一区二区三区电影 | 国产精品-区区久久久狼 | 日日摸夜夜摸狠狠摸婷婷 | 久久综合网欧美色妞网 | 久久综合给合久久狠狠狠97色 | 亚洲无人区一区二区三区 | 人人澡人人妻人人爽人人蜜桃 | 欧美国产日韩久久mv | 亚洲精品美女久久久久久久 | 99久久久无码国产aaa精品 | 国产亚洲精品久久久久久久 | 一本久久伊人热热精品中文字幕 | 荫蒂添的好舒服视频囗交 | 成人性做爰aaa片免费看 | 亚洲伊人久久精品影院 | 99久久久无码国产精品免费 | 国产激情一区二区三区 | 国产女主播喷水视频在线观看 | 亚洲区欧美区综合区自拍区 | 成年美女黄网站色大免费视频 | 成人毛片一区二区 | 人人爽人人澡人人人妻 | 好男人社区资源 | 乱码av麻豆丝袜熟女系列 | 精品国产乱码久久久久乱码 | 伊人色综合久久天天小片 | 亚洲日韩av一区二区三区中文 | 又紧又大又爽精品一区二区 | 亚洲人交乣女bbw | 欧美xxxxx精品 | 国产成人综合在线女婷五月99播放 | 大胆欧美熟妇xx | 精品欧美一区二区三区久久久 | 国产超级va在线观看视频 | 日本护士xxxxhd少妇 | 亚洲欧美中文字幕5发布 | 清纯唯美经典一区二区 | 免费看男女做好爽好硬视频 | 黄网在线观看免费网站 | 国产精品久久久久影院嫩草 | 久久精品中文字幕大胸 | 综合人妻久久一区二区精品 | 国色天香社区在线视频 | 18禁黄网站男男禁片免费观看 | 欧美阿v高清资源不卡在线播放 | 强伦人妻一区二区三区视频18 | 真人与拘做受免费视频 | 性做久久久久久久免费看 | 成人影院yy111111在线观看 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产成人av免费观看 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产色精品久久人妻 | 人人爽人人澡人人高潮 | 欧美zoozzooz性欧美 | 亚洲日韩av一区二区三区四区 | 天天摸天天碰天天添 | 亚洲成av人影院在线观看 | 亚洲色欲久久久综合网东京热 | 国产精品香蕉在线观看 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 国产特级毛片aaaaaaa高清 | 日本熟妇大屁股人妻 | 日日摸天天摸爽爽狠狠97 | 风流少妇按摩来高潮 | 国产精品亚洲五月天高清 | 欧美日韩人成综合在线播放 | 少妇性俱乐部纵欲狂欢电影 | 红桃av一区二区三区在线无码av | 日本大乳高潮视频在线观看 | av人摸人人人澡人人超碰下载 | 人人妻人人澡人人爽精品欧美 | 久久久精品国产sm最大网站 | 欧美35页视频在线观看 | 日韩亚洲欧美中文高清在线 | 性开放的女人aaa片 | 无套内射视频囯产 | 老子影院午夜伦不卡 | 中文字幕无码av激情不卡 | 欧美人与禽猛交狂配 | 国内精品人妻无码久久久影院蜜桃 | 无套内射视频囯产 | 亚洲中文字幕av在天堂 | 欧美日韩一区二区免费视频 | 欧美精品免费观看二区 | 成人免费视频一区二区 | 天天摸天天碰天天添 | 中文字幕人妻丝袜二区 | 国产人妻大战黑人第1集 | 99久久亚洲精品无码毛片 | 久久国内精品自在自线 | 亚洲人交乣女bbw | 在线精品亚洲一区二区 | 亚洲人亚洲人成电影网站色 | 成人无码精品一区二区三区 | 成人欧美一区二区三区黑人 | 国产欧美熟妇另类久久久 | 久久久国产一区二区三区 | 夜夜影院未满十八勿进 | 国产激情无码一区二区 | 精品人妻av区 | 亚洲毛片av日韩av无码 | 人人妻人人澡人人爽人人精品浪潮 | 中文精品无码中文字幕无码专区 | 久久人人爽人人人人片 | 中文无码成人免费视频在线观看 | 在线精品国产一区二区三区 | 精品欧洲av无码一区二区三区 | 中文字幕无码免费久久99 | 性开放的女人aaa片 | 97无码免费人妻超级碰碰夜夜 | 亚洲人成人无码网www国产 | 最近中文2019字幕第二页 | 曰韩无码二三区中文字幕 | 日产精品99久久久久久 | 98国产精品综合一区二区三区 | 天干天干啦夜天干天2017 | 无码精品人妻一区二区三区av | 又大又硬又爽免费视频 | 四十如虎的丰满熟妇啪啪 | 人人爽人人澡人人高潮 | 国产精品沙发午睡系列 | 国产xxx69麻豆国语对白 | 久久久久久久久888 | 美女极度色诱视频国产 | 精品偷自拍另类在线观看 | 欧美人与善在线com | 少妇无套内谢久久久久 | 亚洲国产成人av在线观看 | 国产无遮挡又黄又爽又色 | 国产香蕉尹人综合在线观看 | 少妇性l交大片欧洲热妇乱xxx | 一个人免费观看的www视频 | 国产超级va在线观看视频 | 日韩精品无码一本二本三本色 | 性欧美牲交在线视频 | 丁香花在线影院观看在线播放 | 无码纯肉视频在线观看 | 国产人妻大战黑人第1集 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 超碰97人人射妻 | 国产精华av午夜在线观看 | 日本大香伊一区二区三区 | 久久99久久99精品中文字幕 | 国产精品亚洲а∨无码播放麻豆 | 日本乱偷人妻中文字幕 | 国产成人一区二区三区在线观看 | 亚洲欧洲中文日韩av乱码 | 国产精品久久久久影院嫩草 | 三级4级全黄60分钟 | 日本www一道久久久免费榴莲 | 国产无套粉嫩白浆在线 | 久久亚洲国产成人精品性色 | 日本大乳高潮视频在线观看 | 色情久久久av熟女人妻网站 | 性欧美牲交xxxxx视频 | 亚洲经典千人经典日产 | 国产猛烈高潮尖叫视频免费 | 秋霞成人午夜鲁丝一区二区三区 | 色综合久久久无码中文字幕 | 久久亚洲日韩精品一区二区三区 | 97夜夜澡人人爽人人喊中国片 | 国产精品久久久久久亚洲毛片 | 三上悠亚人妻中文字幕在线 | 亚洲欧美精品伊人久久 | 毛片内射-百度 | 无码av岛国片在线播放 | 亚洲日韩一区二区三区 | 老司机亚洲精品影院 | 欧美成人高清在线播放 | 天天做天天爱天天爽综合网 | 成人影院yy111111在线观看 | 无码人妻丰满熟妇区毛片18 | 亚洲成熟女人毛毛耸耸多 | 久久国产精品二国产精品 | 久久综合香蕉国产蜜臀av | 三级4级全黄60分钟 | 久久久中文字幕日本无吗 | 偷窥日本少妇撒尿chinese | 精品国产一区二区三区四区在线看 | 成人影院yy111111在线观看 | 小泽玛莉亚一区二区视频在线 | 精品乱码久久久久久久 | 欧洲熟妇精品视频 | 亚洲色成人中文字幕网站 | 欧洲精品码一区二区三区免费看 | 日韩精品无码免费一区二区三区 | 免费看少妇作爱视频 | 欧美自拍另类欧美综合图片区 | 无码任你躁久久久久久久 | 国产综合色产在线精品 | 亚洲精品久久久久avwww潮水 | 国产另类ts人妖一区二区 | 色综合久久久久综合一本到桃花网 | 日本大香伊一区二区三区 | 色综合久久中文娱乐网 | 亚洲欧美中文字幕5发布 | 亚洲色偷偷男人的天堂 | 国产精品久久久久久无码 | 久久精品国产99久久6动漫 | 国产激情综合五月久久 | 亚洲人亚洲人成电影网站色 | 国产亚洲欧美在线专区 | 国产真实伦对白全集 | 中文亚洲成a人片在线观看 | 亚洲精品一区二区三区在线观看 | 国产午夜亚洲精品不卡下载 | 亚洲日韩一区二区 | 国产av一区二区精品久久凹凸 | 天干天干啦夜天干天2017 | 丰满人妻精品国产99aⅴ | 99久久精品国产一区二区蜜芽 | 国产亚洲视频中文字幕97精品 | 亚洲成av人影院在线观看 | 97久久国产亚洲精品超碰热 | 中文字幕无码日韩欧毛 | 18精品久久久无码午夜福利 | √天堂资源地址中文在线 | 亚洲伊人久久精品影院 | 国产无av码在线观看 | 欧美丰满熟妇xxxx | 日韩av激情在线观看 | 久久人人爽人人爽人人片ⅴ | 东京热男人av天堂 | 少妇无套内谢久久久久 | 撕开奶罩揉吮奶头视频 | 精品人妻人人做人人爽夜夜爽 | 无遮挡国产高潮视频免费观看 | 日本一区二区三区免费播放 | 成人片黄网站色大片免费观看 | 午夜无码人妻av大片色欲 | 久久天天躁夜夜躁狠狠 | 久久99精品久久久久久动态图 | 亚洲午夜福利在线观看 | 日本www一道久久久免费榴莲 | 夫妻免费无码v看片 | 欧美色就是色 | 中文字幕乱妇无码av在线 | 十八禁视频网站在线观看 | 亚洲人成影院在线无码按摩店 | 精品人妻人人做人人爽夜夜爽 | 色综合久久久无码网中文 | 在线观看欧美一区二区三区 | 无码av免费一区二区三区试看 | 宝宝好涨水快流出来免费视频 | 久久国产精品偷任你爽任你 | 亚洲日本va午夜在线电影 | 国产亚洲美女精品久久久2020 | 亚洲成av人片天堂网无码】 | 亚拍精品一区二区三区探花 | 天堂无码人妻精品一区二区三区 | 欧美黑人巨大xxxxx | 九九在线中文字幕无码 | 国产综合色产在线精品 | 国产无遮挡又黄又爽免费视频 | 国产电影无码午夜在线播放 | 欧美喷潮久久久xxxxx | 国产猛烈高潮尖叫视频免费 | www国产亚洲精品久久网站 | 久久午夜无码鲁丝片午夜精品 | 亚洲第一无码av无码专区 | yw尤物av无码国产在线观看 | 无码人妻黑人中文字幕 | 国产精品人妻一区二区三区四 | 老太婆性杂交欧美肥老太 | 亚洲国精产品一二二线 | 久久国产精品偷任你爽任你 | 无码精品人妻一区二区三区av | 国产av剧情md精品麻豆 | 亚洲天堂2017无码 | 中国女人内谢69xxxx | 最近中文2019字幕第二页 | 日韩av激情在线观看 | 又大又硬又爽免费视频 | 狠狠色噜噜狠狠狠狠7777米奇 | 波多野结衣一区二区三区av免费 | 亚洲精品久久久久中文第一幕 | 蜜桃视频插满18在线观看 | 久久久久久国产精品无码下载 | 人妻少妇精品久久 | 欧洲精品码一区二区三区免费看 | 亚洲日韩一区二区 | 亚洲色大成网站www国产 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 欧美人与禽zoz0性伦交 | 色一情一乱一伦一区二区三欧美 | 国产精品-区区久久久狼 | 欧美 丝袜 自拍 制服 另类 | 一个人看的www免费视频在线观看 | 蜜桃视频韩日免费播放 | 亚洲啪av永久无码精品放毛片 | 99久久婷婷国产综合精品青草免费 | а√天堂www在线天堂小说 | 国产精品.xx视频.xxtv | 久久久久av无码免费网 | 欧美xxxxx精品 | 亚洲va欧美va天堂v国产综合 | 丁香花在线影院观看在线播放 | 精品无码av一区二区三区 | 少妇无码一区二区二三区 | 激情五月综合色婷婷一区二区 | 久久国语露脸国产精品电影 | 国产人妻久久精品二区三区老狼 | 国产在线一区二区三区四区五区 | 亚洲国产精品无码久久久久高潮 | 人妻中文无码久热丝袜 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 性欧美牲交在线视频 | 日日天日日夜日日摸 | 三上悠亚人妻中文字幕在线 | 俄罗斯老熟妇色xxxx | 色综合久久久久综合一本到桃花网 | 亚洲精品国偷拍自产在线麻豆 | 小sao货水好多真紧h无码视频 | 久久精品人人做人人综合 | 成人欧美一区二区三区黑人 | 女人被爽到呻吟gif动态图视看 | 久久天天躁狠狠躁夜夜免费观看 | 色窝窝无码一区二区三区色欲 | 亚洲精品综合五月久久小说 | 天天拍夜夜添久久精品 | 久久亚洲a片com人成 | 18黄暴禁片在线观看 | 思思久久99热只有频精品66 | 久久综合久久自在自线精品自 | 麻豆蜜桃av蜜臀av色欲av | 亚洲精品久久久久avwww潮水 | 免费看男女做好爽好硬视频 | 亚洲精品中文字幕乱码 | 在线天堂新版最新版在线8 | 秋霞特色aa大片 | 免费看男女做好爽好硬视频 | 窝窝午夜理论片影院 | 综合网日日天干夜夜久久 | 亚洲a无码综合a国产av中文 | 人人爽人人澡人人高潮 | 久久99国产综合精品 | 蜜臀aⅴ国产精品久久久国产老师 | 国产农村乱对白刺激视频 | 精品久久久久久亚洲精品 | 成人片黄网站色大片免费观看 | 中文字幕 亚洲精品 第1页 | 欧洲熟妇色 欧美 | 天天拍夜夜添久久精品 | 理论片87福利理论电影 | 国产色精品久久人妻 | 300部国产真实乱 | 人人妻人人澡人人爽欧美精品 | 亚洲精品久久久久avwww潮水 | 伊人久久大香线焦av综合影院 | 国产一区二区三区四区五区加勒比 | 亚洲欧美精品aaaaaa片 | 久久成人a毛片免费观看网站 | 亚洲成av人在线观看网址 | 扒开双腿吃奶呻吟做受视频 | 亚洲欧洲无卡二区视頻 | 高清国产亚洲精品自在久久 | 曰韩无码二三区中文字幕 | 俄罗斯老熟妇色xxxx | 国产综合在线观看 | 色欲久久久天天天综合网精品 | 日日天干夜夜狠狠爱 | 国产精品沙发午睡系列 | 午夜福利一区二区三区在线观看 | 97久久超碰中文字幕 | 国产精品18久久久久久麻辣 | 亚洲一区二区三区无码久久 | 色婷婷综合中文久久一本 | 四虎影视成人永久免费观看视频 | 双乳奶水饱满少妇呻吟 | 久久99久久99精品中文字幕 | 国产另类ts人妖一区二区 | 日韩精品a片一区二区三区妖精 | 精品国产一区二区三区四区在线看 | 夜夜躁日日躁狠狠久久av | 又粗又大又硬又长又爽 | 亚洲国产精品久久久久久 | 欧洲极品少妇 | 男女猛烈xx00免费视频试看 | 黄网在线观看免费网站 | 国产亚洲精品精品国产亚洲综合 | 娇妻被黑人粗大高潮白浆 | www国产亚洲精品久久久日本 | 国产内射老熟女aaaa | 国产精品亚洲综合色区韩国 | 在线欧美精品一区二区三区 | 妺妺窝人体色www在线小说 | 国产色视频一区二区三区 | 日日碰狠狠丁香久燥 | 女人被男人爽到呻吟的视频 | 水蜜桃亚洲一二三四在线 | 成人三级无码视频在线观看 | 国产午夜无码视频在线观看 | 国产亚洲日韩欧美另类第八页 | 永久免费观看美女裸体的网站 | 女人被男人躁得好爽免费视频 | 97夜夜澡人人双人人人喊 | 久久综合久久自在自线精品自 | 国产一区二区不卡老阿姨 | 国产精品久久久久久久9999 | 色老头在线一区二区三区 | 久久久久久国产精品无码下载 | 精品一二三区久久aaa片 | 亚洲狠狠婷婷综合久久 | 台湾无码一区二区 | 精品人妻av区 | 国产精品无码mv在线观看 | 老太婆性杂交欧美肥老太 | 国产区女主播在线观看 | 中文无码伦av中文字幕 | 亚洲男人av香蕉爽爽爽爽 | 东北女人啪啪对白 | 亚洲精品一区国产 | 欧美阿v高清资源不卡在线播放 | 色综合视频一区二区三区 | 国产激情精品一区二区三区 | 国产激情艳情在线看视频 | 国产超碰人人爽人人做人人添 | 欧美老人巨大xxxx做受 | 蜜臀av无码人妻精品 | 国产精品毛片一区二区 | 99久久久国产精品无码免费 | 国产精品理论片在线观看 | 性开放的女人aaa片 | 国产精品国产三级国产专播 | 国产精品.xx视频.xxtv | 国产亚洲精品久久久久久 | 久久久久成人片免费观看蜜芽 | 2019nv天堂香蕉在线观看 | 波多野结衣av一区二区全免费观看 | 午夜丰满少妇性开放视频 | 好屌草这里只有精品 | 2020久久香蕉国产线看观看 | 国产精品无码成人午夜电影 | 爱做久久久久久 | 国产精品资源一区二区 | 中文字幕av无码一区二区三区电影 | 国产肉丝袜在线观看 | 国产午夜亚洲精品不卡 | 国产精品美女久久久网av | 激情五月综合色婷婷一区二区 | 国产精品久久久久9999小说 | 国产内射爽爽大片视频社区在线 | 亚洲春色在线视频 | 激情内射亚州一区二区三区爱妻 | 水蜜桃色314在线观看 | 无码中文字幕色专区 | 成熟女人特级毛片www免费 | 中文字幕乱码人妻无码久久 | 免费无码一区二区三区蜜桃大 | 日本免费一区二区三区最新 | 成人片黄网站色大片免费观看 | 午夜福利试看120秒体验区 | 国产精品无码一区二区三区不卡 | 国产亚洲欧美在线专区 | 日韩av无码中文无码电影 | 国产精品视频免费播放 | 成人女人看片免费视频放人 | 亚洲欧洲无卡二区视頻 | 国产欧美熟妇另类久久久 | 精品人妻中文字幕有码在线 | 伊人色综合久久天天小片 | 中文字幕无码热在线视频 | 国产精品18久久久久久麻辣 | 久久久久人妻一区精品色欧美 | 成人动漫在线观看 | 麻豆md0077饥渴少妇 | 在线观看欧美一区二区三区 | 久久久久国色av免费观看性色 | 成人欧美一区二区三区 | 国产精品资源一区二区 | 日本熟妇人妻xxxxx人hd | 国产麻豆精品一区二区三区v视界 | 亚洲国产日韩a在线播放 | 国产精品久久久久影院嫩草 | 中国女人内谢69xxxxxa片 | 无码人妻久久一区二区三区不卡 | 国产精品久久久久久无码 | 亚洲精品国产品国语在线观看 | 乱中年女人伦av三区 | 久久精品中文闷骚内射 | 国产av一区二区精品久久凹凸 | 亚洲精品美女久久久久久久 | 精品久久久中文字幕人妻 | 欧美35页视频在线观看 | 波多野结衣av一区二区全免费观看 | 中文字幕久久久久人妻 | 精品国产av色一区二区深夜久久 | 国内老熟妇对白xxxxhd | 97夜夜澡人人双人人人喊 | 性生交大片免费看女人按摩摩 | 亚洲国精产品一二二线 | 久久久久久a亚洲欧洲av冫 | 美女张开腿让人桶 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲综合色区中文字幕 | 亚洲高清偷拍一区二区三区 | 国产xxx69麻豆国语对白 | 久久99国产综合精品 | 精品午夜福利在线观看 | 国产一精品一av一免费 | 亚洲精品久久久久中文第一幕 | 亚洲自偷精品视频自拍 | 国产成人精品无码播放 | 国产乡下妇女做爰 | 欧美三级a做爰在线观看 | 亚洲欧美综合区丁香五月小说 | 国产香蕉97碰碰久久人人 | 亚洲热妇无码av在线播放 | 午夜精品久久久内射近拍高清 | 亚洲日韩中文字幕在线播放 | 久久久久久av无码免费看大片 | 2020久久香蕉国产线看观看 | 漂亮人妻洗澡被公强 日日躁 | 亚洲成色www久久网站 | 国产乱子伦视频在线播放 | 性做久久久久久久久 | 东北女人啪啪对白 | 免费人成在线视频无码 | 性色欲网站人妻丰满中文久久不卡 | 无码av免费一区二区三区试看 | 少妇愉情理伦片bd | 国模大胆一区二区三区 | 亚洲熟女一区二区三区 | 亚洲国产精品美女久久久久 | 国产精品香蕉在线观看 | 一个人看的视频www在线 | 日产精品99久久久久久 | 性欧美熟妇videofreesex | 亚洲国产日韩a在线播放 | 狂野欧美性猛xxxx乱大交 | 大胆欧美熟妇xx | 欧美日韩精品 | 鲁大师影院在线观看 | www国产亚洲精品久久网站 | 久激情内射婷内射蜜桃人妖 | 国产两女互慰高潮视频在线观看 | 丝袜 中出 制服 人妻 美腿 | 性欧美videos高清精品 | aa片在线观看视频在线播放 | 大乳丰满人妻中文字幕日本 | 日日天干夜夜狠狠爱 | 午夜理论片yy44880影院 | 国产国产精品人在线视 | 99久久人妻精品免费二区 | 99精品视频在线观看免费 | 国产suv精品一区二区五 | 国产人成高清在线视频99最全资源 | 欧洲极品少妇 | 真人与拘做受免费视频 | 精品成人av一区二区三区 | 美女扒开屁股让男人桶 | 日产精品高潮呻吟av久久 | 国产婷婷色一区二区三区在线 | 久久久久免费看成人影片 | 国产偷抇久久精品a片69 | 精品久久8x国产免费观看 | 牛和人交xxxx欧美 | 激情亚洲一区国产精品 | 中文字幕精品av一区二区五区 | 狠狠亚洲超碰狼人久久 | 丰满少妇人妻久久久久久 | 欧美成人高清在线播放 | 精品一区二区三区波多野结衣 | 国产麻豆精品一区二区三区v视界 | 国产精品高潮呻吟av久久 | 久久久久久av无码免费看大片 | 亚洲色偷偷男人的天堂 | 日本一本二本三区免费 | 十八禁视频网站在线观看 | 国产亚洲精品久久久久久久 | 国产情侣作爱视频免费观看 | 国产精品18久久久久久麻辣 | 亚洲一区二区三区含羞草 | 又湿又紧又大又爽a视频国产 | 永久免费观看美女裸体的网站 | 玩弄中年熟妇正在播放 | 国产熟女一区二区三区四区五区 | 狂野欧美激情性xxxx | 欧美精品免费观看二区 | 久久99热只有频精品8 | 免费观看激色视频网站 | 99久久精品午夜一区二区 | 久久久国产一区二区三区 | 成熟人妻av无码专区 | 天海翼激烈高潮到腰振不止 | 亚洲国产一区二区三区在线观看 | 午夜成人1000部免费视频 | 少妇性l交大片欧洲热妇乱xxx | 国产香蕉尹人综合在线观看 | 亚洲最大成人网站 | 99国产欧美久久久精品 | 亚洲成色在线综合网站 | 一本精品99久久精品77 | 国产综合在线观看 | 蜜桃视频插满18在线观看 | 中文字幕av日韩精品一区二区 | 沈阳熟女露脸对白视频 | 中国女人内谢69xxxxxa片 | 国产无av码在线观看 | 欧美激情一区二区三区成人 | 人人妻人人澡人人爽欧美一区九九 | 清纯唯美经典一区二区 | 国产成人无码a区在线观看视频app | 国产精品爱久久久久久久 | 十八禁视频网站在线观看 | 亚洲综合伊人久久大杳蕉 | 东京一本一道一二三区 | 亚洲狠狠婷婷综合久久 | 亚洲日韩精品欧美一区二区 | 免费乱码人妻系列无码专区 | 久久综合给合久久狠狠狠97色 | 18无码粉嫩小泬无套在线观看 | 丰腴饱满的极品熟妇 | 老熟妇乱子伦牲交视频 | 精品久久8x国产免费观看 | 亚洲欧美日韩综合久久久 | 少妇久久久久久人妻无码 | 国产精品久久久久久久影院 | 色诱久久久久综合网ywww | 夜夜影院未满十八勿进 | 国产成人精品优优av | 欧美老熟妇乱xxxxx | 天堂无码人妻精品一区二区三区 | 中文亚洲成a人片在线观看 | 国产 浪潮av性色四虎 | 色 综合 欧美 亚洲 国产 | 久久精品视频在线看15 | 精品一区二区不卡无码av | 97夜夜澡人人双人人人喊 | 麻豆国产97在线 | 欧洲 | 黑人大群体交免费视频 | 最近的中文字幕在线看视频 | 国产成人无码av一区二区 | 国产香蕉尹人视频在线 | 樱花草在线播放免费中文 | 国产精品永久免费视频 | www国产亚洲精品久久久日本 | 欧美熟妇另类久久久久久不卡 | 无码毛片视频一区二区本码 | 国产99久久精品一区二区 | 中文字幕人妻无码一区二区三区 | 久久国产精品_国产精品 | 中国女人内谢69xxxxxa片 | 亚洲国产精华液网站w | 日本www一道久久久免费榴莲 | 成人无码精品一区二区三区 | 久久精品中文闷骚内射 | 欧美日韩色另类综合 | 久久久国产一区二区三区 | 亚洲熟妇色xxxxx欧美老妇 | 久久综合色之久久综合 | 一本久久a久久精品vr综合 | 久久久久久九九精品久 | 国产又爽又猛又粗的视频a片 | 99久久久国产精品无码免费 | 天干天干啦夜天干天2017 | 少妇激情av一区二区 | 国产性生大片免费观看性 | 亚洲中文无码av永久不收费 | 精品人人妻人人澡人人爽人人 | 国产激情精品一区二区三区 | 超碰97人人做人人爱少妇 | 色婷婷香蕉在线一区二区 | 在线看片无码永久免费视频 | 久久综合久久自在自线精品自 | 亚洲の无码国产の无码步美 | 精品夜夜澡人妻无码av蜜桃 | 久久精品人人做人人综合试看 | 中文字幕人成乱码熟女app | 亚洲精品久久久久久一区二区 | 国产97人人超碰caoprom | 国产精品沙发午睡系列 | 少妇性l交大片欧洲热妇乱xxx | 高潮毛片无遮挡高清免费 | 国产精品怡红院永久免费 | 国产高清不卡无码视频 | 久久久精品欧美一区二区免费 | 夜精品a片一区二区三区无码白浆 | 日韩少妇白浆无码系列 | 国产猛烈高潮尖叫视频免费 | 久久久婷婷五月亚洲97号色 | 国内精品人妻无码久久久影院蜜桃 | 欧美日本精品一区二区三区 | 无遮挡国产高潮视频免费观看 | 精品 日韩 国产 欧美 视频 | 国产一区二区三区四区五区加勒比 | 亚洲中文字幕乱码av波多ji | 高潮喷水的毛片 | 久久精品女人的天堂av | 国产亚洲视频中文字幕97精品 | 青草视频在线播放 | 亚洲精品久久久久久久久久久 | 亚洲精品久久久久中文第一幕 | 鲁鲁鲁爽爽爽在线视频观看 | 精品国产精品久久一区免费式 | 99久久精品无码一区二区毛片 | 中文字幕 亚洲精品 第1页 | 亚洲精品欧美二区三区中文字幕 | 国产成人无码av片在线观看不卡 | www国产亚洲精品久久网站 | 中文字幕av日韩精品一区二区 | 国产亚洲精品久久久久久 | 天海翼激烈高潮到腰振不止 | 97久久国产亚洲精品超碰热 | 高中生自慰www网站 | 在线观看国产午夜福利片 | 特大黑人娇小亚洲女 | 日本精品高清一区二区 | 欧美老妇交乱视频在线观看 | 久久久亚洲欧洲日产国码αv | 久久国产精品精品国产色婷婷 | 亚洲自偷精品视频自拍 | 国产卡一卡二卡三 | 国产精品亚洲综合色区韩国 | 狠狠色丁香久久婷婷综合五月 | 久久久久成人精品免费播放动漫 | 波多野结衣aⅴ在线 | 天堂а√在线地址中文在线 | 日产精品高潮呻吟av久久 | 在线精品亚洲一区二区 | 高潮毛片无遮挡高清免费视频 | 久久久久99精品成人片 | 99久久精品国产一区二区蜜芽 | 久久久久久久女国产乱让韩 | 欧洲熟妇精品视频 | 国产偷国产偷精品高清尤物 | 精品无码国产自产拍在线观看蜜 | 美女毛片一区二区三区四区 | 窝窝午夜理论片影院 | 欧美 日韩 亚洲 在线 | 国产精品嫩草久久久久 | 亚洲综合无码久久精品综合 | 成人欧美一区二区三区黑人免费 | 中文字幕色婷婷在线视频 | 亚洲人成网站色7799 | 亚洲日韩av一区二区三区中文 | 动漫av网站免费观看 | aⅴ在线视频男人的天堂 | 欧美丰满少妇xxxx性 | 亚洲小说图区综合在线 | 欧美性色19p | 久久久精品成人免费观看 | 人妻aⅴ无码一区二区三区 | 天天综合网天天综合色 | 国产亚洲欧美日韩亚洲中文色 | 黄网在线观看免费网站 | 欧美熟妇另类久久久久久不卡 | 宝宝好涨水快流出来免费视频 | 欧美国产日韩亚洲中文 | 欧美freesex黑人又粗又大 | 国产无遮挡吃胸膜奶免费看 | 欧美熟妇另类久久久久久不卡 | 国产精品99爱免费视频 | 久久久亚洲欧洲日产国码αv | a国产一区二区免费入口 | 欧美人与物videos另类 | 精品熟女少妇av免费观看 | 亚洲中文字幕成人无码 | 麻花豆传媒剧国产免费mv在线 | 精品夜夜澡人妻无码av蜜桃 | 久久久www成人免费毛片 | 国产69精品久久久久app下载 | 97夜夜澡人人双人人人喊 | 久9re热视频这里只有精品 | 妺妺窝人体色www在线小说 | 久久亚洲日韩精品一区二区三区 | 夜夜躁日日躁狠狠久久av | 性色av无码免费一区二区三区 | 亚洲一区二区三区偷拍女厕 | 精品无码av一区二区三区 | 自拍偷自拍亚洲精品被多人伦好爽 | 一个人看的视频www在线 | 精品乱子伦一区二区三区 | 国产熟女一区二区三区四区五区 | 性生交大片免费看女人按摩摩 | 性史性农村dvd毛片 | 日产国产精品亚洲系列 | 日本熟妇人妻xxxxx人hd | 亚洲精品www久久久 | 日本饥渴人妻欲求不满 | 久久99精品国产麻豆 | 两性色午夜视频免费播放 | 色五月五月丁香亚洲综合网 | 精品无码成人片一区二区98 | 偷窥村妇洗澡毛毛多 | 久久99精品久久久久久动态图 | 亚洲人成网站色7799 | 成熟妇人a片免费看网站 | 久久99精品久久久久婷婷 | 国产精品久免费的黄网站 | 亚洲色成人中文字幕网站 | 人人妻人人澡人人爽欧美精品 | 成人三级无码视频在线观看 | 牛和人交xxxx欧美 | 亚洲精品中文字幕乱码 | 亲嘴扒胸摸屁股激烈网站 | 久久久久99精品成人片 | 无码中文字幕色专区 | 久久国产劲爆∧v内射 | 国产人妻久久精品二区三区老狼 | 亚洲精品一区二区三区四区五区 | 国产精品二区一区二区aⅴ污介绍 | 日日摸日日碰夜夜爽av | 亚洲国产精品一区二区美利坚 | 99久久亚洲精品无码毛片 | 水蜜桃av无码 | 精品无人区无码乱码毛片国产 | 99久久精品无码一区二区毛片 | 性生交片免费无码看人 | 国产乱人无码伦av在线a | 免费国产黄网站在线观看 | 国产精品.xx视频.xxtv | 丰满少妇人妻久久久久久 | 未满小14洗澡无码视频网站 | 亚洲综合色区中文字幕 | 亚洲日韩一区二区三区 | 亚洲va中文字幕无码久久不卡 | 色一情一乱一伦一区二区三欧美 | 丰满诱人的人妻3 | 久久久久免费看成人影片 | 日本www一道久久久免费榴莲 | 精品国产一区二区三区av 性色 | 国产成人一区二区三区别 | 亚洲成av人在线观看网址 | 亚洲 另类 在线 欧美 制服 | 久久天天躁夜夜躁狠狠 | 色婷婷久久一区二区三区麻豆 | 国产激情艳情在线看视频 | av在线亚洲欧洲日产一区二区 | 老司机亚洲精品影院无码 | 日本熟妇浓毛 | 妺妺窝人体色www在线小说 | 精品一二三区久久aaa片 | 无套内谢的新婚少妇国语播放 | 97se亚洲精品一区 | 小泽玛莉亚一区二区视频在线 | 大肉大捧一进一出视频出来呀 | 国产综合色产在线精品 | 55夜色66夜色国产精品视频 | 亚洲gv猛男gv无码男同 | 丰满人妻一区二区三区免费视频 | 欧美变态另类xxxx | 久久久久久久久蜜桃 | 久青草影院在线观看国产 | 国产亚洲日韩欧美另类第八页 | 扒开双腿吃奶呻吟做受视频 | 精品久久8x国产免费观看 | 在线天堂新版最新版在线8 | 免费中文字幕日韩欧美 | 欧美 丝袜 自拍 制服 另类 | 亚洲精品欧美二区三区中文字幕 | 日韩人妻系列无码专区 | 国产无av码在线观看 | 亚洲精品国偷拍自产在线麻豆 | 国产肉丝袜在线观看 | 捆绑白丝粉色jk震动捧喷白浆 | 日韩在线不卡免费视频一区 | 中文无码伦av中文字幕 | 国产人妻精品一区二区三区 |