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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

FreeRTOS--堆内存管理(二)

發(fā)布時(shí)間:2023/12/1 编程问答 53 豆豆
生活随笔 收集整理的這篇文章主要介紹了 FreeRTOS--堆内存管理(二) 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

堆內(nèi)存管理代碼具體實(shí)現(xiàn)

  • heap_1
    • 內(nèi)存申請函數(shù)
    • 內(nèi)存釋放函數(shù)
  • heap_2
    • 內(nèi)存塊
    • 內(nèi)存堆初始化函數(shù)
    • 內(nèi)存塊插入函數(shù)
    • 內(nèi)存申請函數(shù)
      • 判斷是不是第一次申請內(nèi)存
      • 開始分配內(nèi)存
      • 內(nèi)存釋放函數(shù)
  • heap_3
  • heap_4
    • 內(nèi)存堆初始化函數(shù)
    • 內(nèi)存塊插入函數(shù)
  • heap_5

上一篇文章說了FreeRTOS實(shí)現(xiàn)堆內(nèi)存的原理,這一篇文章說一下常用函數(shù)的代碼的具體實(shí)現(xiàn)。

heap_1

heap_1的內(nèi)存堆為ucHeap[],大小為configTOTAL_HEAP_SIZE

內(nèi)存申請函數(shù)

heap_1的內(nèi)存申請函數(shù)pvPortMalloc()源碼如下:

/*-----------------------------------------------------------*/void * pvPortMalloc( size_t xWantedSize ) {void * pvReturn = NULL;static uint8_t * pucAlignedHeap = NULL;/* Ensure that blocks are always aligned. */#if ( portBYTE_ALIGNMENT != 1 ){if( xWantedSize & portBYTE_ALIGNMENT_MASK ){/* Byte alignment required. Check for overflow. */if ( (xWantedSize + ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) )) > xWantedSize ){xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );}else{xWantedSize = 0;}}}#endifvTaskSuspendAll();{if( pucAlignedHeap == NULL ){/* Ensure the heap starts on a correctly aligned boundary. */pucAlignedHeap = ( uint8_t * ) ( ( ( portPOINTER_SIZE_TYPE ) & ucHeap[ portBYTE_ALIGNMENT - 1 ] ) & ( ~( ( portPOINTER_SIZE_TYPE ) portBYTE_ALIGNMENT_MASK ) ) );}/* Check there is enough room left for the allocation and. */if( ( xWantedSize > 0 ) && /* valid size */( ( xNextFreeByte + xWantedSize ) < configADJUSTED_HEAP_SIZE ) &&( ( xNextFreeByte + xWantedSize ) > xNextFreeByte ) ) /* Check for overflow. */{/* Return the next free byte then increment the index past this* block. */pvReturn = pucAlignedHeap + xNextFreeByte;xNextFreeByte += xWantedSize;}traceMALLOC( pvReturn, xWantedSize );}( void ) xTaskResumeAll();#if ( configUSE_MALLOC_FAILED_HOOK == 1 ){if( pvReturn == NULL ){extern void vApplicationMallocFailedHook( void );vApplicationMallocFailedHook();}}#endifreturn pvReturn; } /*-----------------------------------------------------------*/

下面的代碼塊是判斷內(nèi)存塊是否對齊

void * pvPortMalloc( size_t xWantedSize ) {void * pvReturn = NULL;static uint8_t * pucAlignedHeap = NULL;/* Ensure that blocks are always aligned. */#if ( portBYTE_ALIGNMENT != 1 ){if( xWantedSize & portBYTE_ALIGNMENT_MASK ) /***** 令 length = portBYTE_ALIGNMENT_MASK二進(jìn)制中1的個(gè)數(shù)* x = xWantedSize的后length位的值* y = portBYTE_ALIGNMENT_MASK-x+1* 如果 xWantedSize & portBYTE_ALIGNMENT_MASK = 0,則xWantedSize肯定是(portBYTE_ALIGNMENT_MASK+1)的整數(shù)倍* 如果 xWantedSize & portBYTE_ALIGNMENT_MASK不為0,則xWantedSize的后length位肯定有1,xWantedSize不是portBYTE_ALIGNMENT_MASK的整數(shù)倍* 如果 xWantedSize + ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) )大于xWantedSize,說明后length位肯定有1* xWantedSize = xWantedSize + y,xWantedSize變成portBYTE_ALIGNMENT整數(shù)倍******/{/* Byte alignment required. Check for overflow. */if ( (xWantedSize + ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) )) > xWantedSize ){xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );}else{xWantedSize = 0;}}}#endif

#if ( portBYTE_ALIGNMENT != 1 )是判斷是否進(jìn)行字節(jié)對齊,portBYTE_ALIGNMENT默認(rèn)為8:

#if portBYTE_ALIGNMENT == 32#define portBYTE_ALIGNMENT_MASK ( 0x001f ) #elif portBYTE_ALIGNMENT == 16#define portBYTE_ALIGNMENT_MASK ( 0x000f ) #elif portBYTE_ALIGNMENT == 8#define portBYTE_ALIGNMENT_MASK ( 0x0007 ) #elif portBYTE_ALIGNMENT == 4#define portBYTE_ALIGNMENT_MASK ( 0x0003 ) #elif portBYTE_ALIGNMENT == 2#define portBYTE_ALIGNMENT_MASK ( 0x0001 ) #elif portBYTE_ALIGNMENT == 1#define portBYTE_ALIGNMENT_MASK ( 0x0000 ) #else /* if portBYTE_ALIGNMENT == 32 */#error "Invalid portBYTE_ALIGNMENT definition"

因?yàn)閜ortBYTE_ALIGNMENT 定義為8,所以portBYTE_ALIGNMENT_MASK 定義為0x0007,xWantedSize 是無符號整數(shù)類型(unsigned int),即32位,xWantedSize 與宏portBYTE_ALIGNMENT_MASK 進(jìn)行與運(yùn)算來判斷xWantedSize是否為portBYTE_ALIGNMENT 的整數(shù)倍,如果等于0就說明xWantedSizr是portBYTE_ALIGNMENT 的整數(shù)倍,否則的話將xWantedSize加上一個(gè)值,讓xWantedSize 變成portBYTE_ALIGNMENT 的整數(shù)倍。具體可以看一下代碼,我加了注釋。
調(diào)用vTaskSuspendAll()掛起任務(wù)調(diào)度器,因?yàn)樯暾垉?nèi)存過程中要做保護(hù),不能被其他任務(wù)打斷。

pucAlignedHeap是一個(gè)靜態(tài)變量,下面這個(gè)代碼是初試化pucAlignedHeap,pucAlignedHeap指向ucHeap[ portBYTE_ALIGNMENT - 1 ]

if( pucAlignedHeap == NULL ){/* Ensure the heap starts on a correctly aligned boundary. *//**** 初始化pucAlignedHeap,pucAlignedHeap指向ucHeap[ portBYTE_ALIGNMENT - 1 ]**/pucAlignedHeap = ( uint8_t * ) ( ( ( portPOINTER_SIZE_TYPE ) & ucHeap[ portBYTE_ALIGNMENT - 1 ] ) & ( ~( ( portPOINTER_SIZE_TYPE ) portBYTE_ALIGNMENT_MASK ) ) );}

