青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

isware

Linux的mmap文件內(nèi)存映射機(jī)制

  在講述文件映射的概念時, 不可避免的要牽涉到虛存(SVR 4的VM). 實(shí)際上, 文件映射是虛存的中心概念, 文件映射一方面給用戶提供了一組措施, 好似用戶將文件映射到自己地址空間的某個部分, 使用簡單的內(nèi)存訪問指令讀寫文件;另一方面, 它也可以用于內(nèi)核的基本組織模式, 在這種模式種, 內(nèi)核將整個地址空間視為諸如文件之類的一組不同對象的映射. 中的傳統(tǒng)文件訪問方式是, 用 open系統(tǒng)調(diào)用打開文件, 然后使用read, write以及l(fā)seek等調(diào)用進(jìn)行順序或者隨即的I/O. 這種方式是非常低效的, 每一次I/O操作都需要一次系統(tǒng)調(diào)用. 另外, 如果若干個進(jìn)程訪問同一個文件, 每個進(jìn)程都要在自己的地址空間維護(hù)一個副本, 浪費(fèi)了內(nèi)存空間. 而如果能夠通過一定的機(jī)制將頁面映射到進(jìn)程的地址空間中, 也就是說通過簡單的產(chǎn)生某些內(nèi)存管理數(shù)據(jù)結(jié)構(gòu)完成映射的創(chuàng)建. 當(dāng)進(jìn)程訪問頁面時產(chǎn)生一個缺頁中斷, 內(nèi)核將頁面讀入內(nèi)存并且更新頁表指向該頁面. 這種方式非常方便于同一副本的共享.

  VM是面向?qū)ο蟮姆椒ㄔO(shè)計的, 這里的對象是指內(nèi)存對象: 內(nèi)存對象是一個軟件抽象的概念, 它描述內(nèi)存區(qū)與后備存儲之間的映射. 系統(tǒng)可以使用多種類型的后備存儲, 比如交換空間, 本地或者遠(yuǎn)程文件以及幀緩存等等. VM系統(tǒng)對它們統(tǒng)一處理, 采用同一操作集操作, 比如讀取頁面或者回寫頁面等. 每種不同的后備存儲都可以用不同的方法實(shí)現(xiàn)這些操作. 這樣, 系統(tǒng)定義了一套統(tǒng)一的接口, 每種后備存儲給出自己的實(shí)現(xiàn)方法. 這樣, 進(jìn)程的地址空間就被視為一組映射到不同數(shù)據(jù)對象上的的映射組成. 所有的有效地址就是那些映射到數(shù)據(jù)對象上的地址. 這些對象為映射它的頁面提供了持久性的后備存儲. 映射用戶可以直接尋址這些對象.

  值得提出的是, VM體系結(jié)構(gòu)獨(dú)立于Unix系統(tǒng), 所有的Unix系統(tǒng)語義, 如正文, 數(shù)據(jù)及堆棧區(qū)都可以建構(gòu)在基本VM系統(tǒng)之上. 同時, VM體系結(jié)構(gòu)也是獨(dú)立于存儲管理的, 存儲管理是由操作系統(tǒng)實(shí)施的, 如: 究竟采取什么樣的對換和請求調(diào)頁算法, 究竟是采取分段還是分頁機(jī)制進(jìn)行存儲管理, 究竟是如何將虛擬地址轉(zhuǎn)換成為物理地址等等(Linux中是一種叫Three Level Page Table的機(jī)制), 這些都與內(nèi)存對象的概念無關(guān).

  下面介紹Linux中 VM的實(shí)現(xiàn).

  一個進(jìn)程應(yīng)該包括一個mm_struct(memory manage struct), 該結(jié)構(gòu)是進(jìn)程虛擬地址空間的抽象描述, 里面包括了進(jìn)程虛擬空間的一些管理信息: start_code, end_code, start_data, end_data, start_brk, end_brk等等信息. 另外, 也有一個指向進(jìn)程虛存區(qū)表(vm_area_struct: virtual memory area)的指針, 該鏈?zhǔn)前凑仗摂M地址的增長順序排列的. 在Linux進(jìn)程的地址空間被分作許多區(qū)(vma), 每個區(qū)(vma)都對應(yīng)虛擬地址空間上一段連續(xù)的區(qū)域, vma是可以被共享和保護(hù)的獨(dú)立實(shí)體, 這里的vma就是前面提到的內(nèi)存對象. 下面是vm_area_struct的結(jié)構(gòu), 其中, 前半部分是公共的, 與類型無關(guān)的一些數(shù)據(jù)成員, 如: 指向mm_struct的指針, 地址范圍等等, 后半部分則是與類型相關(guān)的成員, 其中最重要的是一個指向vm_operation_struct向量表的指針vm_ops, vm_pos向量表是一組虛函數(shù), 定義了與vma類型無關(guān)的接口. 每一個特定的子類, 即每種vma類型都在向量表中實(shí)現(xiàn)這些操作. 這里包括了: open, close, unmap, protect, sync, nopage, wppage, swapout這些操作.

  struct vm_area_struct {

  /*公共的, 與vma類型無關(guān)的 */

  struct mm_struct * vm_mm;

  unsigned long vm_start;

  unsigned long vm_end;

  struct vm_area_struct *vm_next;

  pgprot_t vm_page_prot;

  unsigned long vm_flags;

  short vm_avl_height;

  struct vm_area_struct * vm_avl_left;

  struct vm_area_struct * vm_avl_right;

  struct vm_area_struct *vm_next_share;

  struct vm_area_struct **vm_pprev_share;

  /* 與類型相關(guān)的 */

  struct vm_operations_struct * vm_ops;

  unsigned long vm_pgoff;

  struct file * vm_file;

  unsigned long vm_raend;

  void * vm_private_data;

  };

  vm_ops: open, close, no_page, swapin, swapout……

  介紹完VM的基本概念后, 我們可以講述mmap和munmap系統(tǒng)調(diào)用了. mmap調(diào)用實(shí)際上就是一個內(nèi)存對象vma的創(chuàng)建過程, mmap的調(diào)用格式是:

  void * mmap(void *start, size_t length, int prot , int flags, int fd, off_t offset);

  其中start是映射地址, length是映射長度, 如果flags的MAP_FIXED不被置位, 則該參數(shù)通常被忽略, 而查找進(jìn)程地址空間中第一個長度符合的空閑區(qū)域;Fd是映射文件的文件句柄, offset是映射文件中的偏移地址;prot是映射保護(hù)權(quán)限, 可以是PROT_EXEC, PROT_READ, PROT_WRITE, PROT_NONE, flags則是指映射類型, 可以是MAP_FIXED, MAP_PRIVATE, MAP_SHARED, 該參數(shù)被 指定為MAP_PRIVATE和MAP_SHARED其中之一, MAP_PRIVATE 是創(chuàng)建一個寫時拷貝映射(copy-on-write), 也就是說如果有多個進(jìn)程同時映射到一個文件上, 映射建立時只是共享同樣的存儲頁面, 但是某進(jìn)程企圖修改頁面內(nèi)容, 則復(fù)制一個副本給該進(jìn)程私用, 它的任何修改對其它進(jìn)程都不可見. 而MAP_SHARED則無論修改與否都使用同一副本, 任何進(jìn)程對頁面的修改對其它進(jìn)程都是可見的.

  mmap系統(tǒng)調(diào)用的實(shí)現(xiàn)過程是:

  1.先通過文件系統(tǒng)定位要映射的文件;

  2.權(quán)限檢查, 映射的權(quán)限不會超過文件打開的方式, 也就是說如果文件是以只讀方式打開, 那么則不允許建立一個可寫映射;

  3.創(chuàng)建一個vma對象, 并對之進(jìn)行初始化;

  4.調(diào)用映射文件的mmap函數(shù), 其主要工作是給vm_ops向量表賦值;

  5.把該vma鏈入該進(jìn)程的vma鏈表中, 如果可以和前后的vma合并則合并;

  6.如果是要求VM_LOCKED(映射區(qū)不被換出)方式映射, 則發(fā)出缺頁請求, 把映射頁面讀入內(nèi)存中.

  munmap(void * start, size_t length):

  該調(diào)用可以看作是 mmap的一個逆過程. 它將進(jìn)程中從start開始length長度的一段區(qū)域的映射關(guān)閉, 如果該區(qū)域不是恰好對應(yīng)一個vma, 則有可能會分割幾個或幾個vma.

  msync(void * start, size_t length, int flags):

  把映射區(qū)域的修改回寫到后備存儲中. munmap 時并不保證頁面回寫, 如果不調(diào)用msync, 那么有可能在munmap后丟失對映射區(qū)的修改. 其中flags可以是MS_SYNC, MS_ASYNC, MS_INVALIDATE, MS_SYNC要求回寫完成后才返回, MS_ASYNC發(fā)出回寫請求后立即返回, MS_INVALIDATE使用回寫的內(nèi)容更新該文件的其它映射. 該系統(tǒng)調(diào)用是通過調(diào)用映射文件的sync函數(shù)來完成工作的.

  brk(void * end_data_segement):

  將進(jìn)程的數(shù)據(jù)段擴(kuò)展到 end_data_segement指定的地址, 該系統(tǒng)調(diào)用和mmap的實(shí)現(xiàn)方式十分相似, 同樣是產(chǎn)生一個vma, 然后指定其屬性. 不過在此之前需要做一些合法性檢查, 比如該地址是否大于mm->end_code, end_data_segement和mm->brk之間是否還存在其它vma等等. 通過brk產(chǎn)生的vma映射的文件為空, 這和匿名映射產(chǎn)生的vma相似, 關(guān)于匿名映射不做進(jìn)一步介紹. 庫函數(shù)malloc就是通過brk實(shí)現(xiàn)的.

  Linux提供了內(nèi)存映射函數(shù)mmap, 它把文件內(nèi)容映射到一段內(nèi)存上(準(zhǔn)確說是虛擬內(nèi)存上), 通過對這段內(nèi)存的讀取和修改, 實(shí)現(xiàn)對文件的讀取和修改, 先來看一下mmap的函數(shù)聲明:

  頭文件:

  <unistd.h>

  <sys/mman.h>

  原型: void *mmap(void *addr, size_t length, int prot, int flags, int fd, off_t offsize);

  返回值: 成功則返回映射區(qū)起始地址, 失敗則返回MAP_FAILED(-1).

  參數(shù):

  addr: 指定映射的起始地址, 通常設(shè)為NULL, 由系統(tǒng)指定.

  length: 將文件的多大長度映射到內(nèi)存.

  prot: 映射區(qū)的保護(hù)方式, 可以是:

  PROT_EXEC: 映射區(qū)可被執(zhí)行.

  PROT_READ: 映射區(qū)可被讀取.

  PROT_WRITE: 映射區(qū)可被寫入.

  PROT_NONE: 映射區(qū)不能存取.

  flags: 映射區(qū)的特性, 可以是:

  MAP_SHARED: 對映射區(qū)域的寫入數(shù)據(jù)會復(fù)制回文件, 且允許其他映射該文件的進(jìn)程共享.

  MAP_PRIVATE: 對映射區(qū)域的寫入操作會產(chǎn)生一個映射的復(fù)制(copy-on-write), 對此區(qū)域所做的修改不會寫回原文件.

  此外還有其他幾個flags不很常用, 具體查看linux C函數(shù)說明.

  fd: 由open返回的文件描述符, 代表要映射的文件.

  offset: 以文件開始處的偏移量, 是分頁大小的整數(shù)倍, 通常為0, 表示從文件頭開始映射.

  下面說一下內(nèi)存映射的步驟:

  用open系統(tǒng)調(diào)用打開文件, 并返回描述符fd.

  用mmap建立內(nèi)存映射, 并返回映射首地址指針start.

  對映射(文件)進(jìn)行各種操作, 顯示(printf), 修改(sprintf).

  用munmap(void *start, size_t lenght)關(guān)閉內(nèi)存映射.

  用close系統(tǒng)調(diào)用關(guān)閉文件fd.

  注意事項(xiàng):

  在修改映射的文件時, 只能在原長度上修改, 不能增加文件長度, 內(nèi)存是已經(jīng)分配好的.

  Linux-mmap函數(shù)介紹

  mmap函數(shù)是unix/linux下的系統(tǒng)調(diào)用,來看《Unix Netword programming》卷二12.2節(jié)對mmap的介紹:

  The mmap function maps either a file or a Posix shared memory object into the address space of a process.We use this function for three purposes:

  1. with a regular file to provide memory-mapped I/O

  2. with special files to provide anonymous memory mappings

  3. with shm_open to provide Posix shared memory between unrelated processes

  mmap系統(tǒng)調(diào)用并不是完全為了用于共享內(nèi)存而設(shè)計的.它本身提供了不同于一般對普通文件的訪問方式,進(jìn)程可以像讀寫內(nèi)存一樣對普通文件的操作.而 Posix或系統(tǒng)V的共享內(nèi)存IPC則純粹用于共享目的,當(dāng)然mmap()實(shí)現(xiàn)共享內(nèi)存也是其主要應(yīng)用之一.

  mmap系統(tǒng)調(diào)用進(jìn)程之間通過映射同一個普通文件實(shí)現(xiàn)共享內(nèi)存.普通文件被映射到進(jìn)程地址空間后,進(jìn)程可以像訪問普通內(nèi)存一樣對文件進(jìn)行訪問,不必再調(diào)用read(),write()等操作.

  我們的程序中大量運(yùn)用了mmap,用到的正是mmap的這種“像訪問普通內(nèi)存一樣對文件進(jìn)行訪問”的功能.實(shí)踐證明,當(dāng)要對一個文件頻繁的進(jìn)行訪問,并且指針來回移動時,調(diào)用mmap比用常規(guī)的方法快很多.

  來看看mmap的定義:

  void *mmap(void *addr, size_t len, int prot, int flags, int fd, off_t offset);

  參數(shù)fd為即將映射到進(jìn)程空間的文件描述字,一般由open()返回,同時,fd可以指定為-1,此時須指定flags參數(shù)中的MAP_ANON,表明進(jìn)行的是匿名映射(不涉及具體的文件名,避免了文件的創(chuàng)建及打開,很顯然只能用于具有親緣關(guān)系的進(jìn)程間通信).

  len是映射到調(diào)用進(jìn)程地址空間的字節(jié)數(shù),它從被映射文件開頭offset個字節(jié)開始算起.

  prot參數(shù)指定共享內(nèi)存的訪問權(quán)限.可取如下幾個值的或:PROT_READ(可讀),PROT_WRITE(可寫),PROT_EXEC(可執(zhí)行),PROT_NONE(不可訪問).

  flags由以下幾個常值指定:MAP_SHARED, MAP_PRIVATE, MAP_FIXED.其中,MAP_SHARED,MAP_PRIVATE必選其一,而MAP_FIXED則不推薦使用.

  如果指定為MAP_SHARED,則對映射的內(nèi)存所做的修改同樣影響到文件.如果是MAP_PRIVATE,則對映射的內(nèi)存所做的修改僅對該進(jìn)程可見,對文件沒有影響.

  offset參數(shù)一般設(shè)為0,表示從文件頭開始映射.

  參數(shù)addr指定文件應(yīng)被映射到進(jìn)程空間的起始地址,一般被指定一個空指針,此時選擇起始地址的任務(wù)留給內(nèi)核來完成.函數(shù)的返回值為文件映射到進(jìn)程空間的地址,進(jìn)程可直接操作起始地址為該值的有效地址.

  ,舉個例子來結(jié)束本節(jié).4.2節(jié)說過,Fileinformation數(shù)組是以二進(jìn)制的形式寫進(jìn)一個叫inforindex的文件中.那么,當(dāng)要訪問 Fileinformation數(shù)組時,代碼類似這樣:

  struct stat st;

  char buffer=” inforindex”;

  Fileinformation *_fileinfoIndexptr = NULL;

  if(stat(buffer,&st)<0)

 

  fprintf(stderr,"error to stat %sn",buffer);

  exit(-1);

  }

  // mmap the inforindex to _fileinfoIndexptr

  int fd=open(buffer, O_RDONLY);

  if(fd<0)

  {

  printf("error to open %sn",buffer);

  exit(-1);

  }

  _fileinfoIndexptr = (Fileinformation*)mmap(NULL,st.st_size, PROT_READ,MAP_SHARED,fd,0);

  if(MAP_FAILED == _fileinfoIndexptr)

  {

  printf("error to mmap %sn",buffer);

  close(fd);

  exit(-1);

  }

  close(fd);

  下面這個例子顯示了把文件映射到內(nèi)存的方法

  源代碼是:

  /************關(guān)于本文檔********************************************

  *filename: mmap.c

  *purpose: 說明調(diào)用mmap把文件映射到內(nèi)存的方法

  *wrote by: zhoulifa(zhoulifa@163.com) 周立發(fā)(http://zhoulifa.bokee.com)

  Linux愛好者 Linux知識傳播者 SOHO族 開發(fā)者 最擅長C語言

  *date time:2008-01-27 18:59 上海大雪天,據(jù)說是多年不遇

  *Note: 任何人可以任意復(fù)制代碼并運(yùn)用這些文檔,當(dāng)然包括你的商業(yè)用途

  * 但請遵循GPL

  *Thanks to:

  * Ubuntu 本程序在Ubuntu 7.10系統(tǒng)上測試完全正常

  * Google.com 我通常通過google搜索發(fā)現(xiàn)許多有用的資料

  *Hope:希望越來越多的人貢獻(xiàn)自己的力量,為科學(xué)技術(shù)發(fā)展出力

  * 科技站在巨人的肩膀上進(jìn)步更快!感謝有開源前輩的貢獻(xiàn)!

  *********************************************************************/

  #include <sys/mman.h> /* for mmap and munmap */

  #include <sys/types.h> /* for open */

  #include <sys/stat.h> /* for open */

  #include <fcntl.h> /* for open */

  #include <unistd.h> /* for lseek and write */

  #include <stdio.h>

  int main(int argc, char **argv)

  {

  int fd;

  char *mapped_mem, * p;

  int flength = 1024;

  void * start_addr = 0;

  fd = open(argv[1], O_RDWR | O_CREAT, S_IRUSR | S_IWUSR);

  flength = lseek(fd, 1, SEEK_END);

  write(fd, "", 1); /* 在文件添加一個空字符,以便下面printf正常工作 */

  lseek(fd, 0, SEEK_SET);

  mapped_mem = mmap(start_addr, flength, PROT_READ, //允許讀

  MAP_PRIVATE, //不允許其它進(jìn)程訪問此內(nèi)存區(qū)域

  fd, 0);

  /* 使用映射區(qū)域. */

  printf("%sn", mapped_mem); /* 為了保證這里工作正常,參數(shù)傳遞的文件名最好是一個文本文件 */

  close(fd);

  munmap(mapped_mem, flength);

  return 0;

  }

  編譯運(yùn)行此程序:

  gcc -Wall mmap.c

  ./a.out text_filename

  上面的方法用了PROT_READ,只能讀取文件里的內(nèi)容,不能修改,如果換成PROT_WRITE就可以修改文件的內(nèi)容了.又 用了MAAP_PRIVATE只能此進(jìn)程使用此內(nèi)存區(qū)域,如果換成MAP_SHARED,則可以被其它進(jìn)程訪問,比如下面的:

  #include <sys/mman.h> /* for mmap and munmap */

  #include <sys/types.h> /* for open */

  #include <sys/stat.h> /* for open */

  #include <fcntl.h> /* for open */

  #include <unistd.h> /* for lseek and write */

  #include <stdio.h>

  #include <string.h> /* for memcpy */

  int main(int argc, char **argv)

  {

  int fd;

  char *mapped_mem, * p;

  int flength = 1024;

  void * start_addr = 0;

  fd = open(argv[1], O_RDWR | O_CREAT, S_IRUSR | S_IWUSR);

  flength = lseek(fd, 1, SEEK_END);

  write(fd, "", 1); /* 在文件添加一個空字符,以便下面printf正常工作 */

  lseek(fd, 0, SEEK_SET);

  start_addr = 0x80000;

  mapped_mem = mmap(start_addr, flength, PROT_READ|PROT_WRITE, //允許寫入

  MAP_SHARED, //允許其它進(jìn)程訪問此內(nèi)存區(qū)域

  fd, 0);

  /* 使用映射區(qū)域. */

  printf("%sn", mapped_mem); /* 為了保證這里工作正常,參數(shù)傳遞的文件名最好是一個文本文 */

  while((p = strstr(mapped_mem, "Hello"))) { /* 此處來修改文件 內(nèi)容 */

  memcpy(p, "Linux", 5);

  p = 5;

  }

  close(fd);

  munmap(mapped_mem, flength);

  return 0;

  }

  man -a mmap 看更詳細(xì)的信息

