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

開發一個Linux調試器(三):寄存器和內存

系統 Linux
上一篇博文中我們給調試器添加了一個簡單的地址斷點。這次,我們將添加讀寫寄存器和內存的功能,這將使我們能夠使用我們的程序計數器、觀察狀態和改變程序的行為。

[[195831]]

上一篇博文中我們給調試器添加了一個簡單的地址斷點。這次,我們將添加讀寫寄存器和內存的功能,這將使我們能夠使用我們的程序計數器、觀察狀態和改變程序的行為。

系列文章索引

隨著后面文章的發布,這些鏈接會逐漸生效。

注冊我們的寄存器

在我們真正讀取任何寄存器之前,我們需要告訴調試器一些關于我們的目標平臺的信息,這里是 x8664 平臺。除了多組通用和專用目的寄存器,x8664 還提供浮點和向量寄存器。為了簡化,我將跳過后兩種寄存器,但是你如果喜歡的話也可以選擇支持它們。x86_64 也允許你像訪問 32、16 或者 8 位寄存器那樣訪問一些 64 位寄存器,但我只會介紹 64 位寄存器。由于這些簡化,對于每個寄存器我們只需要它的名稱、它的 DWARF 寄存器編號以及 ptrace 返回結構體中的存儲地址。我使用范圍枚舉引用這些寄存器,然后我列出了一個全局寄存器描述符數組,其中元素順序和 ptrace 中寄存器結構體相同。 

  1. enum class reg { 
  2.     rax, rbx, rcx, rdx, 
  3.     rdi, rsi, rbp, rsp, 
  4.     r8,  r9,  r10, r11, 
  5.     r12, r13, r14, r15, 
  6.     rip, rflags,    cs, 
  7.     orig_rax, fs_base, 
  8.     gs_base, 
  9.     fs, gs, ss, ds, es 
  10. }; 
  11. constexpr std::size_t n_registers = 27; 
  12. struct reg_descriptor { 
  13.     reg r; 
  14.     int dwarf_r; 
  15.     std::string name
  16. }; 
  17. const std::array<reg_descriptor, n_registers> g_register_descriptors {{ 
  18.     { reg::r15, 15, "r15" }, 
  19.     { reg::r14, 14, "r14" }, 
  20.     { reg::r13, 13, "r13" }, 
  21.     { reg::r12, 12, "r12" }, 
  22.     { reg::rbp, 6, "rbp" }, 
  23.     { reg::rbx, 3, "rbx" }, 
  24.     { reg::r11, 11, "r11" }, 
  25.     { reg::r10, 10, "r10" }, 
  26.     { reg::r9, 9, "r9" }, 
  27.     { reg::r8, 8, "r8" }, 
  28.     { reg::rax, 0, "rax" }, 
  29.     { reg::rcx, 2, "rcx" }, 
  30.     { reg::rdx, 1, "rdx" }, 
  31.     { reg::rsi, 4, "rsi" }, 
  32.     { reg::rdi, 5, "rdi" }, 
  33.     { reg::orig_rax, -1, "orig_rax" }, 
  34.     { reg::rip, -1, "rip" }, 
  35.     { reg::cs, 51, "cs" }, 
  36.     { reg::rflags, 49, "eflags" }, 
  37.     { reg::rsp, 7, "rsp" }, 
  38.     { reg::ss, 52, "ss" }, 
  39.     { reg::fs_base, 58, "fs_base" }, 
  40.     { reg::gs_base, 59, "gs_base" }, 
  41.     { reg::ds, 53, "ds" }, 
  42.     { reg::es, 50, "es" }, 
  43.     { reg::fs, 54, "fs" }, 
  44.     { reg::gs, 55, "gs" }, 
  45. }}; 

如果你想自己看看的話,你通常可以在 /usr/include/sys/user.h 找到寄存器數據結構,另外 DWARF 寄存器編號取自 System V x86_64 ABI。