接下來就是分配內(nèi)存了,最后返回pvReturn,是分配內(nèi)存的首地址,其中xNextFreeByte是靜態(tài)變量,表示堆ucHeap已經(jīng)用了多少內(nèi)存,configADJUSTED_HEAP_SIZE= configTOTAL_HEAP_SIZE - portBYTE_ALIGNMENT,是可以用的內(nèi)存容量。還有如果剩余內(nèi)存小于portBYTE_ALIGNMENT,也是不會創(chuàng)建成功的,也就說是,最后的堆可能有內(nèi)存碎片,下面也一樣。

內(nèi)存釋放函數(shù)

void vPortInitialiseBlocks( void ) {/* Only required when static memory is not cleared. */xNextFreeByte = ( size_t ) 0; }

可以看出vPortFree并沒有具體釋放內(nèi)存的過程,因此如果使用heap_1,一旦申請內(nèi)存成功就不允許釋放。

heap_2

heap_2的內(nèi)存堆為ucHeap[],大小為configTOTAL_HEAP_SIZE

內(nèi)存塊

為了實(shí)現(xiàn)內(nèi)存釋放,heap_2引入內(nèi)存塊的概念,每分出去的一段內(nèi)存就是內(nèi)存塊,為了管理內(nèi)存塊,引入了一個(gè)鏈表結(jié)構(gòu),此鏈表是來連接空閑塊的,鏈表中的空閑塊順序是根據(jù)空閑塊內(nèi)存的大小排列,鏈表結(jié)構(gòu)如下:

/* Define the linked list structure. This is used to link free blocks in order* of their size. */ typedef struct A_BLOCK_LINK {struct A_BLOCK_LINK * pxNextFreeBlock; /*<< The next free block in the list. */size_t xBlockSize; /*<< The size of the free block. */ } BlockLink_t;

為了管理該列表,FreeRTOS定義兩個(gè)靜態(tài)變量,xStart、xEnd分別指向鏈表的頭和尾:

/* Create a couple of list links to mark the start and end of the list. */ static BlockLink_t xStart, xEnd;

內(nèi)存堆初始化函數(shù)

內(nèi)存堆初始化函數(shù)為pvHeapInit()

static void prvHeapInit( void ) {BlockLink_t * pxFirstFreeBlock;uint8_t * pucAlignedHeap;/* Ensure the heap starts on a correctly aligned boundary. */pucAlignedHeap = ( uint8_t * ) ( ( ( portPOINTER_SIZE_TYPE ) & ucHeap[ portBYTE_ALIGNMENT - 1 ] ) & ( ~( ( portPOINTER_SIZE_TYPE ) portBYTE_ALIGNMENT_MASK ) ) );/* xStart is used to hold a pointer to the first item in the list of free* blocks. The void cast is used to prevent compiler warnings. */xStart.pxNextFreeBlock = ( void * ) pucAlignedHeap;xStart.xBlockSize = ( size_t ) 0;/* xEnd is used to mark the end of the list of free blocks. */xEnd.xBlockSize = configADJUSTED_HEAP_SIZE;xEnd.pxNextFreeBlock = NULL;/* To start with there is a single free block that is sized to take up the* entire heap space. */pxFirstFreeBlock = ( void * ) pucAlignedHeap;pxFirstFreeBlock->xBlockSize = configADJUSTED_HEAP_SIZE;pxFirstFreeBlock->pxNextFreeBlock = &xEnd; }

同heap_1一樣,pucAlignedHeap指向ucHeap[ portBYTE_ALIGNMENT - 1 ],xStart.pxNextFreeBlock指向pucAlignedHeap ,內(nèi)存塊大小為0,xEnd指向的內(nèi)存塊大小為configADJUSTED_HEAP_SIZE,pxNextFreeBlock 的值為NULL,第一個(gè)內(nèi)存塊pxFirstFreeBlock 指向pucAlignedHeap,大小為configADJUSTED_HEAP_SIZE,pxNextFreeBlock 指向xEnd。

內(nèi)存塊插入函數(shù)

#define prvInsertBlockIntoFreeList( pxBlockToInsert ) \{ \BlockLink_t * pxIterator; \size_t xBlockSize; \\xBlockSize = pxBlockToInsert->xBlockSize; \\/* Iterate through the list until a block is found that has a larger size */ \/* than the block we are inserting. */ \for( pxIterator = &xStart; pxIterator->pxNextFreeBlock->xBlockSize < xBlockSize; pxIterator = pxIterator->pxNextFreeBlock ) \{ \/* There is nothing to do here - just iterate to the correct position. */ \} \\/* Update the list to include the block being inserted in the correct */ \/* position. */ \pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock; \pxIterator->pxNextFreeBlock = pxBlockToInsert; \}

就是在一個(gè)排好序的鏈表中插入一個(gè)數(shù)據(jù),xStart最小,for循環(huán)一直找到鏈表中空閑內(nèi)存塊大于pxBlockToInsert內(nèi)存塊大小的內(nèi)存塊,然后插入進(jìn)去

內(nèi)存申請函數(shù)

void * pvPortMalloc( size_t xWantedSize ) {BlockLink_t * pxBlock, * pxPreviousBlock, * pxNewBlockLink;static BaseType_t xHeapHasBeenInitialised = pdFALSE;void * pvReturn = NULL;vTaskSuspendAll();{/* If this is the first call to malloc then the heap will require* initialisation to setup the list of free blocks. */if( xHeapHasBeenInitialised == pdFALSE ){prvHeapInit();xHeapHasBeenInitialised = pdTRUE;}/* The wanted size must be increased so it can contain a BlockLink_t* structure in addition to the requested amount of bytes. */if( ( xWantedSize > 0 ) &&( ( xWantedSize + heapSTRUCT_SIZE ) > xWantedSize ) ) /* Overflow check */{xWantedSize += heapSTRUCT_SIZE;/* Byte alignment required. Check for overflow. */if( ( xWantedSize + ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) ) )> xWantedSize ){xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );configASSERT( ( xWantedSize & portBYTE_ALIGNMENT_MASK ) == 0 );}else{xWantedSize = 0;}}else{xWantedSize = 0;}if( ( xWantedSize > 0 ) && ( xWantedSize <= xFreeBytesRemaining ) ){/* Blocks are stored in byte order - traverse the list from the start* (smallest) block until one of adequate size is found. */pxPreviousBlock = &xStart;pxBlock = xStart.pxNextFreeBlock;while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) ){pxPreviousBlock = pxBlock;pxBlock = pxBlock->pxNextFreeBlock;}/* If we found the end marker then a block of adequate size was not found. */if( pxBlock != &xEnd ){/* Return the memory space - jumping over the BlockLink_t structure* at its start. */pvReturn = ( void * ) ( ( ( uint8_t * ) pxPreviousBlock->pxNextFreeBlock ) + heapSTRUCT_SIZE );/* This block is being returned for use so must be taken out of the* list of free blocks. */pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock;/* If the block is larger than required it can be split into two. */if( ( pxBlock->xBlockSize - xWantedSize ) > heapMINIMUM_BLOCK_SIZE ){/* This block is to be split into two. Create a new block* following the number of bytes requested. The void cast is* used to prevent byte alignment warnings from the compiler. */pxNewBlockLink = ( void * ) ( ( ( uint8_t * ) pxBlock ) + xWantedSize );/* Calculate the sizes of two blocks split from the single* block. */pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;pxBlock->xBlockSize = xWantedSize;/* Insert the new block into the list of free blocks. */prvInsertBlockIntoFreeList( ( pxNewBlockLink ) );}xFreeBytesRemaining -= pxBlock->xBlockSize;}}traceMALLOC( pvReturn, xWantedSize );}( void ) xTaskResumeAll();#if ( configUSE_MALLOC_FAILED_HOOK == 1 ){if( pvReturn == NULL ){extern void vApplicationMallocFailedHook( void );vApplicationMallocFailedHook();}}#endifreturn pvReturn; }