posted on 2011-07-20 15:51 艾斯維亞 閱讀(1375) 評論(0)  編輯 收藏 引用


只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            日韩一级黄色大片| 亚洲综合色噜噜狠狠| 免费亚洲网站| 亚洲精品国产精品国产自| 欧美成人精精品一区二区频| 久久一区二区三区av| 亚洲国内自拍| 亚洲麻豆av| 国产婷婷色一区二区三区| 久久久亚洲国产天美传媒修理工| 久久精品欧美| 亚洲精品午夜精品| 亚洲午夜精品| 亚洲成色777777女色窝| 亚洲激情在线播放| 欧美视频在线一区| 久久久视频精品| 欧美另类久久久品| 久久精品国产成人| 欧美激情精品久久久久久久变态 | 欧美日韩国产探花| 午夜免费日韩视频| 免费欧美高清视频| 欧美一区三区二区在线观看| 美脚丝袜一区二区三区在线观看| 日韩一级大片在线| 欧美一区二区三区在线视频 | 国产欧美在线视频| 亚洲高清电影| 国产色综合天天综合网| 亚洲黄色天堂| 激情国产一区二区| 亚洲午夜女主播在线直播| 在线免费观看一区二区三区| 在线视频欧美日韩| 亚洲日本理论电影| 久久国产手机看片| 性欧美8khd高清极品| 欧美激情中文不卡| 老司机精品视频一区二区三区| 欧美丝袜第一区| 亚洲国产电影| 在线观看亚洲视频啊啊啊啊| 亚洲夜晚福利在线观看| 一区二区国产日产| 欧美成人dvd在线视频| 久久久久久亚洲精品中文字幕| 欧美日在线观看| 91久久在线观看| 亚洲人成亚洲人成在线观看| 久久精品91| 久久久久国产精品午夜一区| 国产精品美女久久久久av超清| 亚洲激情中文1区| 亚洲精品老司机| 欧美国产日韩一二三区| 免费成人你懂的| 一区二区三区我不卡| 欧美在线视频在线播放完整版免费观看 | 一本色道久久88综合亚洲精品ⅰ| 久久精品人人爽| 久久久精品日韩欧美| 国产美女一区二区| 亚洲性图久久| 欧美一区二区视频在线| 欧美在线观看视频在线| 国产精品乱码人人做人人爱| 在线视频亚洲欧美| 亚洲欧美韩国| 国产欧美精品日韩精品| 午夜视频在线观看一区| 久久av在线| 国产中文一区二区| 久久久最新网址| 欧美激情精品久久久六区热门| 亚洲成人直播| 欧美激情精品久久久久久免费印度 | 欧美偷拍一区二区| 这里只有精品视频| 久久精品亚洲一区| 亚洲电影第三页| 欧美巨乳波霸| 亚洲一区二区三区在线看| 欧美在线观看网址综合| 黄色免费成人| 欧美肥婆在线| 亚洲一级黄色| 免费不卡视频| 一区二区三区视频观看| 国产精品综合不卡av| 久久成人精品一区二区三区| 欧美成人首页| 亚洲综合久久久久| 狠狠色狠狠色综合日日91app| 久久在线视频| 亚洲少妇自拍| 欧美99在线视频观看| 亚洲午夜精品17c| 黑人巨大精品欧美黑白配亚洲| 欧美aⅴ99久久黑人专区| 一本久道久久久| 你懂的一区二区| 亚洲欧美日韩另类| 一色屋精品视频免费看| 欧美日韩国产精品成人| 久久精品国产77777蜜臀| 亚洲精品国产精品国自产在线| 久久av资源网站| 一本色道久久加勒比88综合| 国产一区二区欧美| 欧美三级电影一区| 另类图片国产| 欧美一区二区成人6969| 亚洲精品久久久久久一区二区| 欧美一区二区三区在线看| 亚洲黄色成人久久久| 国产欧美在线观看一区| 欧美精品一区视频| 久久全国免费视频| 亚洲欧美制服另类日韩| 亚洲伦伦在线| 亚洲第一精品电影| 久久亚洲精品伦理| 欧美主播一区二区三区美女 久久精品人 | 午夜精品久久久久久99热| 亚洲免费成人| 欧美激情免费在线| 老司机午夜免费精品视频| 欧美一二三区精品| 亚洲男人天堂2024| 亚洲一区二区高清| 一区二区三区国产盗摄| 亚洲人成人77777线观看| 在线观看免费视频综合| 韩日成人在线| 韩日精品中文字幕| 国产资源精品在线观看| 国产一区二区三区精品久久久| 欧美亚日韩国产aⅴ精品中极品| 欧美美女日韩| 欧美久久电影| 欧美视频不卡中文| 国产精品久久久久久久久搜平片 | 六月丁香综合| 免费视频一区二区三区在线观看| 久久精品国产77777蜜臀| 欧美自拍偷拍| 久久露脸国产精品| 女人香蕉久久**毛片精品| 男女视频一区二区| 欧美人牲a欧美精品| 欧美日韩免费在线观看| 欧美午夜精彩| 国产伦理一区| 国产综合香蕉五月婷在线| 在线免费观看日本欧美| 91久久久国产精品| 亚洲一区二区三区免费在线观看| 亚洲一区在线播放| 久久大逼视频| 欧美激情网友自拍| 亚洲免费观看高清在线观看 | 午夜在线不卡| 蜜桃久久av| 欧美色中文字幕| 国产午夜精品一区二区三区视频| 黄色小说综合网站| 一道本一区二区| 久久精品99国产精品| 免费在线播放第一区高清av| 亚洲欧洲一区二区天堂久久| 在线亚洲电影| 久久一区二区三区四区| 欧美日韩视频在线一区二区 | 这里只有视频精品| 欧美一区国产在线| 亚洲国产精品久久久久| 亚洲午夜在线视频| 美女脱光内衣内裤视频久久影院| 欧美日韩亚洲在线| 一区在线免费观看| 亚洲欧美日韩一区二区| 欧美xart系列在线观看| 一本久道久久综合婷婷鲸鱼| 欧美在线视频二区| 欧美视频免费在线观看| 亚洲第一综合天堂另类专| 亚洲综合视频1区| 亚洲成人资源网| 久久成人免费视频| 欧美性猛交视频| 亚洲美女福利视频网站| 久久夜色精品一区| 亚洲一区不卡| 欧美精品成人一区二区在线观看| 国产三区二区一区久久| 亚洲午夜激情网页| 最新高清无码专区| 久久久午夜精品| 国产一区二区在线免费观看 |