3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > 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 的实现原理的全部內容,希望文章能夠幫你解決所遇到的問題。

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

亚洲国产精品久久人人爱 | 午夜无码人妻av大片色欲 | 国产精品对白交换视频 | 国产午夜无码视频在线观看 | 奇米影视7777久久精品人人爽 | 久久久亚洲欧洲日产国码αv | 曰韩无码二三区中文字幕 | 亚洲精品久久久久中文第一幕 | 亚洲精品综合五月久久小说 | 亚洲午夜福利在线观看 | 国内丰满熟女出轨videos | ass日本丰满熟妇pics | 任你躁国产自任一区二区三区 | 亚洲色大成网站www国产 | 奇米影视888欧美在线观看 | 2019午夜福利不卡片在线 | 成人免费视频在线观看 | 理论片87福利理论电影 | 亚洲第一无码av无码专区 | 老熟女重囗味hdxx69 | 人人爽人人澡人人高潮 | 久久国产精品精品国产色婷婷 | 小鲜肉自慰网站xnxx | 国精产品一区二区三区 | 婷婷六月久久综合丁香 | 奇米影视7777久久精品 | 两性色午夜视频免费播放 | 亚洲s色大片在线观看 | 欧美日韩一区二区综合 | 国色天香社区在线视频 | 狠狠色色综合网站 | 纯爱无遮挡h肉动漫在线播放 | 色婷婷av一区二区三区之红樱桃 | 熟女体下毛毛黑森林 | 麻豆国产丝袜白领秘书在线观看 | 最新国产乱人伦偷精品免费网站 | 西西人体www44rt大胆高清 | 国产色xx群视频射精 | 乌克兰少妇xxxx做受 | 中文字幕乱码人妻无码久久 | 日韩av无码一区二区三区 | 亚洲欧洲日本综合aⅴ在线 | 亚洲成a人一区二区三区 | 300部国产真实乱 | 曰本女人与公拘交酡免费视频 | 少妇愉情理伦片bd | 宝宝好涨水快流出来免费视频 | 亚洲日韩精品欧美一区二区 | 国产无遮挡又黄又爽免费视频 | 激情人妻另类人妻伦 | 丰满人妻一区二区三区免费视频 | 无码中文字幕色专区 | 久久人人97超碰a片精品 | v一区无码内射国产 | 国产无遮挡又黄又爽免费视频 | 综合激情五月综合激情五月激情1 | 久久久国产精品无码免费专区 | 国内少妇偷人精品视频免费 | 久久久中文字幕日本无吗 | 久久久久久av无码免费看大片 | 精品国偷自产在线视频 | 网友自拍区视频精品 | 一区二区传媒有限公司 | 欧美性生交xxxxx久久久 | 久久久久人妻一区精品色欧美 | 国产婷婷色一区二区三区在线 | 日日天干夜夜狠狠爱 | 国产卡一卡二卡三 | 日本一本二本三区免费 | 少妇性l交大片欧洲热妇乱xxx | 成人免费视频一区二区 | 又大又紧又粉嫩18p少妇 | 久久精品一区二区三区四区 | 中文字幕久久久久人妻 | 乱人伦人妻中文字幕无码 | 精品偷拍一区二区三区在线看 | 成年美女黄网站色大免费全看 | 狠狠色丁香久久婷婷综合五月 | 久久精品国产日本波多野结衣 | 亚洲精品国产精品乱码视色 | 国产内射爽爽大片视频社区在线 | 激情综合激情五月俺也去 | 国产超级va在线观看视频 | 免费无码的av片在线观看 | 亚洲国产高清在线观看视频 | 国产精品成人av在线观看 | 日韩欧美中文字幕公布 | 亚洲精品无码人妻无码 | 乱人伦人妻中文字幕无码 | 亚洲色欲久久久综合网东京热 | 少妇高潮一区二区三区99 | 黑人大群体交免费视频 | 久久久久99精品国产片 | 国产特级毛片aaaaaaa高清 | 免费观看激色视频网站 | 国产精品无码久久av | 国产av一区二区精品久久凹凸 | 大乳丰满人妻中文字幕日本 | 亚洲中文字幕在线无码一区二区 | av无码久久久久不卡免费网站 | 曰韩无码二三区中文字幕 | 性欧美熟妇videofreesex | 欧美日本精品一区二区三区 | 国产免费久久久久久无码 | 美女极度色诱视频国产 | 久久精品国产精品国产精品污 | 粗大的内捧猛烈进出视频 | 中文字幕av伊人av无码av | 久久国产精品二国产精品 | 97精品国产97久久久久久免费 | 国产艳妇av在线观看果冻传媒 | 激情五月综合色婷婷一区二区 | 亚洲一区二区三区香蕉 | 人妻熟女一区 | 全球成人中文在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 久久人人爽人人爽人人片ⅴ | 日本精品久久久久中文字幕 | 欧美一区二区三区视频在线观看 | 欧美精品免费观看二区 | 日本www一道久久久免费榴莲 | 成人毛片一区二区 | 亚洲成a人片在线观看日本 | 亚洲一区二区三区偷拍女厕 | 一区二区三区高清视频一 | 久久人妻内射无码一区三区 | 国产超级va在线观看视频 | 老司机亚洲精品影院无码 | 好男人社区资源 | 亚洲精品一区国产 | 午夜精品久久久内射近拍高清 | 久久亚洲精品成人无码 | 国产区女主播在线观看 | 又黄又爽又色的视频 | 欧美自拍另类欧美综合图片区 | 人妻少妇精品久久 | 99久久亚洲精品无码毛片 | 国产美女精品一区二区三区 | 国产 浪潮av性色四虎 | 真人与拘做受免费视频一 | 动漫av一区二区在线观看 | 国产乡下妇女做爰 | 老头边吃奶边弄进去呻吟 | 一个人看的www免费视频在线观看 | 四虎永久在线精品免费网址 | 国产亚洲tv在线观看 | 久久久精品欧美一区二区免费 | 小sao货水好多真紧h无码视频 | 精品人妻人人做人人爽夜夜爽 | 国内精品人妻无码久久久影院 | 欧美刺激性大交 | 草草网站影院白丝内射 | 国产美女精品一区二区三区 | 国产精华av午夜在线观看 | 亚洲大尺度无码无码专区 | 伊人色综合久久天天小片 | 亚洲欧美国产精品专区久久 | 人妻少妇精品无码专区二区 | 日韩精品成人一区二区三区 | 欧美成人免费全部网站 | 亚洲爆乳大丰满无码专区 | 色欲久久久天天天综合网精品 | 99久久久国产精品无码免费 | 国产精品亚洲五月天高清 | 四虎4hu永久免费 | 樱花草在线社区www | 最新国产乱人伦偷精品免费网站 | 中文字幕日韩精品一区二区三区 | 国产卡一卡二卡三 | 亚洲中文无码av永久不收费 | 亚洲精品一区二区三区大桥未久 | 亚洲综合久久一区二区 | 成人无码精品1区2区3区免费看 | 最近免费中文字幕中文高清百度 | 亚洲精品国产品国语在线观看 | 国产精品二区一区二区aⅴ污介绍 | 久久午夜无码鲁丝片秋霞 | 中文字幕无码av激情不卡 | 中文无码伦av中文字幕 | 中文字幕 人妻熟女 | 婷婷六月久久综合丁香 | 亚洲欧洲中文日韩av乱码 | 亚洲精品国产品国语在线观看 | 领导边摸边吃奶边做爽在线观看 | 亚洲a无码综合a国产av中文 | 久久www免费人成人片 | 荡女精品导航 | 亚洲一区二区三区四区 | 人人爽人人爽人人片av亚洲 | 无套内谢的新婚少妇国语播放 | 东京热一精品无码av | 啦啦啦www在线观看免费视频 | 亚洲综合另类小说色区 | 18禁黄网站男男禁片免费观看 | 亚洲欧洲日本综合aⅴ在线 | 伊人色综合久久天天小片 | 色噜噜亚洲男人的天堂 | 国产人妻人伦精品 | 成熟女人特级毛片www免费 | 国产精品丝袜黑色高跟鞋 | 草草网站影院白丝内射 | 日欧一片内射va在线影院 | 亚洲精品国产品国语在线观看 | 99国产欧美久久久精品 | 亚洲乱码国产乱码精品精 | 国产精品理论片在线观看 | 少妇性俱乐部纵欲狂欢电影 | 久久久久av无码免费网 | 综合人妻久久一区二区精品 | 99久久亚洲精品无码毛片 | 久久精品中文闷骚内射 | 久久无码人妻影院 | 久久精品国产99久久6动漫 | 欧美人与动性行为视频 | 国产人妻人伦精品 | 无码精品国产va在线观看dvd | 亚洲综合无码一区二区三区 | 亚洲精品无码人妻无码 | 亚洲第一无码av无码专区 | 久久综合狠狠综合久久综合88 | 国产真实夫妇视频 | 色欲av亚洲一区无码少妇 | 激情综合激情五月俺也去 | 中文字幕av无码一区二区三区电影 | 精品国产麻豆免费人成网站 | 一二三四社区在线中文视频 | 国产人妻人伦精品 | 亚洲精品www久久久 | 国産精品久久久久久久 | 亚洲日韩一区二区三区 | 人妻尝试又大又粗久久 | 人妻插b视频一区二区三区 | 99国产精品白浆在线观看免费 | 中文字幕+乱码+中文字幕一区 | 国产精品毛片一区二区 | 少妇人妻偷人精品无码视频 | 亚洲aⅴ无码成人网站国产app | 99在线 | 亚洲 | 狠狠色噜噜狠狠狠狠7777米奇 | 久久国内精品自在自线 | 人妻无码久久精品人妻 | 精品成人av一区二区三区 | 日本www一道久久久免费榴莲 | 成年女人永久免费看片 | 免费视频欧美无人区码 | 理论片87福利理论电影 | 99久久无码一区人妻 | 亚洲精品久久久久中文第一幕 | 久久 国产 尿 小便 嘘嘘 | 国产国产精品人在线视 | 亚洲一区二区三区四区 | 亚洲国产精品美女久久久久 | 久久国产精品萌白酱免费 | 99麻豆久久久国产精品免费 | 色综合天天综合狠狠爱 | 亚洲中文字幕成人无码 | 久久久久av无码免费网 | 国产午夜福利100集发布 | 亚洲人成网站在线播放942 | 欧美国产日产一区二区 | 一本久久伊人热热精品中文字幕 | 在线a亚洲视频播放在线观看 | 日产精品高潮呻吟av久久 | 国产精品18久久久久久麻辣 | 男女下面进入的视频免费午夜 | 欧美黑人乱大交 | 亚洲一区二区三区在线观看网站 | 一本久道久久综合婷婷五月 | 久久99精品国产.久久久久 | 99国产精品白浆在线观看免费 | 国产精品久久久一区二区三区 | 中文字幕无码热在线视频 | 色婷婷综合中文久久一本 | 国产成人精品三级麻豆 | 国产xxx69麻豆国语对白 | 亚洲狠狠色丁香婷婷综合 | 亚洲 激情 小说 另类 欧美 | 国产又爽又黄又刺激的视频 | 偷窥村妇洗澡毛毛多 | 丝袜足控一区二区三区 | 男女下面进入的视频免费午夜 | 激情亚洲一区国产精品 | 精品日本一区二区三区在线观看 | 99国产精品白浆在线观看免费 | 综合网日日天干夜夜久久 | 动漫av网站免费观看 | 免费无码午夜福利片69 | 成人影院yy111111在线观看 | 亚洲国产午夜精品理论片 | 色欲久久久天天天综合网精品 | 成人欧美一区二区三区黑人 | 亚洲s码欧洲m码国产av | 国产精品人妻一区二区三区四 | 人人澡人摸人人添 | 欧美人与禽zoz0性伦交 | 亚洲一区二区三区四区 | 大肉大捧一进一出好爽视频 | 在线播放免费人成毛片乱码 | 国产精品久久久av久久久 | 亚洲国产欧美在线成人 | 精品国产一区二区三区av 性色 | 任你躁在线精品免费 | 性欧美牲交在线视频 | 国产av一区二区精品久久凹凸 | 日韩欧美中文字幕在线三区 | 伊人色综合久久天天小片 | 国产色在线 | 国产 | 欧美zoozzooz性欧美 | 国产深夜福利视频在线 | 欧美日韩一区二区综合 | 国产两女互慰高潮视频在线观看 | 亚洲精品国产精品乱码不卡 | 夜夜躁日日躁狠狠久久av | 搡女人真爽免费视频大全 | 国产精品嫩草久久久久 | 无码播放一区二区三区 | 精品久久8x国产免费观看 | 亚无码乱人伦一区二区 | 97久久超碰中文字幕 | 午夜不卡av免费 一本久久a久久精品vr综合 | 亚洲欧美日韩国产精品一区二区 | 永久免费观看国产裸体美女 | 清纯唯美经典一区二区 | 国产亚洲人成在线播放 | 曰韩无码二三区中文字幕 | 天堂无码人妻精品一区二区三区 | 麻豆av传媒蜜桃天美传媒 | 亚洲熟女一区二区三区 | 少妇被粗大的猛进出69影院 | 亚洲理论电影在线观看 | 成人毛片一区二区 | 国产熟女一区二区三区四区五区 | 国产成人无码av在线影院 | 精品欧美一区二区三区久久久 | 男人的天堂av网站 | 爆乳一区二区三区无码 | 精品日本一区二区三区在线观看 | 国产九九九九九九九a片 | 国内综合精品午夜久久资源 | 国产乱人无码伦av在线a | 国产手机在线αⅴ片无码观看 | 澳门永久av免费网站 | 噜噜噜亚洲色成人网站 | 亚洲成a人片在线观看无码3d | 婷婷五月综合激情中文字幕 | 免费网站看v片在线18禁无码 | 香蕉久久久久久av成人 | 久久综合九色综合欧美狠狠 | 国产乱码精品一品二品 | 黑人玩弄人妻中文在线 | 成人性做爰aaa片免费看 | 97精品国产97久久久久久免费 | 国产麻豆精品一区二区三区v视界 | 国精产品一区二区三区 | 国产明星裸体无码xxxx视频 | 国产亚洲精品久久久久久久久动漫 | 久久亚洲精品成人无码 | 久久精品国产精品国产精品污 | 国产精品毛多多水多 | aⅴ亚洲 日韩 色 图网站 播放 | 日本又色又爽又黄的a片18禁 | 日本大乳高潮视频在线观看 | 亚洲人亚洲人成电影网站色 | 日韩av激情在线观看 | 女人被爽到呻吟gif动态图视看 | 国产真实伦对白全集 | 国产suv精品一区二区五 | 欧美日韩亚洲国产精品 | 在线成人www免费观看视频 | 老熟妇仑乱视频一区二区 | 爽爽影院免费观看 | 麻豆果冻传媒2021精品传媒一区下载 | 网友自拍区视频精品 | 久久精品国产一区二区三区肥胖 | 精品无码av一区二区三区 | 亚洲欧美综合区丁香五月小说 | 免费人成在线观看网站 | 俺去俺来也在线www色官网 | 九一九色国产 | 内射爽无广熟女亚洲 | √8天堂资源地址中文在线 | 无码国产色欲xxxxx视频 | 欧美激情内射喷水高潮 | 亚洲色大成网站www | 国产精品国产自线拍免费软件 | 真人与拘做受免费视频一 | 亚洲精品国偷拍自产在线观看蜜桃 | 中文无码伦av中文字幕 | 亚洲aⅴ无码成人网站国产app | 无码av免费一区二区三区试看 | 国产精品久久久久久无码 | 中文字幕人妻丝袜二区 | 特大黑人娇小亚洲女 | 亚洲精品中文字幕久久久久 | 性生交片免费无码看人 | 亚洲精品综合一区二区三区在线 | 国产尤物精品视频 | 亚洲自偷自偷在线制服 | 国产另类ts人妖一区二区 | 欧美怡红院免费全部视频 | 又大又紧又粉嫩18p少妇 | 精品人人妻人人澡人人爽人人 | 狂野欧美性猛交免费视频 | 欧美日韩一区二区三区自拍 | 国产精品亚洲а∨无码播放麻豆 | 免费无码一区二区三区蜜桃大 | 高清不卡一区二区三区 | 亚洲精品久久久久avwww潮水 | 丰满岳乱妇在线观看中字无码 | 乱人伦人妻中文字幕无码久久网 | 久久久中文字幕日本无吗 | 国精产品一品二品国精品69xx | 亚洲成色在线综合网站 | 国内精品久久毛片一区二区 | 欧美刺激性大交 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 东京热无码av男人的天堂 | 99精品国产综合久久久久五月天 | 成人综合网亚洲伊人 | 亚洲啪av永久无码精品放毛片 | 久久国产精品偷任你爽任你 | 亚无码乱人伦一区二区 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲第一网站男人都懂 | 午夜成人1000部免费视频 | 午夜精品一区二区三区的区别 | 国产精品美女久久久 | 久久精品丝袜高跟鞋 | 中文字幕无码日韩专区 | 超碰97人人做人人爱少妇 | 国产午夜亚洲精品不卡 | 学生妹亚洲一区二区 | 无码人妻久久一区二区三区不卡 | 久久综合网欧美色妞网 | 欧美第一黄网免费网站 | 中文亚洲成a人片在线观看 | 无码午夜成人1000部免费视频 | 亚洲精品www久久久 | 好屌草这里只有精品 | 丁香花在线影院观看在线播放 | 未满成年国产在线观看 | 玩弄中年熟妇正在播放 | 精品无码国产一区二区三区av | 亚洲一区二区三区香蕉 | 免费无码午夜福利片69 | 国产激情艳情在线看视频 | 荫蒂添的好舒服视频囗交 | 午夜精品久久久久久久久 | 国产成人综合美国十次 | 一本色道婷婷久久欧美 | 国产精品久久久av久久久 | 欧美亚洲日韩国产人成在线播放 | 色婷婷综合激情综在线播放 | 荫蒂被男人添的好舒服爽免费视频 | 人人妻人人澡人人爽欧美一区九九 | 欧美日本免费一区二区三区 | 国产特级毛片aaaaaaa高清 | 免费男性肉肉影院 | 亚洲精品一区二区三区婷婷月 | 爆乳一区二区三区无码 | 天堂在线观看www | 人妻无码αv中文字幕久久琪琪布 | 亚洲aⅴ无码成人网站国产app | www国产亚洲精品久久网站 | 暴力强奷在线播放无码 | 亚洲精品无码人妻无码 | 成人免费无码大片a毛片 | 国产精品久久久 | 人妻互换免费中文字幕 | 午夜无码区在线观看 | 久久亚洲精品成人无码 | 久久综合九色综合97网 | 亚洲一区二区三区 | 99riav国产精品视频 | 亚洲精品中文字幕乱码 | 欧美高清在线精品一区 | 亚洲精品中文字幕 | 最近免费中文字幕中文高清百度 | 国产精品久久久久影院嫩草 | av在线亚洲欧洲日产一区二区 | 成年女人永久免费看片 | 人妻有码中文字幕在线 | 国产亚洲精品久久久久久 | 亚洲自偷精品视频自拍 | 国产精品办公室沙发 | 成人无码视频在线观看网站 | 性色欲情网站iwww九文堂 | 亚洲精品久久久久久一区二区 | 人妻天天爽夜夜爽一区二区 | 一二三四社区在线中文视频 | 亚洲乱码国产乱码精品精 | 国产日产欧产精品精品app | 精品国产一区av天美传媒 | 永久免费精品精品永久-夜色 | 精品无码国产一区二区三区av | 精品偷拍一区二区三区在线看 | 又色又爽又黄的美女裸体网站 | 久久国产精品萌白酱免费 | 国产激情无码一区二区app | 狂野欧美性猛交免费视频 | 亚洲精品午夜国产va久久成人 | 伊人久久大香线蕉午夜 | 久久精品国产99久久6动漫 | 55夜色66夜色国产精品视频 | 美女黄网站人色视频免费国产 | 国产偷国产偷精品高清尤物 | 日本又色又爽又黄的a片18禁 | 国产成人精品久久亚洲高清不卡 | 日本在线高清不卡免费播放 | 久久久久99精品成人片 | 日韩欧美中文字幕公布 | 国产成人av免费观看 | 久久精品国产99精品亚洲 | 樱花草在线社区www | 高中生自慰www网站 | 台湾无码一区二区 | 国产亚洲欧美日韩亚洲中文色 | 国产两女互慰高潮视频在线观看 | 国产成人无码区免费内射一片色欲 | 在线观看国产一区二区三区 | 少妇愉情理伦片bd | 无码国模国产在线观看 | 国产午夜亚洲精品不卡 | 婷婷色婷婷开心五月四房播播 | 国产精品无码成人午夜电影 | 国产av无码专区亚洲a∨毛片 | 一本久久a久久精品亚洲 | 亚洲日本va中文字幕 | 国产内射爽爽大片视频社区在线 | 好男人社区资源 | 国产精品久久久午夜夜伦鲁鲁 | 国产av一区二区精品久久凹凸 | 夜夜夜高潮夜夜爽夜夜爰爰 | 丁香花在线影院观看在线播放 | 国产精品人人妻人人爽 | 天堂久久天堂av色综合 | 日韩av无码一区二区三区 | 日韩欧美群交p片內射中文 | 久久99国产综合精品 | 狠狠亚洲超碰狼人久久 | 最近中文2019字幕第二页 | 在线观看国产午夜福利片 | 日本丰满护士爆乳xxxx | 国产精品亚洲综合色区韩国 | 999久久久国产精品消防器材 | 97se亚洲精品一区 | 色五月五月丁香亚洲综合网 | 日韩人妻少妇一区二区三区 | 亚洲日韩av一区二区三区中文 | 人人爽人人澡人人人妻 | 无码一区二区三区在线观看 | 国产人妻精品一区二区三区不卡 | 少妇性俱乐部纵欲狂欢电影 | 国产精品国产自线拍免费软件 | 久久午夜无码鲁丝片午夜精品 | 国产欧美熟妇另类久久久 | 18无码粉嫩小泬无套在线观看 | 3d动漫精品啪啪一区二区中 | 丰满少妇人妻久久久久久 | 人人妻人人澡人人爽精品欧美 | 国产精品久久国产精品99 | 免费人成在线观看网站 | 少妇性l交大片 | 精品久久综合1区2区3区激情 | 无码精品国产va在线观看dvd | 丰满少妇熟乱xxxxx视频 | 国产av一区二区精品久久凹凸 | 国产精品久久久久久亚洲毛片 | 国产精品丝袜黑色高跟鞋 | 中文字幕中文有码在线 | 99久久精品午夜一区二区 | 免费乱码人妻系列无码专区 | 亚洲欧美中文字幕5发布 | 熟妇激情内射com | 欧美xxxxx精品 | 天堂а√在线中文在线 | 人妻插b视频一区二区三区 | 亚洲狠狠色丁香婷婷综合 | 欧美性生交xxxxx久久久 | www成人国产高清内射 | 午夜熟女插插xx免费视频 | 老熟妇仑乱视频一区二区 | 欧美 丝袜 自拍 制服 另类 | 欧美国产日韩久久mv | 久久久久亚洲精品男人的天堂 | 装睡被陌生人摸出水好爽 | 国产激情精品一区二区三区 | 内射老妇bbwx0c0ck | 国产三级久久久精品麻豆三级 | 久久久久久久久蜜桃 | 草草网站影院白丝内射 | 一本加勒比波多野结衣 | 无码福利日韩神码福利片 | 色诱久久久久综合网ywww | 精品 日韩 国产 欧美 视频 | 欧美亚洲日韩国产人成在线播放 | 一本加勒比波多野结衣 | 国产办公室秘书无码精品99 | 精品国产一区二区三区av 性色 | 亚洲欧美色中文字幕在线 | 精品人人妻人人澡人人爽人人 | 欧美色就是色 | 成人欧美一区二区三区黑人免费 | 亚洲人成无码网www | 特黄特色大片免费播放器图片 | www国产精品内射老师 | 日日鲁鲁鲁夜夜爽爽狠狠 | 人人妻人人澡人人爽人人精品 | 欧美人与善在线com | 一本加勒比波多野结衣 | 国产一区二区三区日韩精品 | 激情综合激情五月俺也去 | 色噜噜亚洲男人的天堂 | 少妇性l交大片欧洲热妇乱xxx | 国产真实伦对白全集 | 中文字幕日韩精品一区二区三区 | 亚洲中文字幕无码一久久区 | 亚洲成在人网站无码天堂 | 丝袜人妻一区二区三区 | 国产欧美亚洲精品a | 亚洲精品久久久久中文第一幕 | 人人妻人人澡人人爽欧美一区九九 | 国产精品香蕉在线观看 | 免费中文字幕日韩欧美 | 国产手机在线αⅴ片无码观看 | 乌克兰少妇性做爰 | 国产av一区二区三区最新精品 | 国产色xx群视频射精 | 无码中文字幕色专区 | 清纯唯美经典一区二区 | 少女韩国电视剧在线观看完整 | 日韩精品a片一区二区三区妖精 | 成人精品一区二区三区中文字幕 | 无码毛片视频一区二区本码 | 国产三级久久久精品麻豆三级 | 真人与拘做受免费视频 | 图片小说视频一区二区 | 熟妇女人妻丰满少妇中文字幕 | 亚洲熟女一区二区三区 | 久激情内射婷内射蜜桃人妖 | 国产精品无码一区二区桃花视频 | 亚洲欧美中文字幕5发布 | 久久成人a毛片免费观看网站 | 国产精品亚洲а∨无码播放麻豆 | 久久久亚洲欧洲日产国码αv | 奇米影视888欧美在线观看 | 亚洲欧美色中文字幕在线 | 高清不卡一区二区三区 | 在线a亚洲视频播放在线观看 | 中文字幕色婷婷在线视频 | 精品欧洲av无码一区二区三区 | 日本精品久久久久中文字幕 | 久久人妻内射无码一区三区 | 骚片av蜜桃精品一区 | 国产成人综合美国十次 | 最近的中文字幕在线看视频 | 人人妻人人澡人人爽欧美精品 | 中文字幕人妻丝袜二区 | 亚洲一区av无码专区在线观看 | 熟女少妇在线视频播放 | 午夜福利不卡在线视频 | 日韩欧美成人免费观看 | 精品一区二区三区波多野结衣 | 国产精品国产自线拍免费软件 | 九月婷婷人人澡人人添人人爽 | 欧美日韩一区二区综合 | 中文字幕无码视频专区 | 丰满妇女强制高潮18xxxx | 熟女俱乐部五十路六十路av | 亚拍精品一区二区三区探花 | 国产国语老龄妇女a片 | 国产电影无码午夜在线播放 | 1000部啪啪未满十八勿入下载 | 亚洲精品午夜国产va久久成人 | 久久久久免费精品国产 | 狠狠噜狠狠狠狠丁香五月 | 中文字幕人妻无码一区二区三区 | 国产99久久精品一区二区 | 国产一区二区三区四区五区加勒比 | 久久aⅴ免费观看 | 国产欧美精品一区二区三区 | 中文字幕无码av波多野吉衣 | 精品国产一区二区三区四区在线看 | 国产亚洲精品精品国产亚洲综合 | 久久久国产精品无码免费专区 | 中文字幕无码日韩专区 | 88国产精品欧美一区二区三区 | 精品国产成人一区二区三区 | 成在人线av无码免费 | 国产精品久久久久影院嫩草 | yw尤物av无码国产在线观看 | 国产精品成人av在线观看 | 无遮挡啪啪摇乳动态图 | 国产两女互慰高潮视频在线观看 | 亚洲啪av永久无码精品放毛片 | 激情内射日本一区二区三区 | 无码人妻丰满熟妇区五十路百度 | 久久伊人色av天堂九九小黄鸭 | 免费播放一区二区三区 | 久久久精品456亚洲影院 | 欧美丰满熟妇xxxx性ppx人交 | 久久久久久亚洲精品a片成人 | 在线亚洲高清揄拍自拍一品区 | 无码精品国产va在线观看dvd | 国产精品美女久久久网av | 亚洲精品国偷拍自产在线麻豆 | 76少妇精品导航 | 永久免费精品精品永久-夜色 | 三级4级全黄60分钟 | 自拍偷自拍亚洲精品10p | 国产午夜视频在线观看 | 亚洲欧洲无卡二区视頻 | 桃花色综合影院 | а天堂中文在线官网 | 日韩人妻无码一区二区三区久久99 | 青青久在线视频免费观看 | 精品国产一区二区三区四区 | 亚洲乱亚洲乱妇50p | 欧美精品无码一区二区三区 | 久久精品中文字幕大胸 | 国产在线精品一区二区三区直播 | 麻豆国产丝袜白领秘书在线观看 | 国内精品久久毛片一区二区 | 东京无码熟妇人妻av在线网址 | 荫蒂被男人添的好舒服爽免费视频 | 女人色极品影院 | 亚洲日本在线电影 | 日韩精品a片一区二区三区妖精 | 国产精品亚洲а∨无码播放麻豆 | 国产亚洲精品久久久ai换 | 亚洲熟女一区二区三区 | 高潮毛片无遮挡高清免费视频 | 国产无遮挡吃胸膜奶免费看 | 久久综合香蕉国产蜜臀av | 熟妇人妻激情偷爽文 | aⅴ在线视频男人的天堂 | 一本无码人妻在中文字幕免费 | 成人毛片一区二区 | 成熟人妻av无码专区 | 丰满人妻一区二区三区免费视频 | 欧美人与牲动交xxxx | 免费观看又污又黄的网站 | 成人精品一区二区三区中文字幕 | 动漫av网站免费观看 | 久久精品人妻少妇一区二区三区 | 日韩人妻无码一区二区三区久久99 | 蜜臀aⅴ国产精品久久久国产老师 | 亚洲成av人片在线观看无码不卡 | 牛和人交xxxx欧美 | 日韩精品a片一区二区三区妖精 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 成人精品天堂一区二区三区 | 国产99久久精品一区二区 | 国产激情一区二区三区 | 扒开双腿疯狂进出爽爽爽视频 | 粉嫩少妇内射浓精videos | 国产性生大片免费观看性 | 人人澡人人妻人人爽人人蜜桃 | 亚洲の无码国产の无码影院 | 55夜色66夜色国产精品视频 | 国产精品-区区久久久狼 | 国产亚洲精品久久久久久大师 | 国产精品美女久久久网av | 色综合视频一区二区三区 | 欧美日本精品一区二区三区 | 亚洲日韩av一区二区三区中文 | 亚洲精品成人av在线 | 亚洲欧美精品aaaaaa片 | 亚洲中文字幕乱码av波多ji | 波多野结衣av在线观看 | 国产免费观看黄av片 | av无码电影一区二区三区 | 樱花草在线播放免费中文 | 亚洲精品国产a久久久久久 | 色一情一乱一伦一区二区三欧美 | 精品欧洲av无码一区二区三区 | 白嫩日本少妇做爰 | 色婷婷久久一区二区三区麻豆 | 亚洲精品综合五月久久小说 | 成人免费视频一区二区 | 国产精品理论片在线观看 | 性史性农村dvd毛片 | 国产偷抇久久精品a片69 | 亚洲精品久久久久久久久久久 | 大肉大捧一进一出好爽视频 | 小sao货水好多真紧h无码视频 | 精品国产一区av天美传媒 | 99国产精品白浆在线观看免费 | 国产成人精品视频ⅴa片软件竹菊 | 亚洲自偷自偷在线制服 | 天天做天天爱天天爽综合网 | 亚洲精品国偷拍自产在线麻豆 | 亚洲国产精品毛片av不卡在线 | 日日碰狠狠躁久久躁蜜桃 | 日日躁夜夜躁狠狠躁 | 精品国产成人一区二区三区 | 麻豆成人精品国产免费 | 色欲人妻aaaaaaa无码 | 国产国产精品人在线视 | 中文字幕乱码亚洲无线三区 | 捆绑白丝粉色jk震动捧喷白浆 | 少妇无码av无码专区在线观看 | 亚洲熟妇自偷自拍另类 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产精品久久久久久无码 | 国产成人无码专区 | 欧美日韩亚洲国产精品 | 亚洲一区二区三区在线观看网站 | 色婷婷久久一区二区三区麻豆 | 亚洲精品国偷拍自产在线麻豆 | 天下第一社区视频www日本 | 日韩欧美中文字幕在线三区 | 欧洲欧美人成视频在线 | 扒开双腿吃奶呻吟做受视频 | 亚洲第一无码av无码专区 | 午夜精品久久久久久久久 | 亚洲午夜福利在线观看 | 少妇的肉体aa片免费 | 免费视频欧美无人区码 | 久久久久久av无码免费看大片 | 国产美女极度色诱视频www | 精品乱码久久久久久久 | 亚洲阿v天堂在线 | 亚洲中文字幕无码一久久区 | 全球成人中文在线 | 粗大的内捧猛烈进出视频 | 亚洲欧洲中文日韩av乱码 | 亚洲中文字幕在线无码一区二区 | 欧美日韩色另类综合 | 久久精品一区二区三区四区 | 牲欲强的熟妇农村老妇女 | 久久精品人妻少妇一区二区三区 | 欧美成人免费全部网站 | 色噜噜亚洲男人的天堂 | 伊人久久大香线焦av综合影院 | 麻豆果冻传媒2021精品传媒一区下载 | 少妇人妻av毛片在线看 | 亚洲午夜久久久影院 | 无码人妻黑人中文字幕 | 国产精品对白交换视频 | 又色又爽又黄的美女裸体网站 | 欧美35页视频在线观看 | 国产成人精品无码播放 | 欧美午夜特黄aaaaaa片 | 亚洲另类伦春色综合小说 | 欧美放荡的少妇 | 日韩精品无码一区二区中文字幕 | 日产精品高潮呻吟av久久 | 久久久久久久女国产乱让韩 | 久久人人爽人人人人片 | 午夜成人1000部免费视频 | 国产成人久久精品流白浆 | 中文字幕无码视频专区 | 最新版天堂资源中文官网 | 亚洲人成影院在线观看 | 国产精品对白交换视频 | 国内精品一区二区三区不卡 | 99久久精品日本一区二区免费 | 欧美亚洲日韩国产人成在线播放 | 又色又爽又黄的美女裸体网站 | 国产精品久久久久久无码 | 人人妻在人人 | 高中生自慰www网站 | √天堂中文官网8在线 | 久9re热视频这里只有精品 | 国产亚洲精品久久久久久 | 高潮喷水的毛片 | 最近的中文字幕在线看视频 | 人人妻人人澡人人爽人人精品 | 又大又硬又黄的免费视频 | 午夜嘿嘿嘿影院 | 99久久精品无码一区二区毛片 | av无码久久久久不卡免费网站 | 亚洲一区二区三区香蕉 | 2020久久香蕉国产线看观看 | 国产精品二区一区二区aⅴ污介绍 | 黑人巨大精品欧美黑寡妇 | 久久精品人人做人人综合 | www国产亚洲精品久久久日本 | 亚洲一区二区三区偷拍女厕 | 在线a亚洲视频播放在线观看 | 成人av无码一区二区三区 | 国产精品久久久午夜夜伦鲁鲁 | 国产精品无码永久免费888 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 97精品国产97久久久久久免费 | 一本一道久久综合久久 | 青青青手机频在线观看 | 国产色视频一区二区三区 | 成人片黄网站色大片免费观看 | 免费播放一区二区三区 | 久久久av男人的天堂 | 天天摸天天透天天添 | 国内揄拍国内精品少妇国语 | www国产亚洲精品久久久日本 | аⅴ资源天堂资源库在线 | 成人一区二区免费视频 | 四虎永久在线精品免费网址 | 成人精品视频一区二区 | 少妇太爽了在线观看 | 色综合天天综合狠狠爱 | 好男人www社区 | 亚洲娇小与黑人巨大交 | 国产尤物精品视频 | 亚洲综合无码一区二区三区 | 中文字幕+乱码+中文字幕一区 | 国产精品丝袜黑色高跟鞋 | 四虎影视成人永久免费观看视频 | 天天摸天天碰天天添 | 国产精品办公室沙发 | 男女爱爱好爽视频免费看 | 国产成人一区二区三区在线观看 | 久久天天躁狠狠躁夜夜免费观看 | 丰满肥臀大屁股熟妇激情视频 | 扒开双腿吃奶呻吟做受视频 | 欧美日韩一区二区免费视频 | 亚洲 另类 在线 欧美 制服 | 国产精品人妻一区二区三区四 | 日本爽爽爽爽爽爽在线观看免 | 扒开双腿吃奶呻吟做受视频 | 日本肉体xxxx裸交 | 一区二区三区乱码在线 | 欧洲 | 国产亚洲美女精品久久久2020 | 无码中文字幕色专区 | 亚洲成a人片在线观看日本 | 日本成熟视频免费视频 | 一个人看的www免费视频在线观看 | 亚洲国产精品一区二区美利坚 | 高潮毛片无遮挡高清免费 | 国产97在线 | 亚洲 | 荫蒂添的好舒服视频囗交 | 国产香蕉尹人视频在线 | 国产亚洲精品久久久久久国模美 | 国产成人一区二区三区在线观看 | 色一情一乱一伦一区二区三欧美 | 宝宝好涨水快流出来免费视频 | 亚洲成a人片在线观看无码3d | 丰满人妻被黑人猛烈进入 | 亚洲国产精品久久久久久 | 日韩人妻无码一区二区三区久久99 | 国产香蕉97碰碰久久人人 | 国产偷国产偷精品高清尤物 | 少妇一晚三次一区二区三区 | 六月丁香婷婷色狠狠久久 | 国产精品99爱免费视频 | 3d动漫精品啪啪一区二区中 | 欧美激情一区二区三区成人 | 久久国产36精品色熟妇 | 色综合久久久久综合一本到桃花网 | 国产精品高潮呻吟av久久 | 国产成人无码av在线影院 | 老子影院午夜精品无码 | 久久国产精品萌白酱免费 | 日本一卡二卡不卡视频查询 | 日日橹狠狠爱欧美视频 | 久久97精品久久久久久久不卡 | 久久99精品国产麻豆蜜芽 | 国产在线一区二区三区四区五区 | 午夜免费福利小电影 | 国产麻豆精品精东影业av网站 | 成人精品天堂一区二区三区 | 国产色在线 | 国产 | 亚洲一区二区三区播放 | 日本熟妇乱子伦xxxx | 亚洲国产精品无码久久久久高潮 | 人妻有码中文字幕在线 | 精品国产麻豆免费人成网站 | 内射欧美老妇wbb | 97se亚洲精品一区 | 日本精品久久久久中文字幕 | 久久精品国产大片免费观看 | 国语精品一区二区三区 | 国产另类ts人妖一区二区 | 欧美人与动性行为视频 | 亚洲日韩乱码中文无码蜜桃臀网站 | 国产农村乱对白刺激视频 | 国产精华av午夜在线观看 | 女人色极品影院 | 精品国产精品久久一区免费式 | 国产99久久精品一区二区 | 亚洲精品一区二区三区四区五区 | 国产在线一区二区三区四区五区 | 亚洲色大成网站www国产 | 久久人人爽人人人人片 | 少妇被黑人到高潮喷出白浆 | 无码av免费一区二区三区试看 | 国产亚洲欧美在线专区 | 帮老师解开蕾丝奶罩吸乳网站 | 小鲜肉自慰网站xnxx | 国产亚洲精品久久久久久大师 | 欧美老妇与禽交 | 久久亚洲日韩精品一区二区三区 | 狠狠色欧美亚洲狠狠色www | 无码精品人妻一区二区三区av | 亚洲色在线无码国产精品不卡 | 天天做天天爱天天爽综合网 | 亚洲综合色区中文字幕 | 黑人大群体交免费视频 | 四虎国产精品免费久久 | 无遮无挡爽爽免费视频 | 夜夜躁日日躁狠狠久久av | 丰满人妻精品国产99aⅴ | 久久精品视频在线看15 | 夜夜夜高潮夜夜爽夜夜爰爰 | 无码毛片视频一区二区本码 | 精品国产乱码久久久久乱码 | 色噜噜亚洲男人的天堂 | 丰满人妻被黑人猛烈进入 | 国产亚洲精品久久久ai换 | 国产成人无码av片在线观看不卡 | 免费人成在线视频无码 | 99久久久国产精品无码免费 | 国产成人精品必看 | 国产成人一区二区三区在线观看 | 国产精品美女久久久网av | 国产色视频一区二区三区 | 国产精品毛多多水多 | 日韩人妻无码一区二区三区久久99 | 欧美精品无码一区二区三区 | 波多野结衣av在线观看 | 欧美老妇与禽交 | 欧美激情一区二区三区成人 | 色综合久久久无码中文字幕 | 乱中年女人伦av三区 | 亚洲欧美日韩综合久久久 | 正在播放东北夫妻内射 | 综合激情五月综合激情五月激情1 | 亚洲精品久久久久中文第一幕 | 中文亚洲成a人片在线观看 | 亚洲精品国产精品乱码不卡 | 亚洲一区二区三区四区 | 欧美日韩亚洲国产精品 | 国产免费久久精品国产传媒 | 日本一区二区三区免费高清 | 狂野欧美激情性xxxx | 亚洲中文字幕乱码av波多ji | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | √天堂资源地址中文在线 | 色综合久久久久综合一本到桃花网 | 理论片87福利理论电影 | 成人三级无码视频在线观看 | 国产精品久久久久久亚洲毛片 | 精品国产一区av天美传媒 | 国产又爽又猛又粗的视频a片 | 又紧又大又爽精品一区二区 | 伊人久久大香线蕉亚洲 | 国产乱人无码伦av在线a | 久久久亚洲欧洲日产国码αv | 中文字幕无码免费久久99 | 人人妻人人澡人人爽人人精品浪潮 | 亚洲熟熟妇xxxx | 国产乱人偷精品人妻a片 | 免费人成网站视频在线观看 | 国产精品资源一区二区 | 丰满人妻一区二区三区免费视频 | 国产婷婷色一区二区三区在线 | 成人欧美一区二区三区黑人 | 国产一区二区三区精品视频 | 荫蒂添的好舒服视频囗交 | 久久久国产精品无码免费专区 | 成人免费视频视频在线观看 免费 | 国产口爆吞精在线视频 | 日日麻批免费40分钟无码 | 又大又黄又粗又爽的免费视频 | 国产亚洲精品久久久久久久 | 无码人妻丰满熟妇区毛片18 | 国产美女极度色诱视频www | 成人影院yy111111在线观看 | 18无码粉嫩小泬无套在线观看 | 狠狠色噜噜狠狠狠狠7777米奇 | 影音先锋中文字幕无码 | 中文无码成人免费视频在线观看 | 国产两女互慰高潮视频在线观看 | 精品国产青草久久久久福利 | 鲁大师影院在线观看 | 撕开奶罩揉吮奶头视频 | 日日天日日夜日日摸 | 天下第一社区视频www日本 | 丰满少妇弄高潮了www | 性做久久久久久久免费看 | 免费无码午夜福利片69 | 成在人线av无码免费 | 欧美激情综合亚洲一二区 | 亚洲精品www久久久 | 撕开奶罩揉吮奶头视频 | 无码人妻少妇伦在线电影 | 鲁鲁鲁爽爽爽在线视频观看 | 在教室伦流澡到高潮hnp视频 | 狂野欧美性猛交免费视频 | 国产热a欧美热a在线视频 | 日韩精品一区二区av在线 | 欧美阿v高清资源不卡在线播放 | 正在播放老肥熟妇露脸 | 国产成人精品久久亚洲高清不卡 | 永久免费精品精品永久-夜色 | 波多野42部无码喷潮在线 | 久久熟妇人妻午夜寂寞影院 | 国产成人人人97超碰超爽8 | 日本一卡二卡不卡视频查询 | 激情五月综合色婷婷一区二区 | 亚洲性无码av中文字幕 | 伊人久久大香线蕉午夜 | 国产成人一区二区三区别 | 乱人伦中文视频在线观看 | 麻豆人妻少妇精品无码专区 | 精品国产一区av天美传媒 | 中文字幕无码人妻少妇免费 | 红桃av一区二区三区在线无码av | 学生妹亚洲一区二区 | 日本护士毛茸茸高潮 | 婷婷五月综合激情中文字幕 | 无码精品人妻一区二区三区av | 国产av一区二区三区最新精品 | 亚洲色偷偷男人的天堂 | 88国产精品欧美一区二区三区 | 欧美第一黄网免费网站 | 无码帝国www无码专区色综合 | 一本加勒比波多野结衣 | 一本久久a久久精品vr综合 | 无人区乱码一区二区三区 | 久久综合色之久久综合 | 小泽玛莉亚一区二区视频在线 | 亚洲一区二区三区无码久久 | 55夜色66夜色国产精品视频 | 精品无码国产一区二区三区av | 国产亚洲精品久久久闺蜜 | 免费无码午夜福利片69 | 超碰97人人做人人爱少妇 | 中文字幕无码视频专区 | 成人无码精品1区2区3区免费看 | 国产成人无码a区在线观看视频app | 国产99久久精品一区二区 | 亚洲日韩乱码中文无码蜜桃臀网站 | 久久亚洲日韩精品一区二区三区 | 天堂а√在线中文在线 | 四虎国产精品一区二区 | 精品久久久久香蕉网 | www国产亚洲精品久久网站 | 精品国产麻豆免费人成网站 | 色综合久久久无码中文字幕 | 国产精品免费大片 | 久在线观看福利视频 | 国产成人精品一区二区在线小狼 | 国产香蕉尹人综合在线观看 | 日本精品少妇一区二区三区 | 天堂а√在线地址中文在线 | 国产香蕉尹人综合在线观看 | 色情久久久av熟女人妻网站 | aⅴ在线视频男人的天堂 | 日韩欧美中文字幕公布 | 欧美亚洲国产一区二区三区 | 在线成人www免费观看视频 | 亚洲成a人一区二区三区 | 77777熟女视频在线观看 а天堂中文在线官网 | 久久久久人妻一区精品色欧美 | 午夜无码人妻av大片色欲 | 日韩在线不卡免费视频一区 | 国产亚av手机在线观看 | 动漫av网站免费观看 | 色情久久久av熟女人妻网站 | 精品久久久久香蕉网 | 波多野42部无码喷潮在线 | 东京热男人av天堂 | 亚洲精品一区二区三区在线 | 精品熟女少妇av免费观看 | 欧美黑人乱大交 | 色一情一乱一伦 | 激情内射日本一区二区三区 | 欧洲极品少妇 | 成人av无码一区二区三区 | 亚洲精品一区二区三区在线 | 久久熟妇人妻午夜寂寞影院 | 国产成人无码专区 | 久久天天躁狠狠躁夜夜免费观看 | 国产一区二区不卡老阿姨 | 成人aaa片一区国产精品 | 亚洲精品一区二区三区四区五区 | 亚洲中文字幕无码中文字在线 | 欧美一区二区三区 | 鲁一鲁av2019在线 | 一本久道久久综合狠狠爱 | 久久久久免费看成人影片 | 亚洲熟女一区二区三区 | 久久精品人人做人人综合试看 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 日日麻批免费40分钟无码 | 色婷婷欧美在线播放内射 | 四虎影视成人永久免费观看视频 | 男女爱爱好爽视频免费看 | 精品一区二区不卡无码av | 久久久久国色av免费观看性色 | 玩弄中年熟妇正在播放 | 久久99精品久久久久婷婷 | 国产成人无码av片在线观看不卡 | 久久精品一区二区三区四区 | 人人妻人人澡人人爽欧美精品 | 98国产精品综合一区二区三区 | 国产精品第一区揄拍无码 | 亚洲热妇无码av在线播放 | 日韩av无码一区二区三区 | 欧美高清在线精品一区 | 婷婷六月久久综合丁香 | 丰满人妻精品国产99aⅴ | 内射爽无广熟女亚洲 | 久久国产精品精品国产色婷婷 | 中文无码精品a∨在线观看不卡 | 亚洲国产av精品一区二区蜜芽 | 久9re热视频这里只有精品 | av小次郎收藏 | 狠狠综合久久久久综合网 | 亚洲综合精品香蕉久久网 | 国产精品久久久久影院嫩草 | 一区二区三区乱码在线 | 欧洲 | 乱人伦人妻中文字幕无码 | 亚洲 a v无 码免 费 成 人 a v | 亚洲一区二区三区偷拍女厕 | 亚洲 激情 小说 另类 欧美 | 人妻无码久久精品人妻 | 亚洲狠狠婷婷综合久久 | www国产亚洲精品久久网站 | 免费看少妇作爱视频 | 一个人看的www免费视频在线观看 | 娇妻被黑人粗大高潮白浆 | 国产精品人妻一区二区三区四 | 少妇邻居内射在线 | 国产精品资源一区二区 | 国产后入清纯学生妹 | 国产肉丝袜在线观看 | 日本熟妇大屁股人妻 | 狠狠噜狠狠狠狠丁香五月 | 日本又色又爽又黄的a片18禁 | 国产精品久久久久7777 | 欧洲美熟女乱又伦 | 一本一道久久综合久久 | 亚洲人成影院在线无码按摩店 | 国产精品无码永久免费888 | a片免费视频在线观看 | 亚洲色大成网站www国产 | 夫妻免费无码v看片 | 九九热爱视频精品 | 欧美大屁股xxxxhd黑色 | 精品偷自拍另类在线观看 | 午夜福利不卡在线视频 | 国产亚洲精品久久久闺蜜 | 国产av一区二区精品久久凹凸 | 国产性生大片免费观看性 | 性色av无码免费一区二区三区 | 在线 国产 欧美 亚洲 天堂 | 精品 日韩 国产 欧美 视频 | 亚洲经典千人经典日产 | 精品人妻中文字幕有码在线 | 老头边吃奶边弄进去呻吟 | 在线精品国产一区二区三区 | 亚洲精品一区二区三区在线 | 国産精品久久久久久久 | 一本久道高清无码视频 | 亚洲成a人片在线观看无码 | 亚洲精品国产精品乱码不卡 | 曰韩少妇内射免费播放 | 丰腴饱满的极品熟妇 | 久久婷婷五月综合色国产香蕉 | 国产真实夫妇视频 | 初尝人妻少妇中文字幕 | 国产精品亚洲一区二区三区喷水 | 日韩精品无码一区二区中文字幕 | 免费国产成人高清在线观看网站 | 秋霞特色aa大片 | 国产成人无码a区在线观看视频app | 欧美日韩综合一区二区三区 | 国产极品视觉盛宴 | 一二三四在线观看免费视频 | 性欧美牲交xxxxx视频 | 精品国产精品久久一区免费式 | 久久精品女人天堂av免费观看 | 国产精品人人妻人人爽 | 日韩人妻无码中文字幕视频 | 男女性色大片免费网站 | 国产深夜福利视频在线 | 中文毛片无遮挡高清免费 | 久久国产精品精品国产色婷婷 | 无码人妻av免费一区二区三区 | 丰满少妇人妻久久久久久 | 极品尤物被啪到呻吟喷水 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 特黄特色大片免费播放器图片 | 国产成人无码av在线影院 | 中文字幕无码免费久久99 | 色综合久久久无码网中文 | 色狠狠av一区二区三区 | 欧美大屁股xxxxhd黑色 | 玩弄少妇高潮ⅹxxxyw | 欧美怡红院免费全部视频 | 无码国模国产在线观看 | 东京一本一道一二三区 | 国内丰满熟女出轨videos | 亚洲中文字幕无码一久久区 | 欧美丰满熟妇xxxx性ppx人交 | 精品少妇爆乳无码av无码专区 | 国产性生大片免费观看性 | 3d动漫精品啪啪一区二区中 | 精品偷自拍另类在线观看 | 综合网日日天干夜夜久久 | 国产精品亚洲а∨无码播放麻豆 | 一个人免费观看的www视频 | 欧美高清在线精品一区 | 国产精品福利视频导航 | 色五月五月丁香亚洲综合网 | 日韩精品无码一本二本三本色 | 国产av久久久久精东av | 一个人看的www免费视频在线观看 | а√资源新版在线天堂 | 77777熟女视频在线观看 а天堂中文在线官网 | 老头边吃奶边弄进去呻吟 | 欧美真人作爱免费视频 | 国产乱子伦视频在线播放 | 日本大香伊一区二区三区 | 精品国产福利一区二区 | 久久精品国产99久久6动漫 | 亚洲人成影院在线观看 | 久久亚洲中文字幕无码 | 成人av无码一区二区三区 | 人妻aⅴ无码一区二区三区 | 国产精品毛片一区二区 | 亚洲午夜无码久久 | 国产精品久久久一区二区三区 | 亚洲国产精品成人久久蜜臀 | 国产绳艺sm调教室论坛 | 日本va欧美va欧美va精品 | 国产免费久久久久久无码 | 少妇的肉体aa片免费 | 亚洲第一网站男人都懂 | 国产人成高清在线视频99最全资源 | 精品厕所偷拍各类美女tp嘘嘘 | 波多野结衣乳巨码无在线观看 | 永久免费观看美女裸体的网站 | 免费无码的av片在线观看 | 国产又粗又硬又大爽黄老大爷视 | 亚洲 激情 小说 另类 欧美 | 女人高潮内射99精品 | 76少妇精品导航 | www一区二区www免费 | 亚洲人成影院在线无码按摩店 | 人人妻人人澡人人爽人人精品 | 亚洲第一网站男人都懂 | 精品国产国产综合精品 | 又粗又大又硬毛片免费看 | 夫妻免费无码v看片 | 又色又爽又黄的美女裸体网站 | 亚洲狠狠色丁香婷婷综合 | 欧美精品在线观看 | 精品人人妻人人澡人人爽人人 | 一本大道久久东京热无码av | 女高中生第一次破苞av | 国产农村妇女高潮大叫 | 老子影院午夜精品无码 | 久久综合久久自在自线精品自 | 午夜无码人妻av大片色欲 | 国产精品亚洲专区无码不卡 | 午夜精品久久久久久久久 | 午夜理论片yy44880影院 | 国産精品久久久久久久 | 强开小婷嫩苞又嫩又紧视频 | 99久久久无码国产精品免费 | 熟女俱乐部五十路六十路av | 小sao货水好多真紧h无码视频 | 国产亚洲精品久久久久久 | 日本va欧美va欧美va精品 | 久久国产精品萌白酱免费 | 久久久久99精品成人片 | 亚洲精品成人av在线 | 真人与拘做受免费视频一 | 日韩av激情在线观看 | 欧美性生交活xxxxxdddd | 欧美精品国产综合久久 | 国产亲子乱弄免费视频 | 啦啦啦www在线观看免费视频 | 无码人妻出轨黑人中文字幕 | 又黄又爽又色的视频 | 久久久无码中文字幕久... | 精品国产一区二区三区av 性色 | 男人扒开女人内裤强吻桶进去 | 在线播放免费人成毛片乱码 | 日韩人妻少妇一区二区三区 | 亚洲啪av永久无码精品放毛片 | 亚洲欧美综合区丁香五月小说 | 国产亚洲精品久久久久久大师 | 大肉大捧一进一出视频出来呀 | 欧美日韩视频无码一区二区三 | 激情内射日本一区二区三区 | 又大又紧又粉嫩18p少妇 | 18禁止看的免费污网站 | 国产97色在线 | 免 | 成人精品视频一区二区三区尤物 | 午夜不卡av免费 一本久久a久久精品vr综合 | 一本久道久久综合婷婷五月 | 国产色在线 | 国产 | 动漫av一区二区在线观看 | 色婷婷综合激情综在线播放 | 亚洲熟悉妇女xxx妇女av | 国产免费久久精品国产传媒 | 牲欲强的熟妇农村老妇女视频 | 国产精品久久久一区二区三区 | 人人妻在人人 | 欧美一区二区三区视频在线观看 | 日韩无套无码精品 | 99久久精品午夜一区二区 | 国内精品久久毛片一区二区 | 日韩成人一区二区三区在线观看 | 双乳奶水饱满少妇呻吟 | 岛国片人妻三上悠亚 | 99精品国产综合久久久久五月天 | 国产精品99久久精品爆乳 | 99久久人妻精品免费一区 | 正在播放老肥熟妇露脸 | 熟妇人妻无乱码中文字幕 | a在线亚洲男人的天堂 | 天堂久久天堂av色综合 | v一区无码内射国产 | 成年美女黄网站色大免费视频 | 97无码免费人妻超级碰碰夜夜 | 国产乱人伦av在线无码 | 日日碰狠狠躁久久躁蜜桃 | 亚洲色欲色欲天天天www | 精品无码成人片一区二区98 | 夜先锋av资源网站 | 国产精品人妻一区二区三区四 | 日本成熟视频免费视频 | 亚洲精品无码人妻无码 | 亚洲中文字幕av在天堂 | 国产无遮挡又黄又爽免费视频 | 一个人免费观看的www视频 | 欧美 丝袜 自拍 制服 另类 | 男女超爽视频免费播放 | 又粗又大又硬毛片免费看 | 天天综合网天天综合色 | 国产精品久久国产精品99 | 久久综合香蕉国产蜜臀av | 国产av一区二区三区最新精品 | 精品久久久中文字幕人妻 | 天天躁夜夜躁狠狠是什么心态 | 无码午夜成人1000部免费视频 | 亚洲欧美色中文字幕在线 | 亚洲日韩一区二区 | 无码免费一区二区三区 | 国产人妻久久精品二区三区老狼 | 免费视频欧美无人区码 | 成人亚洲精品久久久久软件 | 久久精品国产99精品亚洲 | 久久久久se色偷偷亚洲精品av | 娇妻被黑人粗大高潮白浆 | 人人爽人人爽人人片av亚洲 | 亚洲精品国偷拍自产在线麻豆 | 欧美三级不卡在线观看 | 成 人 网 站国产免费观看 | 欧美自拍另类欧美综合图片区 | 女人被男人躁得好爽免费视频 | 欧美 丝袜 自拍 制服 另类 | 精品国产国产综合精品 | 久久久精品456亚洲影院 | 色一情一乱一伦一视频免费看 | 激情内射亚州一区二区三区爱妻 | 又大又黄又粗又爽的免费视频 | 日韩欧美成人免费观看 | 中文字幕乱码人妻二区三区 | 成人试看120秒体验区 | 亚洲精品一区二区三区婷婷月 | 国产精品亚洲а∨无码播放麻豆 | 欧美性生交xxxxx久久久 | 午夜福利一区二区三区在线观看 | 小鲜肉自慰网站xnxx | 国产亚洲精品久久久久久久久动漫 | 精品水蜜桃久久久久久久 | 亚洲成熟女人毛毛耸耸多 | 国产高清不卡无码视频 | 牲欲强的熟妇农村老妇女 | 久久久久成人片免费观看蜜芽 | 欧美性生交活xxxxxdddd | 小sao货水好多真紧h无码视频 | 内射爽无广熟女亚洲 | 亚洲色在线无码国产精品不卡 | a在线亚洲男人的天堂 | 性做久久久久久久久 | 国产人成高清在线视频99最全资源 | 日韩精品a片一区二区三区妖精 | 一本加勒比波多野结衣 | 夜夜躁日日躁狠狠久久av | 99久久久无码国产aaa精品 | 欧洲精品码一区二区三区免费看 | аⅴ资源天堂资源库在线 | 国产免费久久久久久无码 | 国产精品人妻一区二区三区四 | 人人妻人人澡人人爽人人精品 | 日日天干夜夜狠狠爱 | 久久www免费人成人片 | 国产 精品 自在自线 | 人妻少妇精品无码专区二区 | 国产人妻人伦精品1国产丝袜 | 亚洲成色www久久网站 | 无套内射视频囯产 | 色婷婷av一区二区三区之红樱桃 | 六月丁香婷婷色狠狠久久 | 亚洲综合久久一区二区 | 国产一区二区三区精品视频 | 久久精品人妻少妇一区二区三区 | 亚洲国精产品一二二线 | 老头边吃奶边弄进去呻吟 | 人妻人人添人妻人人爱 | 99久久久无码国产精品免费 | 一本加勒比波多野结衣 | 少妇的肉体aa片免费 | 最近中文2019字幕第二页 | 亚洲午夜福利在线观看 | 99久久亚洲精品无码毛片 | 精品一区二区三区无码免费视频 | 国内精品久久久久久中文字幕 | 一本久道久久综合狠狠爱 | 无码人妻精品一区二区三区下载 | 国产精品第一区揄拍无码 | 中文字幕乱码人妻无码久久 | 牲交欧美兽交欧美 | 97人妻精品一区二区三区 | 国产在线aaa片一区二区99 | 97se亚洲精品一区 | 强辱丰满人妻hd中文字幕 | 久久精品国产99久久6动漫 | 午夜理论片yy44880影院 | 欧美一区二区三区视频在线观看 | 人妻无码αv中文字幕久久琪琪布 | 免费国产成人高清在线观看网站 | 国产精品久久久 | 无码人妻丰满熟妇区毛片18 | 国产亚洲精品久久久ai换 | 丝袜足控一区二区三区 | 婷婷色婷婷开心五月四房播播 | 四虎国产精品一区二区 | 狠狠躁日日躁夜夜躁2020 | 亚洲精品欧美二区三区中文字幕 | 麻豆md0077饥渴少妇 | 精品无人区无码乱码毛片国产 | 欧美日韩在线亚洲综合国产人 | 丰满肥臀大屁股熟妇激情视频 | 影音先锋中文字幕无码 | 精品人人妻人人澡人人爽人人 | 乱人伦中文视频在线观看 | 狠狠躁日日躁夜夜躁2020 | 成 人影片 免费观看 | 亚洲七七久久桃花影院 | 午夜成人1000部免费视频 | 九九久久精品国产免费看小说 | 国产在线aaa片一区二区99 | 久久精品丝袜高跟鞋 | 成人亚洲精品久久久久软件 | 亚洲春色在线视频 | 精品一区二区三区无码免费视频 | 成人性做爰aaa片免费看 | 成熟人妻av无码专区 | 久久综合色之久久综合 | 免费观看又污又黄的网站 | 亚洲精品综合一区二区三区在线 | 久久久国产精品无码免费专区 | 国产绳艺sm调教室论坛 | 亚洲va中文字幕无码久久不卡 | 久久 国产 尿 小便 嘘嘘 | 亚洲欧美精品aaaaaa片 | 国产卡一卡二卡三 | 国产精品香蕉在线观看 | 四虎影视成人永久免费观看视频 | 国产极品视觉盛宴 | 亚洲精品国产精品乱码不卡 | 麻豆md0077饥渴少妇 | 亚洲国产精品毛片av不卡在线 | 亚洲色www成人永久网址 | 亚洲人成网站色7799 | 少妇性l交大片 | 国产乱人偷精品人妻a片 | 国产热a欧美热a在线视频 | 亚洲精品久久久久中文第一幕 | 男女爱爱好爽视频免费看 | 国产三级精品三级男人的天堂 | 中文毛片无遮挡高清免费 | 成人性做爰aaa片免费看不忠 | 国产xxx69麻豆国语对白 | 亚洲第一无码av无码专区 | 激情综合激情五月俺也去 | 久久久精品456亚洲影院 | 日韩 欧美 动漫 国产 制服 | 巨爆乳无码视频在线观看 | 日本精品久久久久中文字幕 | 99精品无人区乱码1区2区3区 | 精品熟女少妇av免费观看 | 国产精品第一区揄拍无码 | 午夜精品一区二区三区在线观看 | 亚洲欧美色中文字幕在线 | 欧美精品国产综合久久 | 国产精品高潮呻吟av久久4虎 | 亚洲天堂2017无码中文 | 真人与拘做受免费视频 | 97精品人妻一区二区三区香蕉 | 中文字幕无码免费久久9一区9 | 丝袜美腿亚洲一区二区 | 国内少妇偷人精品视频免费 | 国产亚洲精品久久久久久久久动漫 | yw尤物av无码国产在线观看 | 国产午夜精品一区二区三区嫩草 | 国产精品无码成人午夜电影 | 国产偷自视频区视频 | 亚洲中文字幕va福利 | 国产口爆吞精在线视频 | 色五月五月丁香亚洲综合网 | 亚洲精品综合五月久久小说 | 国产偷自视频区视频 | 波多野结衣av一区二区全免费观看 | 亚洲狠狠色丁香婷婷综合 | 日本乱偷人妻中文字幕 | 日日麻批免费40分钟无码 | 午夜福利一区二区三区在线观看 | 久久婷婷五月综合色国产香蕉 | 精品国精品国产自在久国产87 | 无码人妻丰满熟妇区毛片18 | 5858s亚洲色大成网站www | 亚洲小说图区综合在线 | 日韩欧美中文字幕公布 | 色综合天天综合狠狠爱 | 久久视频在线观看精品 | 少妇无码av无码专区在线观看 | 国产精品人人妻人人爽 | 亚洲欧洲中文日韩av乱码 | 人人妻人人澡人人爽人人精品 | 国产亚洲tv在线观看 | 精品乱子伦一区二区三区 | 国产精品人妻一区二区三区四 | 欧美阿v高清资源不卡在线播放 | 国产精品久久国产精品99 | 天干天干啦夜天干天2017 | 熟妇人妻无码xxx视频 | 欧美人与物videos另类 | 国产精品第一区揄拍无码 | 亚洲男人av天堂午夜在 | 成人无码影片精品久久久 | 国产福利视频一区二区 | 2019午夜福利不卡片在线 | 久久久久亚洲精品男人的天堂 | 亚洲一区二区三区含羞草 | 一本加勒比波多野结衣 | 人妻无码αv中文字幕久久琪琪布 | 欧美35页视频在线观看 | 国产精品美女久久久网av | 麻豆国产97在线 | 欧洲 | 国产精品无码永久免费888 | 色欲综合久久中文字幕网 | 无码人妻黑人中文字幕 | 无码国产乱人伦偷精品视频 | 成人欧美一区二区三区 | 丰满肥臀大屁股熟妇激情视频 | 国产人妻精品一区二区三区不卡 | 久久精品人妻少妇一区二区三区 | 亚洲精品一区二区三区在线观看 | 青青青手机频在线观看 | 国产三级久久久精品麻豆三级 | 成 人影片 免费观看 | 亚洲欧美精品aaaaaa片 | 少妇性荡欲午夜性开放视频剧场 | 亚洲成a人片在线观看日本 | 波多野结衣av在线观看 | 国产精品va在线播放 | 亚洲色无码一区二区三区 | 国产人妻大战黑人第1集 | 久久久久亚洲精品男人的天堂 | 扒开双腿吃奶呻吟做受视频 | 日本肉体xxxx裸交 | 大色综合色综合网站 | 国产精品无码一区二区三区不卡 | 亚洲国产成人av在线观看 | 日韩少妇内射免费播放 | 久久亚洲精品成人无码 | 精品久久久久久亚洲精品 |