判斷是不是第一次申請內(nèi)存

xHeapHasBeenInitialised是一個(gè)靜態(tài)變量,初始值為pdFALSE,根據(jù)xHeapHasBeenInitialised判斷是不是第一個(gè)調(diào)用pvPortMalloc,如果是,即xHeapHasBeenInitialised=pdFALSE,則調(diào)用初始化函數(shù)prvHeapInit(),然后將xHeapHasBeenInitialised設(shè)置為pdTRRE。

開始分配內(nèi)存

判斷xWantedSize是否大于0,不是的話則xWantedSize=0。在大于0 的情況下,xWantedSize要加上heapSTRUCT_SIZE,heapSTRUCT_SIZE是一個(gè)static const類型,值為8,是為了來存儲一個(gè)BlockLink_t結(jié)構(gòu),同樣分配的內(nèi)存大小也必須是portBYTE_ALIGNMENT的整數(shù)倍。

if( ( xWantedSize > 0 ) &&( ( xWantedSize + heapSTRUCT_SIZE ) > xWantedSize ) ) /* Overflow check */{xWantedSize += heapSTRUCT_SIZE;/* Byte alignment required. Check for overflow. */if( ( xWantedSize + ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) ) )> xWantedSize ){xWantedSize += ( portBYTE_ALIGNMENT - ( xWantedSize & portBYTE_ALIGNMENT_MASK ) );configASSERT( ( xWantedSize & portBYTE_ALIGNMENT_MASK ) == 0 );}else{xWantedSize = 0;}}

如果xWantedSize>0并且xWantedSize要小于xFreeBytesRemaining,xFreeBytesRemaining是一個(gè)靜態(tài)類型變量,表示剩下的可用字節(jié)數(shù)(所有空閑塊大小之和)。
接著按照空閑塊大小,從小到大,依次遍歷,直到找到一個(gè)空閑塊,其大小大于等于xWantedSize(此時(shí)的xWantedSize=一開始請求的xWantedSize+sizeof(BlockLink_t)),找到滿足所需內(nèi)存塊pxBlock,pxPreviousBlock的pxPreviousBlock就指向pxBlock,如果pxBlock不是指向xEnd,就分配內(nèi)存,pvReturn指向 (pxPreviousBlock->pxNextFreeBlock ) + xHeapStructSize的地址,跳過了BlockLink_t,如果pxBlock剩余的內(nèi)存大于secureheapMINIMUM_BLOCK_SIZE,則將剩余的內(nèi)存設(shè)置成一個(gè)新的空閑內(nèi)存塊,新的空閑內(nèi)存塊用 pxNewBlockLink 表示,pxNewBlockLink指向新的內(nèi)存塊的首地址,接著調(diào)用prvInsertBlockIntoFreeList,將pxNewBlockLink插入到空閑鏈表中。

