日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

简单深入两个虚拟内存API VirtualAlloc及VritualCopy

發布時間:2023/12/15 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 简单深入两个虚拟内存API VirtualAlloc及VritualCopy 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
VirtualAlloc : (配置虛擬記憶體)

[MSDN] http://msdn.microsoft.com/en-us/library/aa366887(VS.85).aspx

LPVOID WINAPI VirtualAlloc (LPVOID lpAddress, //所要分配記憶體區域虛擬位址的起始位址DWORD dwSize, //要分配或者保留的區域的大小DWORD flAllocationType, //分配的類型:DWORD flProtect //指定所要分配區域的存取權限(保護方式)); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

Windows CE上每一個Process其虛擬記憶體(virtual memroy)定址空間(address space)最多只有32 MB,這塊定址空間包含了程式碼﹑程式執行所需要的DLL﹑唯讀資料區域﹑堆疊空間(包含thread stack)外,剩餘的就由Heap所使用。C語言所使用的malloc含式就在Heap上配置記憶體供程式使用,當不在需要這塊記憶體時,可以呼叫 free含式歸還這塊記憶體。
由於最多只有32MB的定址空間,因此當使用malloc含式時,所能配置的記憶體總量是無法超過32MB的(還要扣掉程式碼等所使用的空間),那如果實際記憶體卻提供足夠的量,但是定址空間32MB不夠用時,該怎麼辦呢?要解決這個問題,我們必須更深入瞭解malloc含式。
malloc含式要配置記憶體時,要呼叫到系統所提供的VirtualAlloc含式,VirtualAlloc含式可以先保留一塊定址空間,當有需要時,再於這塊定址空間內配置實際記憶體,這塊記憶體的大小可以小於或等於保留的定址空間大小,當小於保留空間時,程式可以指定實際記憶體從這塊空間的那個位置開始配置。VirtualAlloc含式也可以在保留定址空間同時配置記憶體,如果呼叫成功,保留下來的定址空間可以馬上使用。基本上,malloc 含式以後者方式在保留定址空間時也配置了實際記憶體。
為了要讓程式可以使用超過32MB記憶體,Windows CE系統設定0x42000000~0x80000000為Large Memory Area(簡稱LMA),LMA主要提供定址空間給memory mapped file使用,但是程式透過VirtualAlloc含式也可以使用這塊定址區域。
當VirtualAlloc含式發現要求保留的size超過2MB大小時,會從LMA中找出一塊區域並保留,程式可以在這塊區域中再使用VirtualAlloc含式配置實際記憶體。(reference:http://www.wretch.cc/blog/sufan525/6899850)

flAllocationType詳細說明:

MEM_COMMIT,MEM_AUTO_COMMIT,MEM_RESERVE和MEM_TOP_DOWN。MEM_COMMIT標誌分配程式使用的記憶體,MEM_RESERVE保留虛擬位址空間以便以後提交。保留的頁不能存取直到調用VirtualAlloc的時候再次指定了MEM_COMMIT標誌。第三個標誌,MEM_TOP_DOWN,告訴系統從最高可允許的虛擬位址開始映射應用程式。

The MEM_AUTO_COMMIT標誌是唯一一個Windows CE最方便的標誌,當這個參數被指定了之後,區塊立即被保留,當其中的頁被第一次存取的時候,系統將自動提交該頁。這允許你分配大塊的虛擬記憶體而不需要顧及系統和實際RAM分配直到當前頁被第一次使用。自動提交記憶體的缺點是,物理RAM需要退回當頁面被第一次訪問時可能不可用的頁面。在這種情形下,系統將產生一個異常(exception)(可能會出現因為無法訪問而出錯)

MSDN:Reserves or commits a region of pages in the virtual address space of the calling process. Memory allocated by this function is automatically initialized to zero, unless MEM_RESET is specified.

To allocate memory in the address space of another process, use the VirtualAllocEx function.
VirtualAllocEx Function

LPVOID WINAPI VirtualAllocEx(
? __in????? HANDLE hProcess,
? __in_opt? LPVOID lpAddress,
? __in????? SIZE_T dwSize,
? __in????? DWORD flAllocationType,
? __in????? DWORD flProtect
);

Reserves or commits a region of memory within the virtual address space of a specified process. The function initializes the memory it allocates to zero, unless MEM_RESET is used.

如果想只配置 其他指定的Process的 記憶體空間,可以用VirtualAllocEX 函式,把實體控制碼放到第一個參數hProcess。

實作函式: DoVirtualAlloc

LPVOID DoVirtualAlloc( LPVOID lpvAddress0, DWORD cbSize, DWORD fdwAllocationType, DWORD fdwProtect, DWORD fdwInternal,DWORD dwPFNBase) .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

(WINCEROOT/PRIVATE/WINCEOS/COREOS/NK/KERNEL/virtmem.c)

參數驗證:

1.cbSize 為 0
2.cbSize > 32 MB 且沒有指定虛擬記憶體起始位址
3.無效的存取控制資訊

???? lpAddress:pointer指向指向要分配的region的起始位址。 如果分配的記憶體空間是reserved,那他的位址就會被rounded down 到下一個64-KB,如果記憶體空間不只是reserve,即將要commit,他的address就會被 rounded down到下一個 page (通常為1K或4K)。而如何決定一個一個page的大小則使用了 GetSystemInfo function(一個傳回現在系統資訊的function)。如果這個parameter值是NULL, 就由系統決定這個region要配置到哪裡。
???? cbSize:以bytes為單位表示這個region的大小,如果lpAddress parameter是NULL,cbSize的值就會被rounded up to the next page boundary,否則,被配置的pages就會包括所有從lpAddress to lpAddress+cbSize的範圍。這表示了一個2-byte range跨越了page boundary,造成了有兩個page被包含在被配置的region。
fdwAllocationType:表示配置的型態。以下的表列出了這些型態:

Value

Description

MEM_COMMIT??

以Page為單位

specified region of pages配置在memory或配置在diskpaging file 。試圖commit一個已經被commitpage將不會造成這個functionfail 這表示不管是已經被commit或還沒被commitpages是否會造成functionfailure

MEM_RESERVE?

以Page為單位,但有64KB granularity boundary的限制

Reserves 一段virtual address spaceprocess但是不配給他任何實體儲存空間。這一段被 reserve的範圍不可以再被其他allocation operations使用。Reserved pages 可以在接下來呼叫的DoVirtualAlloc時被committe

MEM_RESET?? (以page為單位)

WinCE不支援

MEM_TOP_DOWN

配置highest possible addressmemory .

其中MEM_RESERVE只是在Process的虛擬地址空間內保留一段虛擬記憶體,並不配置實體記憶體,因此保留的虛擬記憶體並不能被應用程式直接使用。MEM_COMMIT階段才真正的為虛擬記憶體配置實體記憶體。

?

? fdwProtect:表示存取的保護型態。.如果 pages正在被committee,底下列出所有可能發生的型態:
參考MSDN : http://msdn.microsoft.com/en-us/library/aa366786(VS.85).aspx

Value

Description

PAGE_READONLY

對於被commited pages有存取的權力, 如果試圖對commited region 進行寫入會造成access violation?

該區域為唯讀。如果應用程式試圖訪問區域中的頁的時候,將會被拒絕訪問。

PAGE_READWRITE

對於 commited pages有讀和寫的權力
區域可被應用程式讀寫。

PAGE_EXECUTE

對於commited pages有執行的權力,任何對commited pages有讀或寫的動作都會造成access violation
區域包含可被系統執行的代碼。試圖讀寫該區域的操作將被拒絕。

PAGE_EXECUTE_READ

允許在commited pages有執行和讀取的權力,任何試圖對commited pages進行寫入動作都會被視作access violation
區域包含可執行代碼,應用程式可以讀取該區域。

PAGE_EXECUTE_READWRITE

允許對commited pages 進行執行讀取以及寫入的動作。
區域包含可執行代碼,應用程式可以讀寫該區域。

PAGE_GUARD

在這一個region裡的page都會視guard pages.,任何試圖讀或寫guard page都會造成系統raise一個STATUS_GUARD_PAGE exception,如果一個guard page exceptionsystem service時發生servicereturn一個失敗的 indicator
區域第一次被訪問時進入一個STATUS_GUARD_PAGE異常,這個標誌要和其他保護標誌合併使用,表明區域被第一次訪問的許可權。

PAGE_NOACCESS

不允許任何對commited pages 的存取,任何試圖去讀或寫,執行commited pages都會造成access violation exception,(稱為a general protection (GP) fault.
任何存取該區域的操作將被拒絕

PAGE_NOCACHE

不允許committed regions of pages擁有cache,由hardware來支援。在一般的情況下並不適用,對於device drivers比較有用。

對應至此區域的RAM分頁將無法由處理器快取。

PAGE_GUARD和PAGE_NOCHACHE標誌可以和其他標誌合併使用以進一步指定頁的特徵。PAGE_GUARD標誌指定了一個防護頁(guard page),即當一個頁被提交時會因第一次被訪問而產生一個one-shot異常,接著取得指定的存取權限。PAGE_NOCACHE防止當它映射到虛擬頁的時候被微處理器快取緩衝。這個標誌方便設備驅動使用直接記憶體存取方式(DMA)來共用記憶體區塊的裝置驅動程式(Device Driver)而言是很便利的。

?

範例1:

虛擬記憶體在區域內被保留是以64KB為page boundary的。(註:參考WindowsCE 嵌入式系統 理論與實務ISBN:986-125-200-2與此文章,因為Memblock的一個單位就是64K,64K是因為以前16位元的舊系統定義並保留下來的,而依據系統不同而會有不同的分頁大小,通常是1K或4K,以上是本人亂猜的,可參考http://blogs.msdn.com/oldnewthing/archive/2003/10/08/55239.aspx )

因為對每個Process有32MB虛擬記憶體位址空間的限制,這就有了一個最大值 32MB/64KB-1(Guard Section Reserved)=511,這是虛擬記憶體在記憶體溢出前能被保留的最大值。

#define PAGESIZE 1024 // Assume we're on a 1-KB page machinefor (i = 0; i < 512; i++)pMem[i] = VirtualAlloc (NULL, PAGESIZE, MEM_RESERVE │ MEM_COMMIT,PAGE_READWRITE); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

該程式碼配置了512個單頁的虛擬記憶體。甚至你系統還有一半的可用RAM,VirtualAlloc也會在完成配置前失敗。因為它的運作已經超出了應用程式的虛擬位址空間。發生這種情況是因為每1-KB的區塊要佔用64-KB的空間
(註:因為保留最小以64KB為單位,假如只有1KB在實體記憶體,64KB的虛擬記憶體也會被全部Reserved到,也就是每執行一次迴圈,VirtualAlloc就幫你保留64k而不是1k)
,接下來應用程式的Code,Stack,和Local Heap也要映射到同樣的32-MB虛擬位址空間,可用的虛擬分配區域通常不超過475個。( 已經用了2304KB=2.25MB )

?

一個比較好的分配512k(此例也等於512頁)虛擬記憶體的方法是這樣做:

#define PAGESIZE 1024 // Assume we're on a 1-KB page machine.// Reserve a region first.pMemBase = VirtualAlloc (NULL, PAGESIZE * 512, MEM_RESERVE,PAGE_NOACCESS);for (i = 0; i < 512; i++)pMem[i] = VirtualAlloc (pMemBase + (i*PAGESIZE), PAGESIZE,MEM_COMMIT, PAGE_READWRITE); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

程式碼首先保留了Reserved一塊區域,頁面將在以後被提交Commit。因為區域已經被先保留了,且提交頁Commit Page不受64-KB granularity boundary的規定,如果你系統中有512KB的可用實體記憶體,分配將會成功。(這樣實體記憶體不會因為保留而浪費了空間)

  儘管我剛才給你看的是一個人為的例子(還有比直接分配虛擬記憶體更好的方法來分配1-KB的區塊),這中記憶體分配方法驗證了一個重要的不同(對於其他Windows系統)。在桌上出版本的Windows中,工作中的應用程式有一個完全的2-GB的虛擬位址空間。在Windows CE中,一個程式師必須明白每個應用程式只被保留了較小的32-MB虛擬位址空間。

?

?

範例2:

配置64MB虛擬記憶體

VirtualAlloc含式也可以在保留定址空間同時配置記憶體,如果呼叫成功,保留下來的定址空間可以馬上使用。基本上,malloc 含式以這方式在保留定址空間時也配置了實際記憶體。這作法並不適合保留定址空間同時配置記憶體,因此如果程式呼叫
VirtualAlloc(0, 1024 * 1024 * 4, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE); 時所配置4MB的記憶體還是在process所擁有的32MB區域內,要用到 LMA區域的正確作法是 .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; } pVirStart = VirtualAlloc(0, 1024 * 1024 * 64, MEM_RESERVE, PAGE_NOACCESS); ptrMem[0] = VirtualAlloc((PVOID)(pVirStart, 1024 * 1024 * 16, MEM_COMMIT, PAGE_READWRITE); ptrMem[1] = VirtualAlloc((PVOID)(ptrMem[0] + (1024 * 1024 * 16), 1024 * 1024 * 16, MEM_COMMIT, PAGE_READWRITE); ptrMem[2] = VirtualAlloc((PVOID)(ptrMem[1] + (1024 * 1024 * 16), 1024 * 1024 * 16, MEM_COMMIT, PAGE_READWRITE); ptrMem[3] = VirtualAlloc((PVOID)(ptrMem[2] + (1024 * 1024 * 16), 1024 * 1024 * 16, MEM_COMMIT, PAGE_READWRITE);

這樣就可以配置4塊16MB的區域(總共64MB)供程式使用。要注意的是,在配置實際記憶體時要求的大小也有限制,在這個例子中,如果要求一次配置64MB或32MB實際記憶體會失敗(即使定址空間足夠),至於系統一次最大可以要求配置多少實際記憶體,這點還待探索。

VirtualAlloc(0, 1024 * 1024 * 64, MEM_RESERVE | MEM_COMMIT, PAGE_READWRITE); //配置失敗

除了瞭解如何讓配置記憶體超過32MB區域外,VirtualAlloc含式還大有學問,如果你不瞭解清楚就貿然使用,可能會出現一些出乎意料的結果。比如說,我們都清楚記憶體是以page為單位,一個page是4K,因此記憶體最小配置不能小於4K。但4K真的是最小的配置量嗎?如果你配置8K記憶體,系統是否就配置2個page的空間?答案是否定的,系統一次配置記憶體的最小量可以從GetSystemInfo含式取得,GetSystemInfo含式需要傳入一個SYSTEM_INFO變數,這個變數中的dwAllocationGranularity欄位就是系統一次配置的最小量,也就是說,如果 dwAllocationGranularity為64KB,而你要求配置16K記憶體,系統實際上會配置64K記憶體,如果實際有128K記憶體,那你可能會認為只配置32K就沒有記憶體了,實際上是所有記憶體都配置給你囉。。(reference:http://www.wretch.cc/blog/sufan525/6899850)

?

VirtualCopy: (實體位址動態對應至虛擬位址)

[MSDN] http://msdn2.microsoft.com/en-us/library/aa908789.aspx

BOOL VirtualCopy( LPVOID lpvDest, // 要對應至目標的虛擬位址,這個位址必須已保留ReservedLPVOID lpvSrc, // 對應來源的位址,這個位址必須已提交Commit(可以使用的一段實體位址或記憶體)DWORD cbSize, // 要對應區域的大小,以位元組為單位DWORD fdwProtect // 設定存取權限); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

MSDN:This function dynamically maps a virtual address to a physical address by creating a new page-table entry. Terminate the mapping by calling VirtualFree.

PAGE_PHYSICALUsed to map a physical memory region. When using this flag, divide the physical address, that is, lpvSrc, by 256. Memory mapped with PAGE_PHYSICAL is not freed until the device is rebooted. Calling the VirtualFree function does not free this mapped physical memory. This flag is used with dedicated hardware buffers, so it cannot be freed after being mapped.
.csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

雖然以位元組為單位,但是VirtualCopy的操作做小單位是Page.

Remarks WinCE6.0

In CE 6.0 and later, VirtualCopy is a kernel-mode-only function. For information about other kernel-mode only functions, see Kernel Mode APIs.

For CE 6.0, a call to VirtualCopy fails if it crosses a 32-MB section boundary. For example, if you allocate 16 MB and it crosses a 32 MB boundary, you must make two VirtualCopy calls.

WinCE6還有VirtualCopyEX可以使用.

Calling VirtualCopy from user mode work only if it is called from a user-mode driver, where its physical address range is specified in the registry. To port code that calls VirtualAlloc or VirtualCopy, consider doing one of the following, which are in order of preference in terms of security and robustness:

  • Make the code that calls VirtualAlloc or VirtualCopy a driver.
  • Make the code that calls VirtualAlloc or VirtualCopy into a DLL, and use LoadKernelLibrary to load it into kernel.
  • Create a dummy kernel mode driver that implements IOCTL_DO_VIRTUAL_COPY to call VirtualCopy.

Windows CE在ceddk.h中定義了PHYSICAL_ADDRESS,它其實是LARGE_INTEGER類型,其定義如下:
// in ceddk.h
typedef LARGE_INTEGER PHYSICAL_ADDRESS, *PPHYSICAL_ADDRESS;
範圍:--3689348814741910324到+4611686018427387903??

// in winnt.h typedef union _LARGE_INTEGER{ struct{ DWORD LowPart; //4byte=32bit LONG HighPart; //4byte=32bit }; LONGLONG QuadPart; //8byte=64bit } LARGE_INTEGER; .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

56000000 = 是這樣存的
? LowPart??????? HighPart?
00 00 00 56? 00 00 00 00

QuadPart=0x0000000056000000

可見,Windows CE中用64個Bit來代表實體位址,對於大多數32位的CPU而言,只需要把它的HighPart設置為0就可以了。

範例1:

The following code example shows how VirtualCopy is called to map a 128-KB region at physical address 0x64000000.

VirtualCopy(pvDest, (void *) (0x64000000/256), 128*1024, PAGE_READWRITE | PAGE_PHYSICAL | PAGE_NOCACHE); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

?

範例2:

pVMem = (PUCHAR)VirtualAlloc(0, PAGE_SIZE, MEM_RESERVE, PAGE_NOACCESS); if (pVMem) { // map in GPIO registers bMapReturn = VirtualCopy( pVMem, (LPVOID)(S3C2443_BASE_REG_PA_IOPORT>>8), PAGE_SIZE, PAGE_READWRITE | AGE_NOCACHE |PAGE_PHYSICAL); pLED->pIOPReg = (volatile S3C2443_IOPORT_REG*)(pVMem); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

1.S3C2443_BASE_REG_PA_IOPORT使用的實體物理位址,要在第四個參數加上PAGE_PHYSICAL,而且在第二個參數的來源位址要除256(右移8),但是在實作函式DoVirtualCopy裡會在(左移8)移回來

2.VirtualCopy負責把一段實體位址和虛擬位址做對應,所以VirtualAlloc的時候只需要對虛擬記憶體保留,沒有必要提交來實際分配實體記憶體。

3.CEDDK還提供了函數MmMapIoSpace用來把一段物理內存直接映射到虛擬內存。此函數的原形如下:

PVOID MmMapIoSpace( PHYSICAL_ADDRESS PhysicalAddress, // 起始物理地址 ULONG NumberOfBytes, // 要映射的字節數 BOOLEAN CacheEnable // 是否緩存 ); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

其實,MmMapIoSpace函數內部也是使用VirtualAlloc和VirtualCopy來實現實體位址對應到虛擬位址的。MmMapIoSpace函數的原代碼是公開的,我們可以從%_WINCEROOT%/PUBLIC/COMMON/OAK/DRIVERS/CEDDK/DDK_MAP/ddk_map.c得到。

從MmMapIoSpace的定義我們也可以看出VirtualAlloc和VirtualCopy的用法:

PVOID MmMapIoSpace ( IN PHYSICAL_ADDRESS PhysicalAddress, IN ULONG NumberOfBytes, IN BOOLEAN CacheEnable ) { PVOID pVirtualAddress; ULONGLONG SourcePhys; ULONG SourceSize; BOOL bSuccess; SourcePhys = PhysicalAddress.QuadPart & ~(PAGE_SIZE - 1); SourceSize = NumberOfBytes + (PhysicalAddress.LowPart & (PAGE_SIZE - 1)); pVirtualAddress = VirtualAlloc(0, SourceSize, MEM_RESERVE, PAGE_NOACCESS); if (pVirtualAddress != NULL) { bSuccess = VirtualCopy( pVirtualAddress, (PVOID)(SourcePhys >> 8), SourceSize, PAGE_PHYSICAL | PAGE_READWRITE | (CacheEnable ? 0 : PAGE_NOCACHE)); if (bSuccess) { (ULONG)pVirtualAddress += PhysicalAddress.LowPart & (PAGE_SIZE - 1); } else { VirtualFree(pVirtualAddress, 0, MEM_RELEASE); pVirtualAddress = NULL; } } return pVirtualAddress; } .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

此外,Windows CE還供了AllocPhysMem函式和FreePhysMem函式,用來申請和釋放一段連續的實體記憶體。函數可以保證申請的實體記憶體是連續的,如果函式成功執行,會返回虛擬記憶體的代碼和實體記憶體的起始位址。這對於DMA設備非常有用。

?

[MSDN]How To Configure Windows CE for Use With DMA Devices:
http://support.microsoft.com/kb/299355/en-us/

因為WinCE沒有直接支援DMA,在沒有MapVirtualToPhysical API 下,要如何把一段保留的位址對應至32MB的應用程式處理空間(Process),讓ISR可以直接存取它,我們可以使用VirtualAlloc和VirtualCopy函式,首先我們會保留一段實體位址給DMA裝置,然後透過以步驟,即可把實體位址對應至User Mode Process或是Driver Address Spaces.

範例3:

1.In the "MEMORY" section of the Config.bib file, add a "RESERVED" section, as in the following example:

;name hex start address hex size in bytes keyword RESERVED MY_DMA 8003000 00004000 RESERVED .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

我們先必須在Config.bib設定保留一段以後可以DMA的地址,DMA裝置,這個位址是實體位址。

This will reserve a 16-KB contiguous block of memory starting at address 8003000. By definition, any memory reserved with the RESERVED keyword is contiguous.
ISR and kernel mode processes can then directly access this memory, but user mode drivers and applications must use the VirtualAlloc and VirtualCopy commands to map the memory into their address space.
NOTE: From within your ISR, which runs in kernel mode, you can directly reference this memory.

2.From a user mode application or driver you must use code similar to the following sample:

pMem = VirtualAlloc(pStart, dwSize, MEM_RESERVE, PAGE_READWRITE); // pStart is the start of the virtual address range desired. // dwSize is the size in bytes of the region to access. // MEM_RESERVE indicates that the OS should reserve the address space but not back it with physical memory. // pMem will contain the pointer to the virtual memory block if the call is successful or NULL if it fails.<BR/> // now map the RESERVED memory to this address space: LPVOID pSrc = 8003000; // assign source to our RESERVED memory DWORD dwSize = 0x4000; // size of memory; from example bib entry above BOOL bRetCode; bRetCode = VirtualCopy(pStart,pSrc/256, dwSize, PAGE_READWRITE | PAGE PHYSICAL,);// PAGE_PHYSICAL is necessary if pSrc is physical memory with a starting address above 0x1FFFFFFF // When using PAGE_PHYSICAL it is also necessary to divide the source address by 256. // bRetCode is TRUE for success, FALSE for failure.

?

?

?

VirtualFree: (取消提交Decommit或釋放Release虛擬記憶體)

[MSDN] http://msdn.microsoft.com/en-us/library/aa366892(VS.85).aspx

BOOL VirtualFree(LPVOID lpAddress, // 指向要被釋放或取消提交的虛擬記憶體的區域的起始位址DWORD dwSize, //取消提交區域的大小,以位元組為單位。如果區域要被Release,這個值必須是0DWORD dwFreeType //MEM_DECOMMIT標誌指定了區域將被取消提交但是仍被保留,//MEM_RELEASE標誌說明區域要取消提交並且釋放。); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

MSDN:Releases, decommits, or releases and decommits a region of pages within the virtual address space of the calling process.To free memory allocated in another process by the VirtualAllocEx function, use the VirtualFreeEx function.

在區域中的所有的頁通過VirtualFree被釋放必須處在同樣的情況下。更確切地說,區域中的全部頁要被釋放,那這些頁要麼都是被提交的頁,要麼都是被保留的頁。如果有些頁被提交,有些頁被保留,那麼VirtualFree函式呼叫就會失敗。所以要先把提交的先DeCommit 再來一起 Release。( = MEM_DECOMMIT 與 MEM_RELEASE 不能同時使用)

範例:

VirtualFree((PVOID)pLED->pIOPReg, 0, MEM_RELEASE); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

?

VirtualProtect: (變更虛擬記憶體存取權限)
[MSDN]: http://msdn.microsoft.com/en-us/library/aa366898(VS.85).aspx

BOOL VirtualProtect(LPVOID lpAddress, // 指向要被修改虛擬記憶體的區域的起始位址 DWORD dwSize, // 大小DWORD flNewProtect, //設定新的保護標誌。與VirtualAlloc相同。PDWORD lpflOldProtect // 原先虛擬記憶體第一個分頁的保護標誌。設置NULL或錯誤該函式會失敗。); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

?

?

VirtualQuery: (查詢虛擬記憶體存取權限)

[MSDN]: http://msdn.microsoft.com/en-us/library/aa366902(VS.85).aspx

DWORD VirtualQuery(LPCVOID lpAddress, // 開始查詢的位址PMEMORY_BASIC_INFORMATION lPBuffer, //DWORD dwLength, //PMEMORY_BASIC_INFORMATION結構的大小。); .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

?

PMEMORY_BASIC_INFORMATION結構被定義如下: 

 typedef struct _MEMORY_BASIC_INFORMATION {PVOID BaseAddress; //BaseAddress,是傳遞給VirtualQuery函數的一個位址。PVOID AllocationBase;//使用VirtualAlloc函數分配的區域的基底位址DWORD AllocationProtect;//原來,一開始被VirtualAlloc分配時的保護屬性DWORD RegionSize;//傳遞給VirtualQuery的指標開始到一系列具有相同屬性的頁為結尾的區域大小DWORD State;//區域中頁的狀態-自由,保留,提交。DWORD Protect;//MEM_PRIVATE,MEM_MAPPED,MEM_IMAGEDWORD Type;//記憶體的類型} MEMORY_BASIC_INFORMATION;//Protect欄位可以包含MEM_PRIVATE標誌,指明該區域包含應用程式私有的資料; //MEM_MAPPED指明該區域被映射為一個記憶體映射檔; //MEM_IMAGE指明該區域被映射為一個EXE或DLL模組。 .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

範例參考 WindowsCE.NET 程式設計3(Microsoft Press) 7-14頁
 

?

?

其他資料紀錄:

E:/WINCE500/PRIVATE/WINCEOS/COREOS/NK/KERNEL/virtmem.c DoVirtualCopy() ?E:/WINCE500/PRIVATE/WINCEOS/COREOS/NK/KERNEL/virtmem.c #define IsKernelVa(va) (((DWORD)(va) & 0x80000000) && !IsSecureVa(va)) #define PFNfrom256(pg256) ((ulong)(pg256)<<8 & ~(PAGE_SIZE-1)) #define GetPFN(pgpi) ((FirstPT[(ulong)(pgpi)>>20]&0xFFF00000) | ((ulong)(pgpi)&0x000FF000)) ?E:/WINCE500/PRIVATE/WINCEOS/COREOS/NK/INC/mem_arm.h #if (defined(ARMV4) || defined(ARMV4T) || defined(ARMV4I)) // uses 4K page tables #define VA_PAGE 12 #define L2_MASK 0xFF // For a 4K page size (small pages) #define PAGE_SIZE 4096 #elif defined(ARM920) // uses 1K page tables #define VA_PAGE 10 #define L2_MASK 0x3FF #define PAGE_SIZE 1024 #endif ?E:/WINCE500/PRIVATE/WINCEOS/COREOS/NK/INC/nkarm.h #define ArmHigh ((ARM_HIGH *)0xFFFD0000) #define FirstPT (ArmHigh->firstPT) ?typedef struct ARM_HIGH { ulong firstPT[4096]; // 0xFFFD0000: 1st level page table char reserved2[0x20000-0x4000]; ? char exVectors[0x400]; // 0xFFFF0000: exception vectors char reserved3[0x2400-0x400]; ? char intrStack[0x400]; // 0xFFFF2400: interrupt stack char reserved4[0x4900-0x2800]; ? char abortStack[0x700]; // 0xFFFF4900: abort stack char reserved5[0x6800-0x5000]; ? char fiqStack[0x100]; // 0xFFFF6800: FIQ stack char reserved6[0xC000-0x6900]; ? char kStack[0x800]; // 0xFFFFC000: kernel stack struct KDataStruct kdata; // 0xFFFFC800: kernel data page } ARM_HIGH; ? .csharpcode, .csharpcode pre {font-size: small;color: black;font-family: consolas, "Courier New", courier, monospace;background-color: #ffffff;/*white-space: pre;*/ } .csharpcode pre { margin: 0em; } .csharpcode .rem { color: #008000; } .csharpcode .kwrd { color: #0000ff; } .csharpcode .str { color: #006080; } .csharpcode .op { color: #0000c0; } .csharpcode .preproc { color: #cc6633; } .csharpcode .asp { background-color: #ffff00; } .csharpcode .html { color: #800000; } .csharpcode .attr { color: #ff0000; } .csharpcode .alt {background-color: #f4f4f4;width: 100%;margin: 0em; } .csharpcode .lnum { color: #606060; }

----------------------------------------------------------------------------------------------------------------

CE6下還有很多API是AP和user模式的驅動不能使用的,

大家要把CE50下的AP移植到6.0下一定要注意找到替代方案
Virtual Memory APIs
CeVirtualSharedAlloc
LockPages
LockPagesEx
UnlockPages
UnlockPagesEx
VirtualAllocCopyEx
VirtualCopyEx
VirtualSetAttributes
CreateStaticMapping
NKDeleteStaticMapping
VirtualCopy
File System APIs
ReadRegistryFromOEM
SetStoreQueueBase
WriteRegistryToOEM
Power APIs
PowerOffSystem (很多測試AP用到)
Miscellaneous APIs
SetOOMEvent

總結

以上是生活随笔為你收集整理的简单深入两个虚拟内存API VirtualAlloc及VritualCopy的全部內容,希望文章能夠幫你解決所遇到的問題。

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

久久天天操 | 久久avav| 日韩精品91偷拍在线观看 | 中文字幕丝袜一区二区 | 美女精品久久 | 欧美作爱视频 | 成人免费在线电影 | 久久久首页| 精品久久一 | 国产区久久 | 九九热1 | 一区二区三区精品在线视频 | 韩国精品视频在线观看 | 国产不卡av在线 | 人人射网站| 免费a视频| 五月天亚洲综合 | 国产亚洲精品久久久久久移动网络 | 天天干com | 五月天六月婷 | 免费日韩 精品中文字幕视频在线 | 久久免费看视频 | 91看片看淫黄大片 | 91探花国产综合在线精品 | 亚洲专区欧美专区 | 日本特黄特色aaa大片免费 | av片在线看| 婷婷激情5月天 | 久草在线在线视频 | 午夜黄色影院 | 国产精品va在线观看入 | 国产亚洲va综合人人澡精品 | 国内精品国产三级国产aⅴ久 | 婷婷激情网站 | 亚洲视频免费在线观看 | 国产人免费人成免费视频 | 日韩在线视频线视频免费网站 | 91亚州 | 欧美日韩国产mv | 国产在线观看网站 | 91精品无人成人www | 免费在线国产 | 99热在线免费观看 | 亚洲专区在线播放 | 久久草在线精品 | 日韩激情在线视频 | sm免费xx网站| 青青草视频精品 | 91插插插免费视频 | 亚洲成人在线免费 | 六月色丁香 | 国产成人在线免费观看 | 夜夜操狠狠干 | 国产高清日韩欧美 | 日韩视频中文字幕 | 麻豆小视频在线观看 | 国产黄色在线看 | 亚洲在线成人精品 | 超碰av免费| av成人亚洲 | 探花视频在线观看+在线播放 | 精品国产免费人成在线观看 | 五月香婷| 在线最新av | 啪啪动态视频 | 色综合婷婷 | 日韩免费区 | 婷婷丁香九月 | 久久,天天综合 | 成人黄色电影视频 | 亚洲视频在线免费观看 | 黄色小说在线免费观看 | 久草精品视频 | 中文字幕免费久久 | 日韩一级精品 | 久久综合久久综合久久综合 | 国产精品午夜8888 | 免费在线观看国产黄 | 午夜精品视频在线 | 国内丰满少妇猛烈精品播放 | 丝袜美腿在线播放 | 午夜影院三级 | 久操久 | 国产精品久久久久久久免费 | 色综合久久网 | 国产精品久久久久一区二区 | 你操综合 | 精品在线免费视频 | 亚洲一区网站 | 免费三级骚 | 国产精品久久久久久久久费观看 | 中文字幕在线观看91 | 在线观看黄色小视频 | 丁香五婷 | 日韩 国产 | av激情五月| 日韩四虎 | 亚洲资源在线网 | 福利一区视频 | 亚洲精色 | 免费视频99 | 99久久精品无免国产免费 | 国产一级片免费观看 | 欧美日韩高清在线观看 | 久久久久影视 | 国产在线看一区 | 精品国产欧美一区二区三区不卡 | 91桃色在线免费观看 | 久久在线影院 | 夜夜干夜夜 | 国产精品九九九九九九 | 久久天堂精品视频 | 天天综合网~永久入口 | 中文伊人| 激情 婷婷 | 国产成人一区二区三区久久精品 | 日韩欧美亚州 | 国产国语在线 | 91成人在线视频 | 成年人在线观看免费视频 | 成人午夜影院在线观看 | 人人爽人人香蕉 | 天天操天天干天天操天天干 | 欧美在线视频免费 | 国产成在线观看免费视频 | 久久久色 | 最新av免费在线 | 日韩在线视频线视频免费网站 | 日韩av影片在线观看 | 91在线国内视频 | 久久久久久久久爱 | 午夜电影中文字幕 | www.com久久久 | 成片免费| 国产亚洲视频在线观看 | www久久精品 | 久久久三级视频 | 成年人在线 | av免费观看高清 | 天天射天天射天天射 | 91精品在线免费视频 | 激情五月网站 | 日韩电影久久 | 四虎在线视频免费观看 | 国产精品久久久999 国产91九色视频 | 天天操天天操天天操天天操天天操天天操 | 波多野结衣在线中文字幕 | 日韩av高清 | 97超碰人 | 精品国产不卡 | 中文字幕第一页在线 | 手机av网站 | 国产黄色精品在线观看 | 久久国产精品久久精品 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 99视频+国产日韩欧美 | 亚洲人成免费 | av一级黄| 欧美精品亚洲精品日韩精品 | 欧美999 | 欧美中文字幕第一页 | 色吊丝在线永久观看最新版本 | 天天操夜夜逼 | 欧美淫视频 | www色av| 久久免费视频在线观看 | 麻豆视频观看 | 欧美视频网址 | www.五月天激情 | 国产成人av一区二区三区在线观看 | 国产成人精品av在线观 | 日韩久久激情 | 亚洲理论视频 | 999精品在线| 日韩激情三级 | 最新99热 | 免费精品在线观看 | 国产视频手机在线 | 久久尤物电影视频在线观看 | 高清av在线| 91av在线免费| 欧美午夜精品久久久久久浪潮 | 美女久久久久久久 | 国内精品久久久久久久久久清纯 | 99精品一级欧美片免费播放 | 国产色爽 | 中文字幕免费在线 | 97香蕉久久国产在线观看 | 人人干天天干 | 国产精品嫩草影视久久久 | ,久久福利影视 | 在线看国产日韩 | 亚洲a色 | 久久综合九色综合久久久精品综合 | 免费在线观看视频一区 | 日p在线观看 | 欧美巨大荫蒂茸毛毛人妖 | 久久精品99久久久久久2456 | 久久夜色精品国产欧美乱 | 99视频网址 | 亚洲视频久久 | 在线观看免费黄视频 | 在线亚洲午夜片av大片 | 亚洲视频一区二区三区在线观看 | 99精品福利视频 | 天天干.com | 一级α片 | 五月婷社区| 1000部18岁以下禁看视频 | 狠狠操狠狠干天天操 | 久久免费美女视频 | 在线看v片 | 91av蜜桃| 天天色.com| 久久国产精品电影 | 国产精品破处视频 | 久久国产亚洲精品 | 人人人爽 | 欧美男同网站 | 亚洲天堂视频在线 | 成人精品久久久 | 国产又粗又猛又黄视频 | 人人爽人人舔 | 亚洲天堂网站 | 亚洲国产资源 | 日韩久久精品一区二区 | 美女视频一区二区 | www.xxxx变态.com| 日本一区二区不卡高清 | 久久免费视频网站 | www.99av| 西西444www大胆高清视频 | 免费观看日韩av | www日日| 国产精品久久久久久久久久久久 | 久久久精品久久 | 日韩动漫免费观看高清完整版在线观看 | 久久久精品二区 | 日本在线观看一区二区三区 | 五月天电影免费在线观看一区 | 成人av.com| 日韩大片免费在线观看 | 亚洲在线网址 | 波多野结衣资源 | 久久99久久99精品 | 免费色网站 | 麻豆影视在线观看 | 国产精品video爽爽爽爽 | 九九九九热精品免费视频点播观看 | 欧美成人h版 | 五月婷婷在线观看 | 国产精品99久久久精品 | 亚洲国产资源 | 亚州性色 | 五月婷婷在线播放 | 国产精品ssss在线亚洲 | 99久久国产免费,99久久国产免费大片 | 四虎影视精品永久在线观看 | 99久热在线精品 | 久久夜夜夜| 久久九九影视网 | 成人亚洲综合 | 国产日韩欧美综合在线 | 伊人五月天 | 91传媒激情理伦片 | 91精品国产高清 | 久草在线播放视频 | av大全在线免费观看 | 一本一道波多野毛片中文在线 | 最新不卡av| 人人爱人人添 | 亚洲欧美日本一区二区三区 | 日韩精品久久久久久中文字幕8 | 婷婷伊人综合 | 久久久午夜视频 | 99精品在线看 | 久久精品4| 精品国产一区二区三区免费 | 国产精美视频 | 日韩免费三区 | 在线亚洲高清视频 | 欧美午夜性生活 | 九九色在线观看 | 色网免费观看 | 精品久久久久久久久久久久久久久久久久 | 成人国产精品入口 | 国产免费中文字幕 | 久久久福利影院 | 91在线看 | 天堂av官网 | 亚洲美女视频在线观看 | 欧美日韩一区二区在线 | 欧美激情视频一区二区三区 | 久久久久99精品国产片 | 国产美女精品视频 | 国产一区自拍视频 | 又黄又爽又刺激视频 | 亚洲 在线| 亚洲 欧美 国产 va在线影院 | 国产精彩视频一区二区 | 丁香婷婷久久久综合精品国产 | 97超碰人人澡 | 超碰人人舔 | 天天精品视频 | 成年人在线观看免费视频 | 激情五月开心 | 天天干夜夜夜操天 | 午夜一级免费电影 | 中文字幕在线观看第三页 | 日韩在线不卡av | 91最新地址永久入口 | 欧美精品一区二区三区一线天视频 | 五月天婷婷丁香花 | 伊人天堂av | 狠狠狠色狠狠色综合 | 国产精品一二三 | 日韩高清黄色 | 久久久亚洲电影 | 91九色成人 | 亚洲视频在线免费看 | 亚洲一区二区麻豆 | 久久久免费少妇 | 很黄很色很污的网站 | 午夜精品久久久久久久99无限制 | 天天看天天操 | 国产精品视频免费在线观看 | 久久天堂网站 | 亚洲国产一二三 | 日韩在线观看一区二区 | 麻豆视频在线观看免费 | 亚洲精品中文字幕在线观看 | 最新中文字幕在线资源 | 一区二区三区国产欧美 | 精品国产一区二区三区久久久 | 天干啦夜天干天干在线线 | 免费的国产精品 | 国产黑丝袜在线 | 狠狠狠狠狠干 | 国产精品99久久久精品免费观看 | 97人人看 | 国内精品久久久久 | 天天插伊人 | 亚洲视频在线免费观看 | 天天色天天 | 久久精品视频网址 | 91精品国产综合久久婷婷香蕉 | 人人爽久久涩噜噜噜网站 | 久久久国产影院 | 免费在线观看a v | 色av网站| 色婷婷综合久久久久 | 日批视频国产 | 亚洲美女免费精品视频在线观看 | 国产精品久久久久久69 | 蜜臀av性久久久久av蜜臀妖精 | aaa亚洲精品一二三区 | 欧美日韩电影在线播放 | 日韩av资源在线观看 | 国内外成人在线视频 | 91视频免费看片 | 日日爱999| 最新中文字幕在线观看视频 | 亚洲一区日韩 | 99视频精品在线 | 国产无套视频 | 中文字幕日韩国产 | 色婷婷六月 | 在线观看黄网站 | 久草视频在线播放 | 精品黄色在线观看 | 日韩黄色中文字幕 | 午夜精品久久久久久久99 | 天天做天天看 | 在线国产视频观看 | 中文字幕视频在线播放 | 激情在线五月天 | 91精品区 | 久久久这里有精品 | 日日爽日日操 | 久久国产免费视频 | 韩国av电影在线观看 | 深夜激情影院 | 日韩视| 国产日产精品一区二区三区四区 | 亚洲午夜久久久久久久久 | 免费的成人av | 久久久久久久亚洲精品 | 四川妇女搡bbbb搡bbbb搡 | 国产黄色视| 国产在线中文字幕 | 91人网站| 午夜123| 青青看片 | 国产资源在线免费观看 | 91色欧美| 草久久久久久久 | 在线国产视频一区 | 国产精品成人一区二区 | 99精彩视频在线观看免费 | 精品国产一区二区三区四 | se视频网址 | 999电影免费在线观看2020 | 免费网站看av片 | www免费在线观看 | 青春草视频 | 免费电影一区二区三区 | wwwww.国产 | 久草免费手机视频 | 国产一区二区久久久 | 国产一区二区三区在线免费观看 | 免费日韩视频 | 久久久久免费观看 | 国内外成人在线 | 人人澡人人添人人爽一区二区 | 国产精品a久久久久 | 久久久久国产一区二区三区四区 | 四虎精品成人免费网站 | 天天草天天插 | 国产精品一码二码三码在线 | 精品免费久久 | 国产精品美女视频网站 | 五月婷婷丁香网 | 欧美午夜一区二区福利视频 | 最近2019年日本中文免费字幕 | 黄色一级大片免费看 | 欧美日韩性生活 | 特级毛片在线观看 | 日韩性xxx| 91在线国产观看 | 婷婷色在线播放 | 久久综合久色欧美综合狠狠 | 97超碰在线播放 | 精品久久一二三区 | 亚在线播放中文视频 | 9在线观看免费高清完整版在线观看明 | 久操中文字幕在线观看 | 中文字幕在线成人 | 欧美久久久久久久久久久久 | 亚洲精品乱码久久久一二三 | 欧美另类xxxxx | 免费在线播放黄色 | 黄色小视频在线观看免费 | 成人av中文字幕在线观看 | 欧美在线一二区 | 偷拍精偷拍精品欧洲亚洲网站 | av官网在线 | 欧美黄在线 | 成人午夜毛片 | 夜夜干夜夜 | 久久精品永久免费 | 久久免费视频99 | 国产无限资源在线观看 | 国产精品色婷婷视频 | 五月天天天操 | 亚洲国产午夜精品 | 精品美女在线观看 | 亚洲国产精品久久久久 | 最近中文字幕 | 最近免费中文字幕mv在线视频3 | 日韩中文久久 | 欧美一级久久久 | 成年人黄色在线观看 | 黄色福利视频网站 | 国产成人久久 | 天天综合网在线观看 | 久操免费视频 | 在线观看国产区 | 久久国产精品第一页 | 日韩av免费一区二区 | 草久久av | 天天综合天天综合 | 国产一区二区久久精品 | 精品国产一区二区三区久久影院 | 日本中文在线观看 | 国产高清一区二区 | 蜜臀av免费一区二区三区 | 一区免费观看 | 久久精品精品 | 久久国产精品99久久久久久老狼 | 国产在线精品一区二区 | 亚洲资源在线 | 国产精品视频免费观看 | 国产在线无 | 天天综合五月天 | 国产精品热| 六月色丁香 | 在线观看涩涩 | 中文字幕在线观看视频一区二区三区 | 免费高清在线观看电视网站 | 最新真实国产在线视频 | 中文字幕在线电影 | 你操综合 | 日韩中文字幕视频在线 | 久草国产在线观看 | 国产精在线 | 成人免费视频视频在线观看 免费 | 波多野结衣精品 | 国产精品一区二区白浆 | 久久国内免费视频 | 国产99久久精品一区二区永久免费 | 在线观看av大片 | 久久爱导航 | 日韩 在线 | 狠狠狠综合 | 久草在线资源免费 | 少妇性aaaaaaaaa视频 | 免费99精品国产自在在线 | 青青草华人在线视频 | 精品久久五月天 | 亚洲精品美女久久久 | 日日碰狠狠躁久久躁综合网 | 欧美大片在线观看一区 | www.黄色| 欧洲激情在线 | 日韩三级一区 | 在线天堂日本 | 国产精品成人自产拍在线观看 | 国产精品青草综合久久久久99 | 在线成人免费电影 | 涩涩网站在线观看 | 日韩无在线| 天堂在线视频免费观看 | 黄a在线观看 | 99精品一区二区三区 | 国产欧美日韩一区 | 国产精品入口麻豆www | www免费视频com| 中文字幕 在线 一 二 | 欧美国产一区在线 | 99热精品国产一区二区在线观看 | 成人在线播放免费观看 | 天天插综合网 | 大胆欧美gogo免费视频一二区 | 成人欧美一区二区三区在线观看 | 91在线区 | 狠狠色伊人亚洲综合成人 | 日韩精品一区二区三区免费视频观看 | 欧美日韩在线视频观看 | 国产精品乱码久久久久 | 色插综合 | 99久久www免费 | 欧美国产亚洲精品久久久8v | 久久久免费看视频 | 中文字幕一区二区三区在线观看 | 99久久精品免费看国产 | 亚洲人成免费网站 | 97超碰成人| 欧美另类高潮 | 日韩黄色免费电影 | 成人av电影免费观看 | 久久免费精彩视频 | 国产一二区精品 | 人人擦 | 久久三级毛片 | 欧美巨大荫蒂茸毛毛人妖 | 在线岛国av | 在线看片一区 | 激情综合电影网 | 日韩电影中文字幕在线观看 | 一区二区观看 | 亚洲aaa级| 六月色婷 | 国产爽视频 | 日本女人在线观看 | va视频在线 | 国产伦精品一区二区三区无广告 | 日本在线观看一区二区三区 | 日本高清中文字幕有码在线 | 色久综合 | 日日干夜夜草 | 日日碰夜夜爽 | 国产精品白丝av | 国产 日韩 欧美 自拍 | 天天操天天操天天操天天 | 91大神电影 | 操少妇视频 | 99se视频在线观看 | 久久久久成人精品亚洲国产 | 91色一区二区三区 | 91中文字幕网 | av经典在线 | 国产91在线 | 美洲 | 美女网站视频免费黄 | 黄色在线成人 | 久草在线久草在线2 | 97av.com| 国产99久久久久久免费看 | 久久99国产精品自在自在app | 制服丝袜欧美 | 日韩综合一区二区 | 91中文字幕永久在线 | 超碰在线最新 | 日韩中文字幕一区 | 免费久久99精品国产婷婷六月 | 欧美aa一级 | 麻豆视频在线观看免费 | 国际精品久久久 | 最新中文字幕视频 | 亚洲精品福利视频 | 成人黄色在线 | av丁香| 天天看天天干天天操 | 久久精品99精品国产香蕉 | 高清免费在线视频 | 久草综合在线 | 国产在线国产 | 国产精品video爽爽爽爽 | 免费看一及片 | 久草在线免费看视频 | 久久成人麻豆午夜电影 | 在线观看国产v片 | 五月婷在线视频 | 91九色精品 | 欧美日韩在线免费视频 | 亚洲精品乱码久久久久久蜜桃91 | 人人爽人人爽人人爽学生一级 | 91在线免费视频 | 性色大片在线观看 | 欧美视频网址 | 欧美日韩精品在线一区二区 | 国产免费成人av | 夜夜干夜夜 | 日韩免费观看视频 | 最新av在线播放 | 天天艹天天操 | 午夜手机电影 | 五月天.com| 日韩欧美国产成人 | 久久久久久片 | 免费福利视频网 | 婷婷五情天综123 | 国偷自产视频一区二区久 | 精品一区久久 | 免费国产一区二区视频 | 天堂激情网 | 人人射人人澡 | 国产成人福利在线观看 | 91亚洲精品久久久中文字幕 | 久久综合加勒比 | 婷婷久久网站 | 色99导航 | 色一级片| 91看片网址 | 99热999 | 久久精品国产精品亚洲 | 在线观看精品视频 | 国产精品欧美久久久久三级 | 欧美精品亚洲精品 | 色狠狠综合天天综合综合 | 免费v片| 免费日韩 精品中文字幕视频在线 | 91福利国产在线观看 | 综合色久 | 久久99久久久久久 | 奇米网在线观看 | 日韩免费电影网 | 久久最新| 一区二区三区四区在线 | 黄色在线观看污 | 91免费高清观看 | 国产欧美日韩一区 | 91在线日本 | 丁香婷婷激情网 | 黄色国产区 | 四虎国产视频 | 91大神一区二区三区 | 国产九色在线播放九色 | 欧美aa一级| 精品国产精品一区二区夜夜嗨 | 人人爽人人爽人人片av | 日韩一区二区三区在线看 | 69av在线播放 | 97精品国产97久久久久久粉红 | 久久综合导航 | 日韩网站免费观看 | 亚洲国产播放 | av中文字幕亚洲 | 九草视频在线 | 中文字幕免费观看 | 欧美精品一区二区在线播放 | 中文超碰字幕 | 在线а√天堂中文官网 | 国产91av视频在线观看 | 日本中文乱码卡一卡二新区 | 国产精品久久久久9999 | 91精品1区2区| 国产欧美精品一区二区三区 | 成人三级视频 | 精品久久一区二区三区 | 国产中文字幕一区 | 麻豆免费精品视频 | 天天干天天干天天操 | 在线免费视频 你懂得 | a色视频| 国产人成看黄久久久久久久久 | 69精品人人人人 | 日日爽视频 | 成人性生交视频 | 最近最新最好看中文视频 | 久草在线视频国产 | 国产精品视频免费观看 | 人人精久| 免费观看91视频 | 91网址在线| 少妇精69xxtheporn | 久久在线免费观看 | 日韩欧美在线中文字幕 | 欧美精品999 | 日韩精品一区二区三区免费观看视频 | 欧美五月婷婷 | 久久精品精品电影网 | 91桃色在线免费观看 | 日韩精品第1页 | 中文字幕在线观看日本 | 久久精品一区二区三区中文字幕 | 国内小视频 | 97视频在线观看网址 | 在线视频你懂得 | 丁香婷婷基地 | 精品国产伦一区二区三区观看说明 | 黄色电影网站在线观看 | 久久综合久久久久88 | 成人免费在线播放 | 国产亚洲精品久久久久久电影 | 黄网站app在线观看免费视频 | 天天做天天干 | 亚州成人av在线 | www.国产毛片 | 激情久久婷婷 | 久久精品爱爱视频 | 国产高清视频色在线www | 久久免费看av| 国产精品久久99精品毛片三a | 欧美一性一交一乱 | 国产一区二区久久精品 | 最新成人在线 | 黄污网站在线 | 亚洲精品免费在线观看视频 | 国产理论片在线观看 | 狠狠干中文字幕 | 国产成人免费av电影 | 特黄特色特刺激视频免费播放 | 色91在线视频 | 玖玖色在线观看 | 91大神在线观看视频 | 精品福利视频在线 | 在线免费高清 | 中文字幕资源在线 | 黄色片网站免费 | 99精品国产视频 | 日韩免费一区 | 久久精品—区二区三区 | 日韩欧美视频一区 | 玖玖玖在线观看 | 91av短视频 | 在线精品亚洲一区二区 | 香蕉视频在线免费看 | 亚洲精品成人av在线 | 午夜私人影院久久久久 | 成人免费观看网址 | 日韩一区二区久久 | 亚洲成人动漫在线观看 | 超碰夜夜 | 97超碰人人澡人人爱学生 | 久久国产精品二国产精品中国洋人 | 六月丁香婷 | 免费亚洲黄色 | 欧美日韩免费观看一区二区三区 | 不卡的av电影在线观看 | 欧美在线观看视频一区二区 | 日韩av中文在线观看 | 日韩久久精品一区二区三区下载 | 久久精品婷婷 | 成人久久久久久久久久 | 五月婷婷影院 | 日韩91在线 | 91热视频在线观看 | 91av视频网站 | 国产香蕉97碰碰碰视频在线观看 | 亚洲精品国产成人 | 国产精品日韩高清 | 国产一区二区播放 | 久久综合久久综合这里只有精品 | 成人一区二区三区在线 | 欧美日韩国产一区二区在线观看 | 中文字幕第一页在线播放 | 国产精品手机在线播放 | 手机av电影在线观看 | 欧美动漫一区二区三区 | 久久久网页 | 免费观看版 | 成人免费观看完整版电影 | 在线精品播放 | 久久久精品视频成人 | 在线观看免费一级片 | 中文字幕亚洲在线观看 | 在线观看黄色大片 | 91香蕉视频黄色 | 国产精品国产三级国产 | 综合色站 | 欧美久草网 | 国产成人三级 | 亚洲国产午夜视频 | 免费看的黄网站 | 在线黄网站 | 亚洲在线视频观看 | 国产欧美精品一区二区三区四区 | 亚洲成人网在线 | 国产亚洲视频在线观看 | 香蕉精品视频在线观看 | 九九在线国产视频 | 天天狠狠干 | 中文字幕在线观看免费高清完整版 | 五月香婷 | 亚洲影音先锋 | 亚州精品在线视频 | 国产老太婆免费交性大片 | 成人av中文字幕 | 亚洲综合在线五月 | 久草影视在线观看 | 91完整版 | 国产免码va在线观看免费 | 日本精品一区二区在线观看 | 黄色1级毛片 | 在线日韩 | 91 中文字幕 | 久久久国产精品一区二区中文 | 久久久免费毛片 | 日韩成人精品 | 91av成人| 96久久久| 黄色三级网站 | 91在线看视频免费 | 欧洲性视频 | 高清国产一区 | 日日天天av| 久热只有精品 | 97免费视频在线 | 亚洲激情国产精品 | 精品在线观看免费 | 日日弄天天弄美女bbbb | 毛片视频网址 | 男女激情免费网站 | 综合网天天色 | 成人一级在线观看 | 亚洲高清视频一区二区三区 | 欧美孕妇与黑人孕交 | 亚洲精品网页 | 五月天电影免费在线观看一区 | 亚洲天堂精品视频在线观看 | 欧美黄色高清 | 激情电影影院 | 91亚洲夫妻| 日韩一区二区免费播放 | 欧美日韩在线观看视频 | 在线高清av | 在线观看视频你懂 | 亚洲视频播放 | 精品1区二区 | 精品国产伦一区二区三区免费 | 91成人精品国产刺激国语对白 | 免费成人av在线 | 国产成人中文字幕 | 亚洲精品综合一区二区 | 国产一区二区观看 | 99精品国产免费久久久久久下载 | 国产精品18久久久久久首页狼 | 天天操天天爽天天干 | 国产视频一区二区在线 | 日韩中文在线视频 | 国产日韩一区在线 | 最新精品视频在线 | 久久不卡免费视频 | 日韩精品免费一线在线观看 | 欧美激情第一页xxx 午夜性福利 | 国产一级片一区二区三区 | 亚洲精选在线观看 | 女人18精品一区二区三区 | aaa毛片视频 | 色综合国产 | 中文字幕在线观看三区 | 成人av在线影院 | 国产手机在线精品 | 99久热 | 免费成人av在线看 | 91视频在线免费 | 亚洲欧美少妇 | 麻豆影视在线免费观看 | 黄色avwww | 久久久高清一区二区三区 | 国产一级视频在线免费观看 | 最近最新mv字幕免费观看 | 999久久a精品合区久久久 | 91视频3p| 青草草在线视频 | 免费成人在线电影 | 国产成人精品免费在线观看 | 久久久久久久久毛片 | 成人av电影在线观看 | 在线视频日韩欧美 | 成人在线免费观看网站 | 国内久久视频 | 亚洲一一在线 | 色婷婷精品 | 在线观看成人国产 | 日韩视频免费在线 | 精品乱码一区二区三四区 | aⅴ精品av导航 | 蜜臀久久99静品久久久久久 | 免费av大全 | 一本色道久久综合亚洲二区三区 | 一级理论片在线观看 | 日本精品在线 | 狠狠狠色丁香婷婷综合久久五月 | 麻豆国产网站入口 | 天天干,夜夜爽 | 国产精品自拍av | 中文字幕影片免费在线观看 | 涩涩网站在线看 | 欧美日韩另类在线观看 | 国产在线观看免费 | 中文字幕网站 | 2019中文最近的2019中文在线 | 日韩av播放在线 | 国产精品久久久久久久久久尿 | 欧美一区二区三区免费观看 | 免费在线观看日韩欧美 | 西西大胆免费视频 | 久久久久久中文字幕 | 97成人精品视频在线观看 | 色www.| 狠狠干综合 | 一区二区三区www | 国产视频综合在线 | 亚洲精品色 | 天天久久综合 | 91在线免费播放 | 精品国产1区2区3区 国产欧美精品在线观看 | 国产视频一 | www.伊人网.com| 亚洲麻豆精品 | 天天躁日日躁狠狠躁av中文 | 狠狠色丁香婷综合久久 | 波多野结衣小视频 | 久久国产精品99久久人人澡 | 欧美国产不卡 | 午夜精品福利一区二区 | 99久久精品免费看国产四区 | 热久久视久久精品18亚洲精品 | 久久嗨| 久久99精品波多结衣一区 | www.夜夜骑.com| 91网页版免费观看 | 91精品国产自产91精品 | 国产亚洲成人网 | 国产成人精品国内自产拍免费看 | 久久久精品国产免费观看一区二区 | 免费色视频| 免费三级a| av一级久久 | 欧美综合在线视频 | 一区二区精品久久 | 日韩理论片在线观看 | 精品毛片一区二区免费看 | 亚洲精品自拍 | 日韩精品在线观看视频 | 深夜精品福利 | 人人看97 | www国产亚洲精品 | 久久永久免费 | 成人app在线播放 | 日本精品一| 国产一区二区三区免费在线 | 欧美日韩不卡一区二区三区 | 色a4yy| 中文字幕色在线 | 亚洲精品www.| 中文字幕视频观看 | 日韩激情小视频 | 黄色毛片在线看 | 国产精品99久久免费观看 | 五月婷香蕉久色在线看 | 人人藻人人澡人人爽 | av在线看片 | 国产不卡一 | 久久国产精品成人免费浪潮 | 岛国av在线 | 亚洲 欧美 日韩 综合 | 日本中文字幕网址 | 国产性天天综合网 | 激情影音先锋 | 天天摸天天干天天操天天射 | 亚洲毛片在线观看. | 精品一区二区免费视频 | 国产va精品免费观看 | 亚洲91在线| 天天干人人 | 国产黄色片网站 |