現在我們可以編寫一堆函數來和寄存器交互。我們希望可以讀取寄存器、寫入數據、根據 DWARF 寄存器編號獲取值,以及通過名稱查找寄存器,反之類似。讓我們先從實現 get_register_value 開始:

  1. uint64_t get_register_value(pid_t pid, reg r) { 
  2.     user_regs_struct regs; 
  3.     ptrace(PTRACE_GETREGS, pid, nullptr, &regs); 
  4.     //... 

ptrace 使得我們可以輕易獲得我們想要的數據。我們只需要構造一個 user_regs_struct 實例并把它和 PTRACE_GETREGS 請求傳遞給 ptrace。

現在根據要請求的寄存器,我們要讀取 regs。我們可以寫一個很大的 switch 語句,但由于我們 g_register_descriptors 表的布局順序和 user_regs_struct 相同,我們只需要搜索寄存器描述符的索引,然后作為 uint64_t 數組訪問 user_regs_struct 就行。(你也可以重新排序 reg 枚舉變量,然后使用索引把它們轉換為底層類型,但第一次我就使用這種方式編寫,它能正常工作,我也就懶得改它了。)

  1. auto it = std::find_if(begin(g_register_descriptors), end(g_register_descriptors), 
  2.                        [r](auto&& rd) { return rd.r == r; }); 
  3. return *(reinterpret_cast<uint64_t*>(&regs) + (it - begin(g_register_descriptors))); 

到 uint64_t 的轉換是安全的,因為 user_regs_struct 是一個標準布局類型,但我認為指針算術技術上是未定義的行為undefined behavior。當前沒有編譯器會對此產生警告,我也懶得修改,但是如果你想保持最嚴格的正確性,那就寫一個大的 switch 語句。

set_register_value 非常類似,我們只是寫入該位置并在最后寫回寄存器:

  1. void set_register_value(pid_t pid, reg r, uint64_t value) { 
  2.     user_regs_struct regs; 
  3.     ptrace(PTRACE_GETREGS, pid, nullptr, &regs); 
  4.     auto it = std::find_if(begin(g_register_descriptors), end(g_register_descriptors), 
  5.                            [r](auto&& rd) { return rd.r == r; }); 
  6.     *(reinterpret_cast<uint64_t*>(&regs) + (it - begin(g_register_descriptors))) = value; 
  7.     ptrace(PTRACE_SETREGS, pid, nullptr, &regs); 

下一步是通過 DWARF 寄存器編號查找。這次我會真正檢查一個錯誤條件以防我們得到一些奇怪的 DWARF 信息。

  1. uint64_t get_register_value_from_dwarf_register (pid_t pid, unsigned regnum) { 
  2.     auto it = std::find_if(begin(g_register_descriptors), end(g_register_descriptors), 
  3.                            [regnum](auto&& rd) { return rd.dwarf_r == regnum; }); 
  4.     if (it == end(g_register_descriptors)) { 
  5.         throw std::out_of_range{"Unknown dwarf register"}; 
  6.     } 
  7.     return get_register_value(pid, it->r); 

就快完成啦,現在我們已經有了寄存器名稱查找:

  1. std::string get_register_name(reg r) { 
  2.     auto it = std::find_if(begin(g_register_descriptors), end(g_register_descriptors), 
  3.                            [r](auto&& rd) { return rd.r == r; }); 
  4.     return it->name
  5. reg get_register_from_name(const std::string& name) { 
  6.     auto it = std::find_if(begin(g_register_descriptors), end(g_register_descriptors), 
  7.                            [name](auto&& rd) { return rd.name == name; }); 
  8.     return it->r; 

最后我們會添加一個簡單的幫助函數用于導出所有寄存器的內容:

  1. void debugger::dump_registers() { 
  2.     for (const auto& rd : g_register_descriptors) { 
  3.         std::cout << rd.name << " 0x" 
  4.                   << std::setfill('0') << std::setw(16) << std::hex << get_register_value(m_pid, rd.r) << std::endl; 
  5.     } 

正如你看到的,iostreams 有非常精確的接口用于美觀地輸出十六進制數據(啊哈哈哈哈哈哈)。如果你喜歡你也可以通過 I/O 操縱器來擺脫這種混亂。

這些已經足夠支持我們在調試器接下來的部分輕松地處理寄存器,所以我們現在可以把這些添加到我們的用戶界面。

顯示我們的寄存器

這里我們要做的就是給 handle_command 函數添加一個命令。通過下面的代碼,用戶可以輸入 register read rax、 register write rax 0x42 以及類似的語句。

  1. else if (is_prefix(command, "register")) { 
  2.     if (is_prefix(args[1], "dump")) { 
  3.         dump_registers(); 
  4.     } 
  5.     else if (is_prefix(args[1], "read")) { 
  6.         std::cout << get_register_value(m_pid, get_register_from_name(args[2])) << std::endl; 
  7.     } 
  8.     else if (is_prefix(args[1], "write")) { 
  9.         std::string val {args[3], 2}; //assume 0xVAL 
  10.         set_register_value(m_pid, get_register_from_name(args[2]), std::stol(val, 0, 16)); 
  11.     } 

接下來做什么?

設置斷點的時候我們已經讀取和寫入內存,因此我們只需要添加一些函數用于隱藏 ptrace 調用。

  1. uint64_t debugger::read_memory(uint64_t address) { 
  2.     return ptrace(PTRACE_PEEKDATA, m_pid, address, nullptr); 
  3. void debugger::write_memory(uint64_t address, uint64_t value) { 
  4.     ptrace(PTRACE_POKEDATA, m_pid, address, value); 

你可能想要添加支持一次讀取或者寫入多個字節,你可以在每次希望讀取另一個字節時通過遞增地址來實現。如果你需要的話,你也可以使用 process_vm_readv 和 process_vm_writev 或 /proc/<pid>/mem 代替 ptrace。

現在我們會給我們的用戶界面添加命令:

  1. else if(is_prefix(command, "memory")) { 
  2.         std::string addr {args[2], 2}; //assume 0xADDRESS 
  3.         if (is_prefix(args[1], "read")) { 
  4.             std::cout << std::hex << read_memory(std::stol(addr, 0, 16)) << std::endl; 
  5.         } 
  6.         if (is_prefix(args[1], "write")) { 
  7.             std::string val {args[3], 2}; //assume 0xVAL 
  8.             write_memory(std::stol(addr, 0, 16), std::stol(val, 0, 16)); 
  9.         } 
  10.     } 

給 continue_execution 打補丁

在我們測試我們的更改之前,我們現在可以實現一個更健全的 continue_execution 版本。由于我們可以獲取程序計數器,我們可以檢查我們的斷點映射來判斷我們是否處于一個斷點。如果是的話,我們可以停用斷點并在繼續之前跳過它。

為了清晰和簡潔起見,首先我們要添加一些幫助函數:

  1. uint64_t debugger::get_pc() { 
  2.     return get_register_value(m_pid, reg::rip); 
  3. void debugger::set_pc(uint64_t pc) { 
  4.     set_register_value(m_pid, reg::rip, pc); 

然后我們可以編寫函數來跳過斷點:

  1. void debugger::step_over_breakpoint() { 
  2.     // - 1 because execution will go past the breakpoint 
  3.     auto possible_breakpoint_location = get_pc() - 1; 
  4.     if (m_breakpoints.count(possible_breakpoint_location)) { 
  5.         auto& bp = m_breakpoints[possible_breakpoint_location]; 
  6.         if (bp.is_enabled()) { 
  7.             auto previous_instruction_address = possible_breakpoint_location; 
  8.             set_pc(previous_instruction_address); 
  9.             bp.disable(); 
  10.             ptrace(PTRACE_SINGLESTEP, m_pid, nullptr, nullptr); 
  11.             wait_for_signal(); 
  12.             bp.enable(); 
  13.         } 
  14.     } 

首先我們檢查當前程序計算器的值是否設置了一個斷點。如果有,首先我們把執行返回到斷點之前,停用它,跳過原來的指令,再重新啟用斷點。

wait_for_signal 封裝了我們常用的 waitpid 模式:

  1. void debugger::wait_for_signal() { 
  2.     int wait_status; 
  3.     auto options = 0; 
  4.     waitpid(m_pid, &wait_status, options); 

最后我們像下面這樣重寫 continue_execution:

  1. void debugger::continue_execution() { 
  2.     step_over_breakpoint(); 
  3.     ptrace(PTRACE_CONT, m_pid, nullptr, nullptr); 
  4.     wait_for_signal(); 

測試效果

現在我們可以讀取和修改寄存器了,我們可以對我們的 hello world 程序做一些有意思的更改。類似第一次測試,再次嘗試在 call 指令處設置斷點然后從那里繼續執行。你可以看到輸出了 Hello world。現在是有趣的部分,在輸出調用后設一個斷點、繼續、將 call 參數設置代碼的地址寫入程序計數器(rip)并繼續。由于程序計數器操縱,你應該再次看到輸出了 Hello world。為了以防你不確定在哪里設置斷點,下面是我上一篇博文中的 objdump 輸出:

  1. 0000000000400936 <main>: 
  2.   400936:   55                      push   rbp 
  3.   400937:   48 89 e5                mov    rbp,rsp 
  4.   40093a:   be 35 0a 40 00          mov    esi,0x400a35 
  5.   40093f:   bf 60 10 60 00          mov    edi,0x601060 
  6.   400944:   e8 d7 fe ff ff          call   400820 <_ZStlsISt11char_traitsIcEERSt13basic_ostreamIcT_ES5_PKc@plt> 
  7.   400949:   b8 00 00 00 00          mov    eax,0x0 
  8.   40094e:   5d                      pop    rbp 
  9.   40094f:   c3                      ret 

你要將程序計數器移回 0x40093a 以便正確設置 esi 和 edi 寄存器。

在下一篇博客中,我們會第一次接觸到 DWARF 信息并給我們的調試器添加一系列逐步調試的功能。之后,我們會有一個功能工具,它能逐步執行代碼、在想要的地方設置斷點、修改數據以及其它。一如以往,如果你有任何問題請留下你的評論!

你可以在這里找到這篇博文的代碼。 

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2017-06-28 14:21:22

Linux調試器斷點

2017-08-28 14:40:57

Linux調試器源碼和信號

2017-07-25 10:30:32

Linux調試器Elves和dwarv

2017-06-22 10:44:55

Linux調試器準備環境

2017-10-09 10:26:01

Linux調試器堆棧展開

2017-10-09 10:56:49

Linux調試器處理變量

2017-10-12 18:20:44

Linux調試器高級主題

2017-09-25 08:04:31

Linux調試器源碼級斷點

2017-08-28 15:29:19

Linux調試器源碼級逐步執行

2018-10-22 12:18:50

存儲器內存寄存器

2017-04-19 21:35:38

Linux調試器工作原理

2023-09-14 12:35:28

寄存器

2021-03-15 10:00:38

鴻蒙HarmonyOS應用

2010-12-21 10:16:53

2011-08-25 16:34:27

Lua調試器

2010-03-01 11:06:52

Python 調試器

2025-06-10 02:22:00

C語言硬件寄存器

2020-03-16 10:05:13

EmacsGUDLinux

2021-02-26 08:46:46

PHY寄存器網絡

2009-12-14 10:57:34

Ruby調試器
點贊
收藏

51CTO技術棧公眾號

日韩欧美亚洲国产精品字幕久久久| 国产乱淫av一区二区三区| 欧美一区二区三区四区久久| 97超碰人人爱| 性欧美8khd高清极品| 影音先锋中文字幕一区| 日韩精品免费在线播放| 嫩草av久久伊人妇女超级a| 福利在线视频导航| 国产在线精品国自产拍免费| 国内精品模特av私拍在线观看| 国产一级二级在线观看| 菠萝蜜视频在线观看www入口| 国产一区二区成人久久免费影院| 欧美日韩国产999| 特级西西人体wwwww| 国产一区二区三区四区五区3d| 亚洲欧美日韩久久精品| 国产精品区一区二区三含羞草| 久久久久久久中文字幕| 国产精品一区二区99| 7777精品伊人久久久大香线蕉超级流畅 | 欧美老女人性开放| 久久国产日韩欧美精品| 欧美激情区在线播放| 女女互磨互喷水高潮les呻吟| 精品入口麻豆88视频| 福利微拍一区二区| 日韩精品一区二区免费| 麻豆视频在线播放| 国产偷国产偷亚洲高清人白洁 | 91欧美视频在线| 成人小电影网站| 亚洲午夜久久久久久久久电影网| 伊人色综合影院| 久久精品国产亚洲a∨麻豆| 成人污污视频在线观看| 亚洲综合国产精品| 国产乱淫av免费| 蜜臀va亚洲va欧美va天堂| 69国产精品成人在线播放| 久久国产露脸精品国产| 亚州av乱码久久精品蜜桃 | 污影院在线观看| 成人免费小视频| 翔田千里亚洲一二三区| 国产女主播在线写真| 91麻豆成人久久精品二区三区| 高清国产在线一区| 亚洲国产精品无码久久| 国产一区二区日韩精品| 亚洲综合日韩在线| wwwav在线播放| 国产99精品国产| 国产成人免费观看| 少妇又色又爽又黄的视频| 成人国产精品免费网站| 国产一区高清视频| 天堂中文在线观看视频| 26uuu精品一区二区三区四区在线 26uuu精品一区二区在线观看 | 日韩精品中文字幕一区二区 | 日韩欧美在线视频日韩欧美在线视频| 日韩小视频网站| 咪咪网在线视频| 日韩欧美国产网站| 国产精品天天av精麻传媒| 九色成人搞黄网站| 正在播放亚洲一区| 日韩精品在线播放视频| 国产91精品入| 亚洲裸体xxxx| 亚洲熟女少妇一区二区| 在线精品小视频| 国产69精品99久久久久久宅男| 亚欧视频在线观看| 丝袜美腿亚洲色图| 国产精品久久精品| 国产乱人乱偷精品视频a人人澡| 国产精品系列在线播放| 国产一区二区三区黄| 欧美女优在线| 国产精品理论片在线观看| 在线观看av的网址| 成人av观看| 欧美精品一二三| 国产性生活毛片| 成久久久网站| 久久99久久亚洲国产| 亚洲黄色三级视频| 麻豆成人久久精品二区三区红 | 无码人妻一区二区三区精品视频| 国产精东传媒成人av电影| 亚洲第一天堂av| 亚洲图片第一页| 激情久久久久| 国产精品亚洲视频在线观看| 亚洲精品久久久蜜桃动漫| 久久美女艺术照精彩视频福利播放| 在线观看日韩片| 久草在线资源站手机版| 欧美日韩不卡视频| 国产亚洲色婷婷久久99精品91| 日韩精品影视| 91地址最新发布| 国产草草影院ccyycom| 久久久精品黄色| 国产激情片在线观看| 欧洲av一区二区| 精品91自产拍在线观看一区| 国产又黄又粗又猛又爽的| 国产精品试看| http;//www.99re视频| 国产51人人成人人人人爽色哟哟| 亚洲综合自拍偷拍| 国产视频手机在线播放| 日韩av中文字幕一区| 久久成人av网站| 曰批又黄又爽免费视频| 久久伊99综合婷婷久久伊| 男人的天堂视频在线| 成人黄色图片网站| 亚洲欧洲在线视频| 91精品国产乱码久久久张津瑜| 激情亚洲综合在线| 亚洲高清视频一区| 日韩精品专区| 亚洲欧美精品一区| 在线观看亚洲欧美| 99久久夜色精品国产网站| 欧美日韩午夜爽爽| 免费精品一区二区三区在线观看| 伊人伊人伊人久久| 中文在线最新版天堂| 久久久久久一二三区| 午夜精品久久久久久久无码| 中文字幕一区二区三区中文字幕| 久久色精品视频| 91片黄在线观看喷潮| 国产精品视频麻豆| 亚洲综合欧美在线| 三上亚洲一区二区| 国产精品中文久久久久久久| 不卡在线视频| 欧美日韩一区二区在线观看| 亚洲自拍偷拍图| 日韩成人一级大片| 性欧美精品一区二区三区在线播放 | 日本精品在线| 欧美日韩综合在线| 国产一级淫片久久久片a级| 免费不卡在线视频| 亚洲日本精品国产第一区| 国产亚洲精品精品国产亚洲综合| 色妞欧美日韩在线| 国产精品一区二区av白丝下载 | 中日韩黄色大片| 99r国产精品| aaaaaa亚洲| 久久国产亚洲精品| 91嫩草在线视频| 日本动漫理论片在线观看网站| 欧美成人福利视频| 日本免费观看视| 国产夜色精品一区二区av| 欧美日韩亚洲自拍| 欧美黄色aaaa| 国产呦系列欧美呦日韩呦| 久久sese| 精品国产一区二区三区久久狼黑人| 国产精品国产三级国产普通话对白| 亚洲日本在线视频观看| 日韩精品国产一区| 国产日韩欧美| 亚洲精品在线免费| 6080亚洲理论片在线观看| 91精品国产一区| 永久免费在线观看视频| 日韩免费高清视频| 色屁屁影院www国产高清麻豆| 中文字幕精品一区| 日韩高清一二三区| 鲁大师成人一区二区三区| 一本色道婷婷久久欧美| 91久久精品无嫩草影院 | 亚洲精品少妇一区二区| 九九热hot精品视频在线播放| 欧美中文字幕精品| 免费网站成人| 日韩激情av在线播放| 在线观看不卡的av| 午夜精品久久久久久久久久| eeuss中文字幕| 成人深夜视频在线观看| 深夜黄色小视频| 亚洲精品激情| 小说区视频区图片区| 欧美大片网址| 91影视免费在线观看| 巨茎人妖videos另类| 久久成人在线视频| 国产午夜精品一区理论片| 精品免费国产二区三区| 一区二区视频免费观看| 欧美日韩激情视频| 久久免费看少妇高潮v片特黄 | 裸体武打性艳史| 久久久蜜臀国产一区二区| 中文字幕18页| 韩国一区二区三区| 国产成人久久777777| 伊人激情综合| www亚洲国产| 精品国产123区| 国产亚洲第一区| 日韩成人精品| 成人免费淫片视频软件| 黄色精品视频| 日本久久久久亚洲中字幕| www欧美xxxx| 九九精品视频在线观看| 免费黄色在线观看| 中文字幕少妇一区二区三区| 五月婷中文字幕| 欧美精品一区二区在线播放| 国产xxxxxx| 7777女厕盗摄久久久| 一区二区视频网站| 欧美亚洲免费在线一区| 在线观看日本视频| 日韩欧美极品在线观看| 国产午夜激情视频| 亚洲精品国产无天堂网2021 | 成人欧美一区二区三区在线湿哒哒| 三上悠亚激情av一区二区三区| 久久人人爽人人爽人人片av高清| 宅男在线观看免费高清网站| 久久视频在线看| 秋霞午夜在线观看| 日韩在线免费视频观看| 777电影在线观看| 国产亚洲精品日韩| 韩国三级在线观看久| 亚洲天堂久久av| 国产午夜在线视频| 这里只有视频精品| 亚洲乱亚洲乱妇| 日韩在线国产精品| 黄网站在线免费| 久久精品国产亚洲| 51xtv成人影院| 欧美激情精品久久久久久| 午夜伦理在线视频| 97在线精品国自产拍中文| 国产欧洲在线| 国产不卡视频在线| 国产精品99精品一区二区三区∴| 国产精品欧美一区二区三区奶水 | 欧美日韩精品电影| 一级特黄aaa| 日韩欧美你懂的| 人妻与黑人一区二区三区| 亚洲国产中文字幕久久网| 欧美成人免费| 色老头一区二区三区| 少女频道在线观看免费播放电视剧| 欧美第一黄色网| 色偷偷偷在线视频播放| 国产99久久精品一区二区| 日本久久一区| 99久热re在线精品996热视频| 国产精品巨作av| 欧美视频小说| 亚洲区综合中文字幕日日| 日韩五码在线观看| 丝袜美腿亚洲一区| 男人女人拔萝卜视频| 99re这里只有精品6| 欧美福利第一页| 亚洲欧美视频一区| 天天操天天摸天天干| 欧美色偷偷大香| 少妇喷水在线观看| 日韩在线资源网| 91九色porn在线资源| 国产精品久久久久久久久久久不卡| 99亚洲男女激情在线观看| 久久66热这里只有精品| 日韩亚洲一区在线| 免费av手机在线观看| 日本va欧美va欧美va精品| 日本成人在线免费| 久久精品视频免费| 男女羞羞免费视频| 欧美综合欧美视频| 亚洲AV无码精品自拍| 国产亚洲精品美女| 岛国毛片av在线| 国产中文字幕亚洲| 午夜精品影视国产一区在线麻豆| a级网站在线观看| 日韩av不卡在线观看| 亚洲精品乱码久久久久久蜜桃图片| 国产精品全国免费观看高清| 在线观看免费国产视频| 91精品国产综合久久久久久久久久 | 最新国产精品拍自在线播放| 麻豆免费在线| 亚洲自拍欧美另类| 欧美激情另类| 成人免费毛片播放| 成人av片在线观看| 久久久久久久久毛片| 欧美日韩午夜精品| 欧美另类自拍| 57pao成人国产永久免费| 日韩精品中文字幕吗一区二区| 亚洲人成网站在线播放2019| 欧美资源在线| av黄色一级片| 一二三四区精品视频| 亚洲深夜福利网站| 日本最新在线视频| 日韩美女激情视频| 牛牛影视久久网| 久久这里只有精品18| 国内一区二区视频| 粉嫩精品久久99综合一区| 欧美性生交大片免费| 人人妻人人澡人人爽精品日本| 久久综合久中文字幕青草| 成人免费黄色| 日韩一区免费观看| 日韩国产成人精品| 女女互磨互喷水高潮les呻吟| 欧美日韩中文字幕日韩欧美| 日本美女一级视频| 久久久久久久成人| 成人中文字幕视频| 成人免费观看在线| 成人免费高清视频| 午夜偷拍福利视频| 亚洲成人精品久久久| 日本aa在线| 国产成人精品一区二区三区福利| 国产综合精品| 黄色在线免费播放| 偷拍亚洲欧洲综合| 四虎在线免费观看| 456亚洲影院| 亚洲性视频大全| www日韩在线观看| 国产精品女主播在线观看| 又污又黄的网站| 欧美另类老女人| baoyu135国产精品免费| 国产原创中文在线观看| 91小视频免费看| 中日精品一色哟哟| 久久精品夜夜夜夜夜久久| 日韩免费高清视频网站| 日本一道本久久| 久久精品视频在线免费观看| 亚洲无码精品国产| 九九热r在线视频精品| 久久午夜影院| 蜜臀av午夜一区二区三区 | 国产在线精品一区二区三区| 日韩午夜电影| 在线免费观看视频| 91精品国产美女浴室洗澡无遮挡| 青青草原国产在线| 欧美高清性xxxxhd| 久久99精品国产91久久来源| 午夜少妇久久久久久久久| 亚洲福利视频久久| 主播大秀视频在线观看一区二区| 大桥未久一区二区三区| 99久久久久久| 亚洲天天综合网| 国模视频一区二区| 欧美一区二区三区激情视频| 特级西西444www| 精品国产乱码久久久久久虫虫漫画| 福利片在线看| 波多野结衣久草一区| 久久成人精品| 69av.com| 伊人激情综合网| 国产精品x8x8一区二区| 最近中文字幕一区二区| 亚洲va国产天堂va久久en| 在线观看免费版| 国产在线一区二| 韩国一区二区三区| 销魂美女一区二区| 欧美国产亚洲视频| 成人羞羞视频播放网站| 69xxx免费视频| 欧美精品日韩一区| 男人天堂视频在线|