if( ( xWantedSize & xBlockAllocatedBit ) == 0 ){/* The wanted size is increased so it can contain a BlockLink_t* structure in addition to the requested amount of bytes. */if( xWantedSize > 0 ){xWantedSize += xHeapStructSize;/* Ensure that blocks are always aligned to the required number of* bytes. */if( ( xWantedSize & secureportBYTE_ALIGNMENT_MASK ) != 0x00 ){/* Byte alignment required. */xWantedSize += ( secureportBYTE_ALIGNMENT - ( xWantedSize & secureportBYTE_ALIGNMENT_MASK ) );secureportASSERT( ( xWantedSize & secureportBYTE_ALIGNMENT_MASK ) == 0 );}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}if( ( xWantedSize > 0 ) && ( xWantedSize <= xFreeBytesRemaining ) ){/* Traverse the list from the start (lowest address) block until* one of adequate size is found. */pxPreviousBlock = &xStart;pxBlock = xStart.pxNextFreeBlock;while( ( pxBlock->xBlockSize < xWantedSize ) && ( pxBlock->pxNextFreeBlock != NULL ) ){pxPreviousBlock = pxBlock;pxBlock = pxBlock->pxNextFreeBlock;}/* If the end marker was reached then a block of adequate size was* not found. */if( pxBlock != pxEnd ){/* Return the memory space pointed to - jumping over the* BlockLink_t structure at its start. */pvReturn = ( void * ) ( ( ( uint8_t * ) pxPreviousBlock->pxNextFreeBlock ) + xHeapStructSize );/* This block is being returned for use so must be taken out* of the list of free blocks. */pxPreviousBlock->pxNextFreeBlock = pxBlock->pxNextFreeBlock;/* If the block is larger than required it can be split into* two. */if( ( pxBlock->xBlockSize - xWantedSize ) > secureheapMINIMUM_BLOCK_SIZE ){/* This block is to be split into two. Create a new* block following the number of bytes requested. The void* cast is used to prevent byte alignment warnings from the* compiler. */pxNewBlockLink = ( void * ) ( ( ( uint8_t * ) pxBlock ) + xWantedSize );secureportASSERT( ( ( ( size_t ) pxNewBlockLink ) & secureportBYTE_ALIGNMENT_MASK ) == 0 );/* Calculate the sizes of two blocks split from the single* block. */pxNewBlockLink->xBlockSize = pxBlock->xBlockSize - xWantedSize;pxBlock->xBlockSize = xWantedSize;/* Insert the new block into the list of free blocks. */prvInsertBlockIntoFreeList( pxNewBlockLink );}

接著更新xFreeBytesRemaining,xBlockSize=請求的xWantedSize+sizeof(BlockLink_t)

xFreeBytesRemaining -= pxBlock->xBlockSize;

最后如果使用hook函數(shù),就調(diào)用vApplicationMallocFailedHook()

內(nèi)存釋放函數(shù)

void vPortFree( void * pv ) {uint8_t * puc = ( uint8_t * ) pv;BlockLink_t * pxLink;if( pv != NULL ){/* The memory being freed will have an BlockLink_t structure immediately* before it. */puc -= heapSTRUCT_SIZE;/* This unexpected casting is to keep some compilers from issuing* byte alignment warnings. */pxLink = ( void * ) puc;vTaskSuspendAll();{/* Add this block to the list of free blocks. */prvInsertBlockIntoFreeList( ( ( BlockLink_t * ) pxLink ) );xFreeBytesRemaining += pxLink->xBlockSize;traceFREE( pv, pxLink->xBlockSize );}( void ) xTaskResumeAll();} }

puc為要釋放的內(nèi)存首地址,這就是申請內(nèi)存返回的pvReturn所指向的地址,所以必須減去heapSTRUCT_SIZE才是要釋放的內(nèi)存段所在內(nèi)存塊的首地址。pxLink 指向真正的釋放的內(nèi)存首地址,將pxLink插入到空閑塊鏈表中,更新xFreeBytesRemaining 。

heap_3

這個(gè)分配方法是對標(biāo)準(zhǔn)C庫中的mallco和free函數(shù)簡單封裝,FreeRTOS對這兩個(gè)函數(shù)做了線程保護(hù),不分析了。

heap_4

heap_4提供了最優(yōu)的匹配算法,并且會將碎片合并成一個(gè)大的可用內(nèi)存塊,它提供了內(nèi)存塊合并算法

內(nèi)存堆初始化函數(shù)

static void prvHeapInit( void ) /* PRIVILEGED_FUNCTION */ {BlockLink_t * pxFirstFreeBlock;uint8_t * pucAlignedHeap;size_t uxAddress;size_t xTotalHeapSize = configTOTAL_HEAP_SIZE;/* Ensure the heap starts on a correctly aligned boundary. */uxAddress = ( size_t ) ucHeap;if( ( uxAddress & portBYTE_ALIGNMENT_MASK ) != 0 ){uxAddress += ( portBYTE_ALIGNMENT - 1 );uxAddress &= ~( ( size_t ) portBYTE_ALIGNMENT_MASK );xTotalHeapSize -= uxAddress - ( size_t ) ucHeap;}pucAlignedHeap = ( uint8_t * ) uxAddress;/* xStart is used to hold a pointer to the first item in the list of free* blocks. The void cast is used to prevent compiler warnings. */xStart.pxNextFreeBlock = ( void * ) pucAlignedHeap;xStart.xBlockSize = ( size_t ) 0;/* pxEnd is used to mark the end of the list of free blocks and is inserted* at the end of the heap space. */uxAddress = ( ( size_t ) pucAlignedHeap ) + xTotalHeapSize;uxAddress -= xHeapStructSize;uxAddress &= ~( ( size_t ) portBYTE_ALIGNMENT_MASK );pxEnd = ( void * ) uxAddress;pxEnd->xBlockSize = 0;pxEnd->pxNextFreeBlock = NULL;/* To start with there is a single free block that is sized to take up the* entire heap space, minus the space taken by pxEnd. */pxFirstFreeBlock = ( void * ) pucAlignedHeap;pxFirstFreeBlock->xBlockSize = uxAddress - ( size_t ) pxFirstFreeBlock;pxFirstFreeBlock->pxNextFreeBlock = pxEnd;/* Only one block exists - and it covers the entire usable heap space. */xMinimumEverFreeBytesRemaining = pxFirstFreeBlock->xBlockSize;xFreeBytesRemaining = pxFirstFreeBlock->xBlockSize;/* Work out the position of the top bit in a size_t variable. */xBlockAllocatedBit = ( ( size_t ) 1 ) << ( ( sizeof( size_t ) * heapBITS_PER_BYTE ) - 1 ); }

首先對申請的內(nèi)存做字節(jié)對齊處理,pucAlignedHeap 為內(nèi)存堆字節(jié)對齊以后的可用起始地址,初始化xStart、pxEnd,同heap_2一樣,內(nèi)存塊前面會有一個(gè)BlockLink_t類型的變量來描述內(nèi)存塊,這里是完成pxFirstFreeBlock 的初始化,xMinimumEverFreeBytesRemaining 記錄最小的空閑內(nèi)存塊大小,xFreeBytesRemaining 表示內(nèi)存堆剩余大小,初始化靜態(tài)變量xBlockAllocatedBit

內(nèi)存塊插入函數(shù)

static void prvInsertBlockIntoFreeList( BlockLink_t * pxBlockToInsert ) /* PRIVILEGED_FUNCTION */ {BlockLink_t * pxIterator;uint8_t * puc;/* Iterate through the list until a block is found that has a higher address* than the block being inserted. */for( pxIterator = &xStart; pxIterator->pxNextFreeBlock < pxBlockToInsert; pxIterator = pxIterator->pxNextFreeBlock ){/* Nothing to do here, just iterate to the right position. */}/* Do the block being inserted, and the block it is being inserted after* make a contiguous block of memory? */puc = ( uint8_t * ) pxIterator;if( ( puc + pxIterator->xBlockSize ) == ( uint8_t * ) pxBlockToInsert ){pxIterator->xBlockSize += pxBlockToInsert->xBlockSize;pxBlockToInsert = pxIterator;}else{mtCOVERAGE_TEST_MARKER();}/* Do the block being inserted, and the block it is being inserted before* make a contiguous block of memory? */puc = ( uint8_t * ) pxBlockToInsert;if( ( puc + pxBlockToInsert->xBlockSize ) == ( uint8_t * ) pxIterator->pxNextFreeBlock ){if( pxIterator->pxNextFreeBlock != pxEnd ){/* Form one big block from the two blocks. */pxBlockToInsert->xBlockSize += pxIterator->pxNextFreeBlock->xBlockSize;pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock->pxNextFreeBlock;}else{pxBlockToInsert->pxNextFreeBlock = pxEnd;}}else{pxBlockToInsert->pxNextFreeBlock = pxIterator->pxNextFreeBlock;}/* If the block being inserted plugged a gab, so was merged with the block* before and the block after, then it's pxNextFreeBlock pointer will have* already been set, and should not be set here as that would make it point* to itself. */if( pxIterator != pxBlockToInsert ){pxIterator->pxNextFreeBlock = pxBlockToInsert;}else{mtCOVERAGE_TEST_MARKER();} }

下面的代碼是遍歷空閑內(nèi)存塊鏈表,找出當(dāng)前內(nèi)存塊插入點(diǎn),內(nèi)存塊是按照地址從低到高的順序鏈接在一起

for( pxIterator = &xStart; pxIterator->pxNextFreeBlock < pxBlockToInsert; pxIterator = pxIterator->pxNextFreeBlock ){/* Nothing to do here, just iterate to the right position. */}

找到插入點(diǎn)以后判斷是否可以和要插入的內(nèi)存塊合并,如果可以的話就合并在一起,接著檢查是否可以和下一個(gè)內(nèi)存塊合并,如果可以就再次合并,如果不能就將這兩個(gè)內(nèi)存塊連接起來,pxIterator不等于pxBlockToInsert就意味著在內(nèi)存塊插入的過程中 沒有進(jìn)行過一次內(nèi)存合并這樣的話就使用最普通的處理方法,pxIterator所指向的內(nèi)存塊在前,pxBlockToinsert所指向的內(nèi)存塊在后,將兩個(gè)內(nèi)存塊鏈接起來。

heap_5

heap_5 使用了和heap_4相同的合并算法,內(nèi)存管理實(shí)現(xiàn)起來基本相同,但是heap_5內(nèi)存堆跨越多個(gè)不連續(xù)的內(nèi)存段,在使用heap_5調(diào)用API函數(shù)之前需要調(diào)用vPortDefineHeapRegions來對內(nèi)存做初始化處理,在vPortDefineHeapRegions未執(zhí)行之前禁止調(diào)用任何可能會調(diào)用pvPortMalloc的API函數(shù)。vPortDefineHeapRegions的參數(shù)是一個(gè)HeapRegion_t類型的數(shù)組,HeapRegion是一個(gè)結(jié)構(gòu)體:

typedef struct HeapRegion {uint8_t * pucStartAddress; //內(nèi)存塊的起始地址 size_t xSizeInBytes; //內(nèi)存段大小 } HeapRegion_t;

總結(jié)

以上是生活随笔為你收集整理的FreeRTOS--堆内存管理(二)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

亚洲一区美女视频在线观看免费 | 91精品国产自产91精品 | 偷拍精偷拍精品欧洲亚洲网站 | 91久久国产综合精品女同国语 | 懂色av一区二区在线播放 | 97成人免费| av在线看片| 国产一区二区三区高清播放 | 欧美精品久久久久性色 | 大荫蒂欧美视频另类xxxx | 992tv人人草| 日韩在线免费视频 | 欧美一区二区三区在线视频观看 | 91视频啪| 国产伦理一区二区 | 日批视频国产 | 九九热免费视频在线观看 | 美女免费视频黄 | 成年人看片网站 | 黄色视屏av | 欧美另类v | 久久免费的视频 | 国产不卡在线看 | 香蕉影院在线 | 免费在线观看亚洲视频 | 久久精品香蕉视频 | 99久久精品国产一区二区三区 | 天天爱综合 | 视频在线观看国产 | 超碰人人av| 亚洲国产成人精品在线观看 | 三三级黄色片之日韩 | 成年人在线视频观看 | 免费福利在线播放 | 日本一区二区免费在线观看 | 激情久久一区二区三区 | 久久99精品久久久久蜜臀 | 中文字幕在线观看完整 | 日本久久影视 | 久久综合亚洲鲁鲁五月久久 | 米奇四色影视 | 欧美一级爽 | 91入口在线观看 | 激情婷婷| 亚洲欧美成aⅴ人在线观看 四虎在线观看 | 久久99亚洲精品久久 | 久久夜色精品国产欧美乱 | 国产精品美女久久 | 精品国产伦一区二区三区 | 久久伊人精品天天 | 在线精品一区二区 | 日韩在线观看视频网站 | 亚州中文av| 日韩av在线资源 | 99久久99久久精品国产片果冰 | 精品美女视频 | 国产精品每日更新 | 日韩久久久久久久久 | 人人舔人人干 | 国产三级精品在线 | 亚洲视频中文 | 久久久www免费电影网 | 在线观看视频99 | 97av在线视频免费播放 | 欧美在线1 | 免费在线播放 | 伊人久久在线观看 | 欧美日韩国产三级 | 天天爽人人爽夜夜爽 | 成人国产电影在线观看 | 色婷婷骚婷婷 | 欧美国产在线看 | 欧美孕妇视频 | 91欧美视频网站 | 日本中文字幕在线电影 | 成人精品视频久久久久 | 亚洲一级黄色 | 一区二区精品在线 | 亚洲福利精品 | av网址在线播放 | 久久69av| 久久精品成人热国产成 | 激情影院在线观看 | 久久高清毛片 | 天天色天天干天天色 | 天天草天天色 | 久久免费电影 | 精品专区一区二区 | 99久久精品免费看国产 | 亚洲女同ⅹxx女同tv | 黄色最新网址 | 天堂av影院| 狠狠躁夜夜躁人人爽超碰97香蕉 | 在线免费观看亚洲视频 | 久草免费在线观看视频 | 国内精品久久久久久久97牛牛 | a级国产乱理论片在线观看 伊人宗合网 | 天堂av高清 | 亚洲一区二区三区毛片 | 久久网页 | 亚洲欧洲日韩在线观看 | 亚洲,播放 | 91麻豆精品国产91久久久无需广告 | 中文成人字幕 | 中文字幕在线乱 | 69国产在线观看 | 中文字幕色综合网 | 韩国三级一区 | 在线免费观看视频a | 最近日本字幕mv免费观看在线 | 国产一区 在线播放 | 亚洲国产片色 | 亚洲国产精品成人综合 | 在线观看av网 | 99精品国产视频 | 免费看一级特黄a大片 | 中文字幕国产精品一区二区 | 亚洲精品视频免费在线观看 | 91视频午夜 | 超级碰碰碰免费视频 | 在线电影日韩 | 91完整版 | 国产xx视频| 欧美日韩在线精品一区二区 | 久久国产精品一区二区 | 国产福利免费在线观看 | 国产最顶级的黄色片在线免费观看 | 午夜成人免费电影 | 月下香电影 | 久久午夜羞羞影院 | 国产精品一区二区三区在线免费观看 | 中文字幕av免费 | 99久久精品日本一区二区免费 | 四虎欧美 | 在线播放第一页 | 日韩伦理一区二区三区av在线 | 欧美日韩国产一区二区在线观看 | 国产精品av免费在线观看 | 久久国产剧场电影 | 婷婷在线精品视频 | 久久精品1区 | 国产a精品 | av动图 | 亚洲精品中文在线观看 | 欧美大荫蒂xxx| av黄色国产 | 香蕉在线播放 | 成人丝袜 | 99热99| 亚洲精品久久久久999中文字幕 | 在线亚洲午夜片av大片 | 中文字幕黄网 | 国产主播99 | av动态图片 | 亚洲免费在线视频 | 国产又粗又猛又黄视频 | 2019中文最近的2019中文在线 | 亚洲欧美日韩国产一区二区 | 国产明星视频三级a三级点| 国产资源在线观看 | 国产日本高清 | 69视频在线播放 | 亚洲精品国产精品国 | 日本激情视频中文字幕 | 欧美日韩中文在线视频 | 久精品视频在线 | 久久久久成人精品免费播放动漫 | 天天艹天天 | 成人免费共享视频 | 久久夜夜夜 | 亚洲高清视频在线 | 久久伊人免费视频 | 亚洲国产97在线精品一区 | a级国产乱理论片在线观看 伊人宗合网 | 综合久久久久久久 | 成人精品久久 | 国产综合片 | 中文字幕在线视频免费播放 | 91视频链接| 日韩精品视频免费专区在线播放 | 91精品视频在线免费观看 | 免费在线观看av网站 | 最新国产中文字幕 | 97超碰在 | 99视频在线免费播放 | 色五月色开心色婷婷色丁香 | 97视频总站 | 欧美日韩电影在线播放 | 天天拍天天色 | 欧美日韩中 | 狠狠色狠狠综合久久 | 天天射天天爱天天干 | 精品久久九九 | 国产午夜精品免费一区二区三区视频 | 婷婷综合电影 | 韩国av在线播放 | 狠狠插狠狠操 | 97成人在线免费视频 | www.com久久| 激情视频久久 | 精品久久久久久一区二区里番 | 亚洲成人免费 | 在线一二三四区 | 97品白浆高清久久久久久 | 天天插天天 | 欧美一级片在线 | 日韩视频免费看 | 国产一级视频免费看 | 亚洲一区二区视频在线播放 | 99热精品在线观看 | 国产短视频在线播放 | 亚洲精品视频免费在线观看 | 99这里只有精品99 | wwwwww国产 | 在线观看免费成人 | 99热超碰在线 | 99产精品成人啪免费网站 | 狠狠色丁香久久婷婷综合五月 | 日韩午夜高清 | 久久手机免费视频 | 久久99精品久久久久蜜臀 | 国产欧美日韩视频 | 国产精品美女久久久久久久网站 | 欧美日本国产在线观看 | 亚洲国产综合在线 | 天天操夜夜叫 | 国产精品区二区三区日本 | 狠狠色噜噜狠狠狠狠 | 日韩精品一区二区免费视频 | 夜夜骑日日 | 亚洲视频免费在线观看 | 日日爽天天爽 | 久久久久国产精品一区二区 | 天天伊人网 | 不卡的av在线 | 亚洲综合在线观看视频 | 国产精品成人一区二区三区吃奶 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 亚洲综合精品视频 | 国产亚洲精品久久久久久 | 狠狠色丁香九九婷婷综合五月 | 婷婷精品视频 | 成人久久18免费网站 | 成 人 黄 色 视频 免费观看 | 成人免费看视频 | 婷婷日韩 | 五月婷婷综合久久 | 五月天久久综合 | 国产色综合| 成人在线视频免费看 | av在线免费在线观看 | 免费色视频在线 | 最近中文字幕免费视频 | 久久精品国产免费看久久精品 | 国产日韩欧美在线免费观看 | 久久永久视频 | 中文字幕在线免费看 | 国产视频久久久 | 综合色播 | 国产主播大尺度精品福利免费 | 国产一区在线免费观看视频 | 国产一二三区在线观看 | 三级av在线免费观看 | www色综合 | 国产免费中文字幕 | 69久久夜色精品国产69 | 午夜久久久久久久 | 日韩中文字幕亚洲一区二区va在线 | 欧美一二三专区 | 久久久免费| 特级大胆西西4444www | 久草线| 久久精品爱爱视频 | 亚洲精品99 | 日韩免费观看高清 | 免费黄色特级片 | 91最新视频在线观看 | 国产精品 视频 | 看片黄网站 | 亚洲伦理精品 | 美女视频是黄的免费观看 | 午夜精品视频一区二区三区在线看 | 亚洲日本va午夜在线电影 | 九九视频这里只有精品 | 成人av一二三区 | 91高清一区| 久久视频这里有精品 | 美女网站免费福利视频 | 成人在线免费小视频 | 久久久久久久久久电影 | 91精品在线观看入口 | 免费黄色在线播放 | 日韩欧美区 | 黄视频网站大全 | 九9热这里真品2 | 成人午夜电影网站 | 日日夜夜精品免费 | 色综合激情网 | 开心丁香婷婷深爱五月 | 国产一区在线视频播放 | 亚洲一级片在线观看 | 国产精品久久人 | 国产福利a | 视频一区二区视频 | 中文一区二区三区在线观看 | 免费看黄20分钟 | 欧美性色xo影院 | 亚洲欧美国产精品久久久久 | 精品国产成人在线影院 | jizz18欧美18 | 日日操日日操 | 午夜视频99 | 久久久久久久久久亚洲精品 | 亚洲少妇自拍 | 久久网站最新地址 | 探花视频免费观看高清视频 | 91丨九色丨国产丨porny精品 | 亚洲精品黄色在线观看 | 亚洲精品国产综合99久久夜夜嗨 | 亚洲乱码国产乱码精品天美传媒 | 亚洲精品一区二区网址 | 久久久久久久久久久综合 | 在线播放av网址 | 中文字幕有码在线 | 久久久久www | 久久精品一区八戒影视 | 国产无套精品久久久久久 | 精品国产精品久久一区免费式 | 91视频大全 | 视频一区二区在线观看 | 国产精品嫩草影院123 | 天天射狠狠干 | 久草在线视频新 | 日韩三级一区 | 黄在线免费看 | 国产一区不卡在线 | 国内精品久久久久影院日本资源 | 又黄又爽又无遮挡的视频 | 日韩精品免费 | 日韩在线观看你懂得 | 8x8x在线观看视频 | 欧美久久久一区二区三区 | 亚洲国产欧美一区二区三区丁香婷 | 99久久99| 四虎在线免费观看视频 | 国产成人黄色在线 | 欧美国产不卡 | 九九热免费在线视频 | 人人舔人人爽 | 久久人人精 | 免费观看黄 | 91久久国产自产拍夜夜嗨 | 深爱五月激情五月 | 国产精品久久久亚洲 | 日韩在线观看免费 | 99久久精品国产系列 | 狠狠色丁香久久婷婷综合五月 | 亚洲精品xxxx | 欧美精品久久久久久久久久久 | 91av免费观看 | www.在线看片.com | 狠狠久久伊人 | 久久再线视频 | 免费a视频在线 | 激情xxxx| 99精品在线免费视频 | 99久久99热这里只有精品 | 欧美黄色特级片 | 丁香婷婷激情国产高清秒播 | 国产精品免费大片视频 | 91精品1区2区| 成人在线一区二区三区 | 四虎在线观看网址 | 久久黄色免费视频 | 亚洲一区二区视频在线 | 精品国产精品久久一区免费式 | 亚洲 欧美日韩 国产 中文 | 热久精品 | 亚洲日本一区二区在线 | 久久久久久国产一区二区三区 | 色综合天天 | 欧美日韩国产免费视频 | 成人免费观看网站 | 一区二区三区在线视频111 | 亚洲精品乱码 | 中文字幕在线久一本久 | 久久综合婷婷综合 | 久草在线综合 | 青草草在线 | 久久免费a | 国产成人在线观看 | 国产在线最新 | 午夜av日韩 | 久久这里只有精品9 | 成人午夜免费剧场 | 久久精品官网 | 精品一区二区在线免费观看 | 日本中文在线观看 | www成人精品 | 成人亚洲免费 | 国产成人免费精品 | 一级做a视频 | 成人影视免费看 | 日韩午夜电影网 | 亚洲黄色av网址 | 免费人成在线观看 | 欧美资源在线观看 | 日韩精品视| 国产精品99久久久久久宅男 | 99久久精品国产系列 | 亚洲一区网 | 天天插综合 | 欧美日韩国产精品久久 | 少妇bbb好爽 | 最近中文字幕免费视频 | 96国产在线 | 日韩精品中文字幕av | 精品国产91亚洲一区二区三区www | 国产一区在线观看视频 | 丝袜护士aⅴ在线白丝护士 天天综合精品 | 97超碰人人爱 | 午夜91在线| 亚洲片在线 | 93久久精品日日躁夜夜躁欧美 | 超碰免费公开 | 久久艹99 | 国产黄色片免费看 | 黄色av成人在线 | 中文字幕一区二区三区乱码在线 | 欧美日韩一区二区三区不卡 | 99riav1国产精品视频 | 91av片 | 在线免费黄 | 日韩激情视频在线观看 | 午夜久久久久久久久久影院 | 欧美一区二区免费在线观看 | 91成人国产 | 国产精品99久久久久人中文网介绍 | 天天操月月操 | 波多野结衣视频一区二区 | 国产综合精品久久 | 美腿丝袜av | 精品在线观看免费 | 国内久久精品视频 | 色婷婷av国产精品 | 日本高清中文字幕有码在线 | 天天婷婷| 夜夜夜夜操 | www.狠狠色.com | 在线 国产 亚洲 欧美 | 久久国产美女视频 | 一区二区三区免费在线观看视频 | 免费黄色看片 | www五月天 | 久青草视频在线观看 | 日本黄色大片免费 | 在线v片免费观看视频 | 亚洲天堂社区 | 天天天天天天操 | 久久免费a | 在线免费三级 | 亚洲欧美在线综合 | 日韩亚洲国产精品 | 中文字幕资源网 | 国产精品久久久久高潮 | 午夜免费久久看 | 激情视频免费在线 | 一区二区视频在线播放 | 在线中文字幕观看 | 亚洲男男gaygay无套同网址 | 久久久久99精品成人片三人毛片 | 这里有精品在线视频 | 在线有码中文字幕 | 亚洲视频在线看 | 久久国产精品区 | a极黄色片 | 日韩理论电影在线 | 黄色免费网站大全 | 国产在线观看黄 | 天堂va在线观看 | 精品国产电影一区二区 | www.夜夜爱| 日韩天天操 | 日韩免费视频观看 | 人人网人人爽 | 日韩一区二区免费在线观看 | 色综久久 | 综合色站| 久久影院中文字幕 | 97人人人人| 91精品视频一区二区三区 | 欧美久草网 | 中文字幕在线观看第三页 | 亚洲成人欧美 | 久久国产免费 | 中文字幕乱视频 | 91在线精品播放 | 日韩精品一区二区久久 | 日韩精品一区二区三区丰满 | 国产99久久精品一区二区永久免费 | 久草电影在线观看 | 日韩精品中文字幕有码 | 草久久精品 | 国内揄拍国内精品 | 不卡中文字幕av | 中文字幕麻豆 | 亚洲精品日韩一区二区电影 | 一区二区三区视频网站 | 欧美激情精品久久久久 | 国产成人久久av | 日韩电影在线一区二区 | 日韩欧美专区 | 日本久久久久久 | 综合天天色 | 国产视频精选 | 欧美日韩三级在线观看 | av在线播放观看 | 日本精品视频一区 | 96av视频 | 成 人 免费 黄 色 视频 | 亚洲理论影院 | 日本久久久影视 | 高清av网| 天天天天天天操 | 午夜久久久久久久久久影院 | 亚洲影院天堂 | 日韩欧美精品一区 | 九九精品在线观看 | 人人射av | 九色porny真实丨国产18 | 欧美激情精品久久久久久免费印度 | 日韩国产高清在线 | 手机在线永久免费观看av片 | 国产亚洲精品中文字幕 | 三级黄色大片在线观看 | 97免费中文视频在线观看 | 亚洲精品国产精品国自产观看 | 国产亚洲精品免费 | 天天曰夜夜爽 | 久久免费av电影 | 国产91亚洲精品 | 亚洲春色成人 | 色综合久久久久综合 | 久久久久久在线观看 | 麻豆免费视频观看 | 五月激情五月激情 | 精品国产乱码 | 亚洲高清色综合 | 久久在现 | 久久久久久久免费看 | 久久婷婷久久 | 亚洲激情网站免费观看 | 欧美一区二区三区在线 | 日韩激情片在线观看 | www.天天成人国产电影 | sesese图片 | 亚洲成a人片在线www | 亚洲日本精品视频 | 韩国av免费观看 | 亚洲 欧洲 国产 精品 | 亚洲黄色区 | 久久久2o19精品 | 在线小视频你懂的 | 日韩免费观看一区二区 | 黄色在线观看污 | 亚洲午夜精品久久久久久久久久久久 | 久久综合久久88 | 国产精品永久久久久久久久久 | 久久精品电影 | 亚洲精品影院在线观看 | 国模视频一区二区 | 欧美日韩在线观看一区二区三区 | 成人国产精品入口 | 九九国产视频 | 国产一级免费在线 | 国产日韩视频在线 | 久久久精品视频网站 | 天天做天天爽 | 日韩中文字幕第一页 | 超碰在线网 | 亚洲五月六月 | 亚洲在线视频网站 | 亚洲专区在线播放 | 久草资源在线观看 | 天天综合网 天天综合色 | 日韩成人在线一区二区 | 亚洲在线视频免费观看 | 91精品欧美一区二区三区 | 视色网站 | 中文字幕在线资源 | www.天天操.com| 成片免费观看视频 | 免费看v片网站 | 亚洲成人黄 | 久久一及片| 久久99视频精品 | 久久电影日韩 | 久久成人精品电影 | 人人精品| 91精品伦理 | 97国产大学生情侣酒店的特点 | 国产精品免费一区二区 | 99色人 | 日韩理论片在线 | 中文字幕一区二区三区乱码在线 | 国产精品毛片 | 高清av影院 | 国产一区二区精 | 五月婷婷播播 | 亚洲午夜久久久久久久久电影网 | 九九三级毛片 | 国产精品对白一区二区三区 | 极品美女被弄高潮视频网站 | 国产日产av | 国产精品久久久久久久久久尿 | 色五月成人 | 在线观看国产区 | 六月色婷婷 | 国产成人三级在线 | av在线播放观看 | 黄色视屏在线免费观看 | 国产无区一区二区三麻豆 | 国产高清在线免费视频 | 国产女做a爱免费视频 | 国产精品一区二区三区99 | 国产91在线看 | www日| 欧美日韩一级久久久久久免费看 | 在线免费观看视频一区二区三区 | 国产剧情在线一区 | 亚洲免费视频在线观看 | www.久热| 96视频免费在线观看 | 午夜色场| 伊人春色电影网 | 日韩久久久久久久久久久久 | 五月综合激情婷婷 | 日韩一区二区三区高清在线观看 | 久久免费视频7 | 91精品1区2区 | 欧美黄色高清 | 欧美做受高潮 | 国产激情久久久 | jizz999| 天天天天天天天天操 | 五月婷婷操 | 五月综合久久 | 国产亚洲在 | 四虎影视国产精品免费久久 | 国产精品视频免费看 | 国产91免费观看 | 亚洲国产一区二区精品专区 | 福利视频一区二区 | 久久久久久久久久久久99 | 国产在线播放一区 | 久久亚洲免费视频 | 亚洲伊人av | 欧美日韩国产高清视频 | www免费看片com | 欧美日韩国产精品一区二区 | 国产精品久久久久久久久久久久久 | 天天爱天天插 | 黄色毛片在线看 | 中中文字幕av | 东方av在线免费观看 | 狠狠ri| 99久高清在线观看视频99精品热在线观看视频 | 成人三级网址 | 国产亚洲精品久久久久动 | 亚洲欧美激情精品一区二区 | 久久精品视频免费播放 | 九九热免费观看 | 国产一区精品在线 | 欧美日韩一区二区三区免费视频 | 91精品人成在线观看 | www黄色软件 | 欧美久久综合 | 午夜久久网站 | 国产小视频91 | 久久伊人精品一区二区三区 | 在线观看免费色 | 欧美日本啪啪无遮挡网站 | av解说在线观看 | 久久久久久毛片精品免费不卡 | 久久精品韩国 | 午夜久久福利视频 | 婷婷深爱五月 | 午夜视频欧美 | 成片免费观看视频999 | 一区二区三区高清 | 国产香蕉97碰碰碰视频在线观看 | 日韩美女高潮 | 美女视频免费精品 | 日本在线观看中文字幕无线观看 | 亚洲欧洲在线视频 | 六月色播| 久久99视频精品 | 欧美日韩高清免费 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 伊人久久国产精品 | 精品自拍网 | 狠狠干狠狠操 | 久草视频在线新免费 | 天天操天天操天天操天天操天天操天天操 | 国产在线欧美在线 | 久久综合色综合88 | 亚洲激情影院 | 婷婷色网址 | 中文字幕在线日亚洲9 | 亚洲国内在线 | 久艹视频在线免费观看 | 久久精品一二三区白丝高潮 | 国产美女网站在线观看 | 婷五月激情| 超碰免费在线公开 | 99久久99视频只有精品 | 国产资源网 | 亚洲美女精品视频 | 免费在线精品视频 | 久久国产精品免费 | 九九热免费在线观看 | 欧美成人黄色 | 97国产大学生情侣酒店的特点 | 麻豆成人小视频 | 国产精品毛片 | 亚洲国内精品视频 | 久久色网站 | 日韩色高清| 亚洲国产网站 | 日韩中文字幕视频在线 | 久草精品电影 | 黄色精品国产 | 亚洲免费国产 | 91黄视频在线观看 | 黄色成年网站 | 成人在线观看免费视频 | av电影在线观看完整版一区二区 | 综合色在线观看 | 国产69熟 | av在线免费不卡 | 少妇资源站 | 国产精品三级视频 | 天天插狠狠干 | 国产女人40精品一区毛片视频 | 色婷婷88av视频一二三区 | 免费一级片久久 | 亚洲成人av电影 | 日韩,精品电影 | 欧美日韩国内在线 | 久久黄色影视 | 日韩av午夜 | 在线观看视频你懂的 | 久久黄色网 | 五月婷婷中文网 | 欧美精品首页 | 超碰夜夜 | av天天澡天天爽天天av | 97成人超碰 | 五月开心六月婷婷 | 婷婷激情小说网 | 国产色爽 | 亚洲国产片 | 成人av资源网站 | 久99精品 | 色香蕉在线 | 国产在线精品一区二区三区 | 麻豆精品在线视频 | 欧美日韩久久久 | 婷婷伊人五月天 | 成人福利在线观看 | 欧美一区视频 | 少妇搡bbbb搡bbb搡aa | 亚洲精品网站 | 久久国产精品久久精品国产演员表 | 美女免费视频观看网站 | 精品国产乱码久久久久久久 | 久久特级毛片 | 久久成人一区二区 | 日日操夜| 国产精品综合久久久 | 成 人 黄 色视频免费播放 | 国产精品免费观看久久 | 最新亚洲视频 | 久久久久久久久久毛片 | 五月天婷婷在线播放 | 4438全国亚洲精品在线观看视频 | 免费福利小视频 | 91色影院| 91久久久久久久一区二区 | 天天躁天天操 | 黄色的网站免费看 | 99视频免费| 中文字幕成人在线 | 婷婷网址| 亚洲国产欧美在线人成大黄瓜 | 97色狠狠 | 久久爱资源网 | 国产精品麻豆欧美日韩ww | 欧美视频国产视频 | 人人精久 | 亚洲国产成人在线观看 | 国产精品一区二区 91 | 欧美男女爱爱视频 | 久久久久久久久毛片 | 狠狠色伊人亚洲综合成人 | 六月丁香色婷婷 | 久久欧美精品 | 久久精品日本啪啪涩涩 | 99精品国产免费久久久久久下载 | 青草视频免费观看 | 日韩欧美视频在线观看免费 | 天天操天天操天天操天天 | 久久超碰99 | 五月婷婷六月丁香在线观看 | 成人三级黄色 | 亚州欧美视频 | h动漫中文字幕 | 婷婷成人综合 | 欧美日韩高清在线一区 | 国产中文视 | 一级黄色电影网站 | 久久久久久久久久网站 | 日本精品视频在线观看 | 成 人 黄 色 视频 免费观看 | 97免费在线视频 | 9999精品免费视频 | 深夜国产福利 | 中文字幕免费一区 | 黄色在线免费观看网址 | 日韩在线一二三区 | 99精品视频观看 | 69精品在线| 日韩免费视频一区二区 | 国产欧美精品在线观看 | 亚洲国产影院 | 91亚洲国产成人久久精品网站 | av一级片网站 | 久久国产精品小视频 | 久久久久久久久久网 | 一区二区伦理电影 | 久草网站 | 中文字幕在线视频一区 | 色wwww| 免费中文字幕 | 欧美日韩大片在线观看 | 国产中文视 | 99久久精品免费看 | 毛片一区二区 | 丝袜少妇在线 | 免费国产视频 | 中文字幕丝袜一区二区 | 国产精品视频免费看 | 亚洲精品视频在线观看网站 | 99精品久久精品一区二区 | 97国产一区二区 | 亚洲精品av在线 | 香蕉网在线观看 | 欧美大片在线观看一区 | 国产.精品.日韩.另类.中文.在线.播放 | 最近2019年日本中文免费字幕 | 欧美一区二区精美视频 | 911在线| 婷婷激情综合五月天 | 手机在线永久免费观看av片 | 久久久久久久久久久网站 | 日韩电影中文,亚洲精品乱码 | 午夜国产一区 | 天天天色| 日韩精品中文字幕久久臀 | 国产精品一区二区三区四 | 成人在线观看你懂的 | 伊甸园永久入口www 99热 精品在线 | 92国产精品久久久久首页 | 久久久久激情电影 | 丁香婷婷激情网 | 国产经典av | 欧美日韩视频在线观看一区二区 | 成人日韩av | 日韩啪视频| 99久久精品国产免费看不卡 | 中文伊人| 欧美精品天堂 | 中文字幕在线看视频 | 国产精品免费成人 | a一片一级 | 免费视频91蜜桃 | 免费碰碰| 私人av| 超碰官网 | 在线视频欧美日韩 | 日韩在线一区二区免费 | 夜夜视频| 日韩久久午夜一级啪啪 | 一区二区三区观看 | 午夜在线看片 | 成人免费在线视频观看 | 国产免费二区 | 亚洲免费色 | 国产 日韩 欧美 自拍 | 国产中文字幕在线看 | 国产美女免费观看 | 九九欧美 | 欧美日韩免费在线视频 | 欧美性一级观看 | 香蕉色综合 | av网站在线观看播放 | 久热国产视频 | 色综合人人 | 国产精品久久久久久久久费观看 | 久久精品欧美一 | 中文字幕在线色 | 97视频在线播放 | 黄色片视频免费 | 日韩激情免费视频 | 国产一区免费观看 | 欧美日韩免费观看一区=区三区 | 国产精品欧美激情在线观看 | 国产精品久久9 | 天天操天天插 | 欧洲激情综合 | 天天操一操| 欧美极品在线播放 | 中文字幕免费久久 | 成人午夜黄色影院 | 国产精品破处视频 | 91视频 - x99av | 久久久99精品免费观看app | 日韩欧美一区二区在线观看 | 不卡av在线 | 在线欧美小视频 | 超碰97人人射妻 | 2022国产精品视频 | 国产成人精品亚洲日本在线观看 | 日韩免费在线网站 | 免费欧美高清视频 | a√天堂中文在线 | 超碰人人乐 | 人操人| 欧美日韩国产二区三区 | www.夜夜爽| 久久新 | 日韩欧美一区二区不卡 | 成人av一区二区在线观看 | 香蕉视频免费在线播放 | 婷婷国产在线观看 | 男女视频91 | 欧美日本啪啪无遮挡网站 | 婷婷丁香狠狠爱 | 国产女做a爱免费视频 | 91色偷偷| 国产精品美女久久久久久免费 | 久久久久亚洲天堂 | 亚洲精品玖玖玖av在线看 | 久久精品中文 | 日韩欧美视频在线播放 | 久久免费视频网站 | 国产精品日韩久久久久 | 色婷婷综合视频在线观看 | 国产精品九九九 | 国产成人一区二区三区免费看 | 色免费在线 | free. 性欧美.com | 亚洲成a人片77777kkkk1在线观看 | 91综合久久一区二区 | 91精品久久久久久粉嫩 | 中文在线a√在线 | 毛片黄色一级 | 正在播放日韩 | 丁香婷婷综合五月 | 免费视频你懂得 | 一区二区视频欧美 | 中文视频一区二区 | 丝袜美腿在线播放 | 日日夜夜艹 | 97超碰在线播放 | 成人免费 在线播放 | 婷婷av网 | 欧美精品久久久久性色 | 成人免费在线视频 | av日韩国产 | 99综合影院在线 | 欧美午夜精品久久久久久浪潮 | 综合网天天色 | 91av看片 | 国产精品一区二区在线观看 | 国内精品久久久久久 | 国产一区电影在线观看 | 天天综合婷婷 | 欧美永久视频 | 在线观看国产一区二区 | 一区二区三区福利 | 久久不射电影院 | 久久综合九色综合久久久精品综合 | 一区二区电影在线观看 | 久久不见久久见免费影院 | 国产一级不卡视频 | 色婷五月 | 国产精品日韩欧美一区二区 |