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

歡迎訪問(wèn) 生活随笔!

生活随笔

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

编程问答

FreeRTOS互斥锁

發(fā)布時(shí)間:2025/3/15 编程问答 49 豆豆
生活随笔 收集整理的這篇文章主要介紹了 FreeRTOS互斥锁 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

信號(hào)量API函數(shù)實(shí)際上都是宏,它使用現(xiàn)有的隊(duì)列機(jī)制。這些宏定義在semphr.h文件中。如果使用信號(hào)量或者互斥量,需要包含semphr.h頭文件。

信號(hào)量包括二值信號(hào)量、計(jì)數(shù)信號(hào)量、互斥信號(hào)量和遞歸互斥信號(hào)量。和普通隊(duì)列比起來(lái),信號(hào)量雖然沒(méi)有隊(duì)列項(xiàng)實(shí)體,但是信號(hào)量值等同于隊(duì)列項(xiàng)個(gè)數(shù)。

?

?

互斥鎖和遞歸互斥鎖:互斥鎖是用來(lái)保證共享數(shù)據(jù)操作的完整性,同時(shí)只能有一個(gè)任務(wù)訪問(wèn)共享數(shù)據(jù)。遞歸互斥鎖和普通互斥鎖比起來(lái),同一個(gè)任務(wù)可以多次獲取遞歸互斥鎖,在釋放同等次數(shù)之后才能解鎖。

?

?

在分析互斥鎖之前,先搞清楚兩個(gè)概念,優(yōu)先級(jí)反轉(zhuǎn)和優(yōu)先級(jí)繼承

優(yōu)先級(jí)反轉(zhuǎn):互斥鎖被低優(yōu)先級(jí)的任務(wù)持有,高優(yōu)先級(jí)任務(wù)等待解鎖。這時(shí)中等優(yōu)先級(jí)任務(wù)一直運(yùn)行,這導(dǎo)致高優(yōu)先級(jí)任務(wù)在等待低優(yōu)先級(jí)任務(wù),而低優(yōu)先級(jí)任務(wù)無(wú)法執(zhí)行。這種高優(yōu)先級(jí)等待中優(yōu)先級(jí)的情況,叫做優(yōu)先級(jí)反轉(zhuǎn)。

優(yōu)先級(jí)繼承:為了解決優(yōu)先級(jí)反轉(zhuǎn)而提出優(yōu)化機(jī)制,讓低優(yōu)先級(jí)任務(wù)臨時(shí)繼承高優(yōu)先級(jí)任務(wù)的優(yōu)先級(jí)。在低優(yōu)先級(jí)釋放互斥鎖之后,還要恢復(fù)原來(lái)的優(yōu)先級(jí)。

?

?

先看一下任務(wù)TCB

因?yàn)閮?yōu)先級(jí)繼承機(jī)制,在互斥鎖釋放后需要恢復(fù)優(yōu)先級(jí),uxBasePriority在優(yōu)先級(jí)繼承期間被用來(lái)保存任務(wù)優(yōu)先級(jí)

uxMutexesHeld表示任務(wù)持有了多少個(gè)互斥鎖

/* 任務(wù)TCB */ typedef struct tskTaskControlBlock {volatile StackType_t *pxTopOfStack; /* 棧頂?shù)刂?*/......ListItem_t xStateListItem; /* 狀態(tài)列表項(xiàng):運(yùn)行、就緒、掛起、阻塞 */ListItem_t xEventListItem; /* 事件列表項(xiàng) */UBaseType_t uxPriority; /* 優(yōu)先級(jí) */StackType_t *pxStack; /* 棧指針 */char pcTaskName[configMAX_TASK_NAME_LEN]; /* 任務(wù)名 */......#if (configUSE_MUTEXES == 1)UBaseType_t uxBasePriority; /* 任務(wù)基礎(chǔ)優(yōu)先級(jí) */UBaseType_t uxMutexesHeld; /* 互斥鎖持有數(shù)量 */ #endif...... }tskTCB; typedef tskTCB TCB_t;

?

?

創(chuàng)建互斥鎖

?互斥鎖實(shí)際上是調(diào)用了隊(duì)列的創(chuàng)建函數(shù),創(chuàng)建好之后調(diào)用prvInitialiseMutex來(lái)初始化一些互斥鎖特有的變量

#define xSemaphoreCreateMutex() xQueueCreateMutex(queueQUEUE_TYPE_MUTEX) /* 創(chuàng)建互斥鎖 */ QueueHandle_t xQueueCreateMutex(const uint8_t ucQueueType) {QueueHandle_t xNewQueue;const UBaseType_t uxMutexLength = (UBaseType_t)1, uxMutexSize = (UBaseType_t)0;/* 創(chuàng)建互斥鎖隊(duì)列 */xNewQueue = xQueueGenericCreate(uxMutexLength, uxMutexSize, ucQueueType);/* 初始化互斥鎖隊(duì)列 */prvInitialiseMutex((Queue_t *)xNewQueue);return xNewQueue; }

prvInitialiseMutex函數(shù),將互斥鎖初始化為沒(méi)有被任何任務(wù)持有,并且處于解鎖狀態(tài)(隊(duì)列中有一個(gè)隊(duì)列項(xiàng))

/* 初始化互斥鎖 */ static void prvInitialiseMutex(Queue_t *pxNewQueue) {if(pxNewQueue != NULL){/* 初始化互斥鎖的持有者為空 */pxNewQueue->u.xSemaphore.xMutexHolder = NULL;/* 初始化隊(duì)列類型為互斥鎖 */pxNewQueue->uxQueueType = queueQUEUE_IS_MUTEX;/* 初始化遞歸次數(shù)為0 */pxNewQueue->u.xSemaphore.uxRecursiveCallCount = 0;traceCREATE_MUTEX(pxNewQueue);/* 初始化互斥鎖為解鎖狀態(tài)(向隊(duì)列中發(fā)送一個(gè)隊(duì)列項(xiàng)) */(void)xQueueGenericSend(pxNewQueue, NULL, (TickType_t)0U, queueSEND_TO_BACK);}else{traceCREATE_MUTEX_FAILED();} }

?

?

獲取互斥鎖

互斥鎖也叫互斥信號(hào)量,獲取互斥鎖和獲取信號(hào)量使用同一個(gè)函數(shù)

和普通信號(hào)量不同的是:

1.獲取成功時(shí),將互斥鎖持有者設(shè)為當(dāng)前任務(wù),當(dāng)前任務(wù)持有互斥鎖數(shù)量加一

2.因互斥鎖被其它任務(wù)持有而阻塞時(shí),為了防止優(yōu)先級(jí)反轉(zhuǎn)現(xiàn)象,進(jìn)行優(yōu)先級(jí)繼承處理

3.因互斥鎖被其它任務(wù)持有而阻塞,超時(shí)之后,因?yàn)榭赡苓M(jìn)行了優(yōu)先級(jí)繼承,剝奪原先繼承的優(yōu)先級(jí)(剝不剝奪看優(yōu)先級(jí)是否繼承自該任務(wù))

從源代碼看,調(diào)用xTaskPriorityInherit函數(shù)來(lái)進(jìn)行優(yōu)先級(jí)繼承;在超時(shí)之后,使用prvGetDisinheritPriorityAfterTimeout和vTaskPriorityDisinheritAfterTimeout函數(shù)來(lái)恢復(fù)優(yōu)先級(jí)

#define xSemaphoreTake(xSemaphore, xBlockTime) xQueueSemaphoreTake((xSemaphore), (xBlockTime)) /* 獲取信號(hào)量值 */ BaseType_t xQueueSemaphoreTake(QueueHandle_t xQueue, TickType_t xTicksToWait) {BaseType_t xEntryTimeSet = pdFALSE;TimeOut_t xTimeOut;Queue_t *const pxQueue = xQueue;#if (configUSE_MUTEXES == 1)BaseType_t xInheritanceOccurred = pdFALSE; #endifconfigASSERT((pxQueue));configASSERT(pxQueue->uxItemSize == 0);#if ((INCLUDE_xTaskGetSchedulerState == 1) || (configUSE_TIMERS == 1)){configASSERT(!((xTaskGetSchedulerState() == taskSCHEDULER_SUSPENDED) && (xTicksToWait != 0)));}#endiffor(;;){/* 進(jìn)入臨界區(qū) */taskENTER_CRITICAL();{/* 信號(hào)量計(jì)數(shù) */const UBaseType_t uxSemaphoreCount = pxQueue->uxMessagesWaiting;/* 信號(hào)量值大于0 */if(uxSemaphoreCount > (UBaseType_t)0){traceQUEUE_RECEIVE(pxQueue);/* 信號(hào)量值減一 */pxQueue->uxMessagesWaiting = uxSemaphoreCount - (UBaseType_t)1;#if (configUSE_MUTEXES == 1){/* 隊(duì)列類型是互斥鎖 */if(pxQueue->uxQueueType == queueQUEUE_IS_MUTEX){/* 互斥鎖的持有者設(shè)為當(dāng)前任務(wù),當(dāng)前任務(wù)持有鎖的數(shù)量加一 */pxQueue->u.xSemaphore.xMutexHolder = pvTaskIncrementMutexHeldCount();}else{mtCOVERAGE_TEST_MARKER();}}#endif/* 等待釋放信號(hào)量而阻塞的任務(wù)列表不為空 */if(listLIST_IS_EMPTY(&(pxQueue->xTasksWaitingToSend)) == pdFALSE){/* 將任務(wù)從釋放信號(hào)量而阻塞的任務(wù)列表中移除,任務(wù)優(yōu)先級(jí)大于當(dāng)前任務(wù)優(yōu)先級(jí) */if(xTaskRemoveFromEventList(&(pxQueue->xTasksWaitingToSend)) != pdFALSE){/* 請(qǐng)求切換任務(wù) */queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}/* 退出臨界區(qū) */taskEXIT_CRITICAL();/* 成功 */return pdPASS;}/* 信號(hào)量值為0 */else{/* 等待時(shí)間為0 */if(xTicksToWait == (TickType_t)0){#if (configUSE_MUTEXES == 1){configASSERT(xInheritanceOccurred == pdFALSE);}#endif/* 退出臨界區(qū) */taskEXIT_CRITICAL();traceQUEUE_RECEIVE_FAILED(pxQueue);/* 返回隊(duì)列為空錯(cuò)誤 */return errQUEUE_EMPTY;}/* 沒(méi)有記錄過(guò)當(dāng)前節(jié)拍狀態(tài) */else if(xEntryTimeSet == pdFALSE){/* 記錄當(dāng)前節(jié)拍狀態(tài) */vTaskInternalSetTimeOutState(&xTimeOut);/* 已經(jīng)記錄過(guò)當(dāng)前節(jié)拍狀態(tài) */xEntryTimeSet = pdTRUE;}else{mtCOVERAGE_TEST_MARKER();}}}/* 退出臨界區(qū) */taskEXIT_CRITICAL();/* 掛起調(diào)度器 */vTaskSuspendAll();/* 鎖定隊(duì)列 */prvLockQueue(pxQueue);/* 檢查是否超時(shí),沒(méi)有超時(shí) */if(xTaskCheckForTimeOut(&xTimeOut, &xTicksToWait) == pdFALSE){/* 檢查信號(hào)量值是否為0,為0 */if(prvIsQueueEmpty(pxQueue) != pdFALSE){traceBLOCKING_ON_QUEUE_RECEIVE(pxQueue);#if (configUSE_MUTEXES == 1){/* 隊(duì)列類型為互斥鎖 */if(pxQueue->uxQueueType == queueQUEUE_IS_MUTEX){/* 進(jìn)入臨界區(qū) */taskENTER_CRITICAL();{/* 任務(wù)優(yōu)先級(jí)繼承,返回值是否繼承優(yōu)先級(jí) */xInheritanceOccurred = xTaskPriorityInherit(pxQueue->u.xSemaphore.xMutexHolder);}/* 退出臨界區(qū) */taskEXIT_CRITICAL();}else{mtCOVERAGE_TEST_MARKER();}}#endif/* 將任務(wù)插入等待獲取信號(hào)量而阻塞的任務(wù)列表中 */vTaskPlaceOnEventList(&(pxQueue->xTasksWaitingToReceive), xTicksToWait);/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起,沒(méi)有切換過(guò)任務(wù) */if(xTaskResumeAll() == pdFALSE){/* 請(qǐng)求切換任務(wù) */portYIELD_WITHIN_API();}else{mtCOVERAGE_TEST_MARKER();}}/* 隊(duì)列不為空,while下一個(gè)循環(huán)時(shí)取走隊(duì)列項(xiàng) */else{/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起 */(void)xTaskResumeAll();}}/* 已經(jīng)超時(shí)或者超時(shí)之后 */else{/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起 */(void)xTaskResumeAll();/* 檢查隊(duì)列是否為空,為空 */if(prvIsQueueEmpty(pxQueue) != pdFALSE){#if (configUSE_MUTEXES == 1){/* 繼承了優(yōu)先級(jí) */if(xInheritanceOccurred != pdFALSE){/* 進(jìn)入臨界區(qū) */taskENTER_CRITICAL();{UBaseType_t uxHighestWaitingPriority;/* 獲取剩下所有等待互斥鎖任務(wù)的最高優(yōu)先級(jí) */uxHighestWaitingPriority = prvGetDisinheritPriorityAfterTimeout(pxQueue);/* 超時(shí)之后剝奪繼承優(yōu)先級(jí) */vTaskPriorityDisinheritAfterTimeout(pxQueue->u.xSemaphore.xMutexHolder, uxHighestWaitingPriority);}/* 退出臨界區(qū) */taskEXIT_CRITICAL();}}#endiftraceQUEUE_RECEIVE_FAILED(pxQueue);/* 返回隊(duì)列為空錯(cuò)誤 */return errQUEUE_EMPTY;}/* 隊(duì)列不為空,while下一個(gè)循環(huán)時(shí)取走隊(duì)列項(xiàng) */else{mtCOVERAGE_TEST_MARKER();}}} }

?

?

釋放互斥鎖

從源代碼來(lái)看,看不出和普通信號(hào)量處理有什么區(qū)別。

但是,因?yàn)榛コ怄i可能存在優(yōu)先級(jí)繼承的問(wèn)題,因此釋放互斥鎖時(shí)肯定需要恢復(fù)優(yōu)先級(jí)。

事實(shí)上,恢復(fù)優(yōu)先級(jí)在prvCopyDataToQueue函數(shù)中進(jìn)行。

#define xSemaphoreGive(xSemaphore) xQueueGenericSend((QueueHandle_t)(xSemaphore), NULL, semGIVE_BLOCK_TIME, queueSEND_TO_BACK) /* 發(fā)送隊(duì)列項(xiàng) */ BaseType_t xQueueGenericSend(QueueHandle_t xQueue, const void *const pvItemToQueue, TickType_t xTicksToWait, const BaseType_t xCopyPosition) {BaseType_t xEntryTimeSet = pdFALSE, xYieldRequired;TimeOut_t xTimeOut;Queue_t *const pxQueue = xQueue;configASSERT(pxQueue);configASSERT(!((pvItemToQueue == NULL) && (pxQueue->uxItemSize != (UBaseType_t)0U)));configASSERT(!((xCopyPosition == queueOVERWRITE) && (pxQueue->uxLength != 1)));#if ((INCLUDE_xTaskGetSchedulerState == 1) || (configUSE_TIMERS == 1)){configASSERT(!((xTaskGetSchedulerState() == taskSCHEDULER_SUSPENDED) && (xTicksToWait != 0)));}#endiffor(;;){/* 進(jìn)入臨界區(qū) */taskENTER_CRITICAL();{/* 目前已插入隊(duì)列項(xiàng)數(shù)小于最大可插入隊(duì)列數(shù)或者覆蓋型插入 */if((pxQueue->uxMessagesWaiting < pxQueue->uxLength) || (xCopyPosition == queueOVERWRITE)){traceQUEUE_SEND(pxQueue);#if (configUSE_QUEUE_SETS == 1){UBaseType_t uxPreviousMessagesWaiting = pxQueue->uxMessagesWaiting;xYieldRequired = prvCopyDataToQueue(pxQueue, pvItemToQueue, xCopyPosition);if(pxQueue->pxQueueSetContainer != NULL){if((xCopyPosition == queueOVERWRITE) && (uxPreviousMessagesWaiting != (UBaseType_t)0)){mtCOVERAGE_TEST_MARKER();}else if(prvNotifyQueueSetContainer(pxQueue, xCopyPosition) != pdFALSE){queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}else{if(listLIST_IS_EMPTY(&(pxQueue->xTasksWaitingToReceive)) == pdFALSE){if(xTaskRemoveFromEventList(&(pxQueue->xTasksWaitingToReceive)) != pdFALSE){queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}else if(xYieldRequired != pdFALSE){queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}}#else{/* 根據(jù)不同的入隊(duì)方式,將隊(duì)列項(xiàng)數(shù)據(jù)拷貝到隊(duì)列中 */xYieldRequired = prvCopyDataToQueue(pxQueue, pvItemToQueue, xCopyPosition);/* 等待接收隊(duì)列項(xiàng)而阻塞的任務(wù)列表不為空 */if(listLIST_IS_EMPTY(&(pxQueue->xTasksWaitingToReceive)) == pdFALSE){/* 將任務(wù)從事件列表中移除一個(gè)任務(wù),并掛接到就緒列表 */if(xTaskRemoveFromEventList(&(pxQueue->xTasksWaitingToReceive)) != pdFALSE){/* 請(qǐng)求切換任務(wù) */queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}/* 等待接收隊(duì)列項(xiàng)而阻塞的任務(wù)列表為空 */else if(xYieldRequired != pdFALSE){queueYIELD_IF_USING_PREEMPTION();}else{mtCOVERAGE_TEST_MARKER();}}#endif/* 退出臨界區(qū) */taskEXIT_CRITICAL();/* 成功 */return pdPASS;}/* 目前隊(duì)列已經(jīng)滿了,且不是覆蓋型插入 */else{/* 阻塞時(shí)間為0 */if(xTicksToWait == (TickType_t)0){taskEXIT_CRITICAL();traceQUEUE_SEND_FAILED(pxQueue);/* 返回隊(duì)列已滿錯(cuò)誤 */return errQUEUE_FULL;}/* 當(dāng)前節(jié)拍狀態(tài)還未記錄 */else if(xEntryTimeSet == pdFALSE){/* 記錄當(dāng)前節(jié)拍狀態(tài) */vTaskInternalSetTimeOutState(&xTimeOut);/* 當(dāng)前節(jié)拍狀態(tài)已經(jīng)記錄 */xEntryTimeSet = pdTRUE;}else{mtCOVERAGE_TEST_MARKER();}}}/* 退出臨界區(qū) */taskEXIT_CRITICAL();/* 掛起調(diào)度器 */vTaskSuspendAll();/* 鎖定隊(duì)列 */prvLockQueue(pxQueue);/* 檢查任務(wù)是否超時(shí),并未超時(shí) */if(xTaskCheckForTimeOut(&xTimeOut, &xTicksToWait) == pdFALSE){/* 檢查隊(duì)列是否已滿,已經(jīng)滿了 */if(prvIsQueueFull(pxQueue) != pdFALSE){traceBLOCKING_ON_QUEUE_SEND(pxQueue);/* 將任務(wù)掛接到等待發(fā)送而阻塞的任務(wù)列表中,并將任務(wù)掛接到延時(shí)列表中 */vTaskPlaceOnEventList(&(pxQueue->xTasksWaitingToSend), xTicksToWait);/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起 */if(xTaskResumeAll() == pdFALSE){/* 請(qǐng)求切換 */portYIELD_WITHIN_API();}}/* 剛好隊(duì)列出現(xiàn)空位,下一次while循環(huán)重新插入 */else{/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起 */(void)xTaskResumeAll();}}/* 已經(jīng)超時(shí)或者超時(shí)之后 */else{/* 解鎖隊(duì)列 */prvUnlockQueue(pxQueue);/* 解除調(diào)度器掛起 */(void)xTaskResumeAll();traceQUEUE_SEND_FAILED(pxQueue);/* 隊(duì)列已滿 */return errQUEUE_FULL;}} }

下面看一下prvCopyDataToQueue函數(shù),看看是怎么恢復(fù)優(yōu)先級(jí)的

從源代碼來(lái)看是通過(guò)xTaskPriorityDisinherit函數(shù)來(lái)恢復(fù)優(yōu)先級(jí)

/* 將隊(duì)列項(xiàng)拷貝到隊(duì)列中 */ static BaseType_t prvCopyDataToQueue(Queue_t *const pxQueue, const void *pvItemToQueue, const BaseType_t xPosition) {BaseType_t xReturn = pdFALSE;UBaseType_t uxMessagesWaiting;/* 隊(duì)列中隊(duì)列項(xiàng)數(shù) */uxMessagesWaiting = pxQueue->uxMessagesWaiting;/* 隊(duì)列項(xiàng)大小為0 */if(pxQueue->uxItemSize == (UBaseType_t)0){#if (configUSE_MUTEXES == 1){/* 隊(duì)列類型為互斥鎖 */if(pxQueue->uxQueueType == queueQUEUE_IS_MUTEX){/* 剝奪繼承優(yōu)先級(jí) */xReturn = xTaskPriorityDisinherit(pxQueue->u.xSemaphore.xMutexHolder);/* 互斥鎖持有者設(shè)置為空 */pxQueue->u.xSemaphore.xMutexHolder = NULL;}else{mtCOVERAGE_TEST_MARKER();}}#endif}/* 隊(duì)列項(xiàng)大小不為0,從隊(duì)列尾部插入 */else if(xPosition == queueSEND_TO_BACK){/* 將隊(duì)列項(xiàng)插入隊(duì)列 */(void)memcpy((void *)pxQueue->pcWriteTo, pvItemToQueue, (size_t)pxQueue->uxItemSize);/* 將隊(duì)列項(xiàng)寫入指針向后偏移一個(gè)隊(duì)列項(xiàng) */pxQueue->pcWriteTo += pxQueue->uxItemSize;/* 隊(duì)列項(xiàng)寫入指針已經(jīng)偏移到隊(duì)列尾部了 */if(pxQueue->pcWriteTo >= pxQueue->u.xQueue.pcTail){/* 將隊(duì)列項(xiàng)寫入指針偏移到頭部 */pxQueue->pcWriteTo = pxQueue->pcHead;}else{mtCOVERAGE_TEST_MARKER();}}/* 隊(duì)列項(xiàng)大小不為0,從隊(duì)列頭部插入/覆蓋插入 */else{/* 將隊(duì)列項(xiàng)插入隊(duì)列 */(void)memcpy((void *)pxQueue->u.xQueue.pcReadFrom, pvItemToQueue, (size_t)pxQueue->uxItemSize);/* 將隊(duì)列項(xiàng)讀出指針向前偏移一個(gè)隊(duì)列項(xiàng) */pxQueue->u.xQueue.pcReadFrom -= pxQueue->uxItemSize;/* 隊(duì)列項(xiàng)讀出指針已經(jīng)偏移到隊(duì)列頭部了 */if(pxQueue->u.xQueue.pcReadFrom < pxQueue->pcHead){/* 將隊(duì)列項(xiàng)讀出指針偏移到尾部 */pxQueue->u.xQueue.pcReadFrom = (pxQueue->u.xQueue.pcTail - pxQueue->uxItemSize);}else{mtCOVERAGE_TEST_MARKER();}/* 覆蓋式插入 */if(xPosition == queueOVERWRITE){/* 隊(duì)列項(xiàng)個(gè)數(shù)大于0 */if(uxMessagesWaiting > (UBaseType_t)0){/* 因?yàn)楦采w了一個(gè)隊(duì)列項(xiàng),所以隊(duì)列項(xiàng)數(shù)減一 */--uxMessagesWaiting;}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}}/* 隊(duì)列項(xiàng)數(shù)加一 */pxQueue->uxMessagesWaiting = uxMessagesWaiting + (UBaseType_t)1;return xReturn; }

?

?

創(chuàng)建遞歸互斥鎖

遞歸互斥鎖和互斥鎖的創(chuàng)建過(guò)程是一樣的,只是互斥鎖的類型不同

#define xSemaphoreCreateMutex() xQueueCreateMutex(queueQUEUE_TYPE_MUTEX)

?

?

獲取遞歸互斥鎖

和互斥鎖不同的是,同一任務(wù)可以多次獲取遞歸互斥鎖。因此,主要步驟為:

1.如果當(dāng)前任務(wù)不持有該互斥鎖,則申請(qǐng)持有互斥鎖,遞歸次數(shù)加一

2.如果當(dāng)前任務(wù)已經(jīng)持有該互斥鎖,則直接遞歸次數(shù)加一?

/* 獲取遞歸互斥鎖 */ BaseType_t xQueueTakeMutexRecursive(QueueHandle_t xMutex, TickType_t xTicksToWait) {BaseType_t xReturn;Queue_t *const pxMutex = (Queue_t *)xMutex;configASSERT(pxMutex);traceTAKE_MUTEX_RECURSIVE(pxMutex);/* 互斥鎖持有者為當(dāng)前任務(wù) */if(pxMutex->u.xSemaphore.xMutexHolder == xTaskGetCurrentTaskHandle()){/* 遞歸次數(shù)加一 */(pxMutex->u.xSemaphore.uxRecursiveCallCount)++;xReturn = pdPASS;}/* 互斥鎖持有者不為當(dāng)前任務(wù) */else{/* 持有該互斥鎖 */xReturn = xQueueSemaphoreTake(pxMutex, xTicksToWait);if(xReturn != pdFAIL){/* 遞歸次數(shù)加一 */(pxMutex->u.xSemaphore.uxRecursiveCallCount)++;}else{traceTAKE_MUTEX_RECURSIVE_FAILED(pxMutex);}}return xReturn; }

?

?

釋放遞歸互斥鎖

和互斥鎖不同的是,同一任務(wù)可以多次獲取遞歸互斥鎖,解除同等次數(shù)才能徹底釋放。因此,主要步驟為:

1.遞歸次數(shù)減一

2.當(dāng)遞歸次數(shù)減完,徹底釋放互斥鎖

/* 釋放遞歸互斥鎖 */ BaseType_t xQueueGiveMutexRecursive(QueueHandle_t xMutex) {BaseType_t xReturn;Queue_t *const pxMutex = (Queue_t *)xMutex;configASSERT(pxMutex);/* 互斥鎖持有者為當(dāng)前任務(wù) */if(pxMutex->u.xSemaphore.xMutexHolder == xTaskGetCurrentTaskHandle()){traceGIVE_MUTEX_RECURSIVE(pxMutex);/* 遞歸次數(shù)減一 */(pxMutex->u.xSemaphore.uxRecursiveCallCount)--;/* 遞歸次數(shù)減到0 */if(pxMutex->u.xSemaphore.uxRecursiveCallCount == (UBaseType_t)0){/* 徹底釋放互斥鎖 */(void)xQueueGenericSend(pxMutex, NULL, queueMUTEX_GIVE_BLOCK_TIME, queueSEND_TO_BACK);}else{mtCOVERAGE_TEST_MARKER();}xReturn = pdPASS;}/* 互斥鎖持有者不為當(dāng)前任務(wù),直接返回錯(cuò)誤 */else{xReturn = pdFAIL;traceGIVE_MUTEX_RECURSIVE_FAILED(pxMutex);}return xReturn; }

?

?

優(yōu)先級(jí)繼承和剝奪

從上面的分析,我們知道優(yōu)先級(jí)繼承和剝奪函數(shù)如下

優(yōu)先級(jí)繼承:xTaskPriorityInherit

互斥鎖阻塞超時(shí)后,恢復(fù)優(yōu)先級(jí):prvGetDisinheritPriorityAfterTimeout和vTaskPriorityDisinheritAfterTimeout

解放互斥鎖,恢復(fù)優(yōu)先級(jí):xTaskPriorityDisinherit

?

下面我們一個(gè)一個(gè)來(lái)分析,首先是xTaskPriorityInherit

1.當(dāng)前任務(wù)優(yōu)先級(jí)和互斥鎖持有任務(wù)優(yōu)先級(jí)進(jìn)行比較,將互斥鎖持有任務(wù)的優(yōu)先級(jí)更新為更高的那個(gè)優(yōu)先級(jí)

2.將互斥鎖持有任務(wù)按照新的優(yōu)先級(jí)重新放到就緒列表中

/* 任務(wù)優(yōu)先級(jí)繼承 */ BaseType_t xTaskPriorityInherit(TaskHandle_t const pxMutexHolder) {TCB_t *const pxMutexHolderTCB = pxMutexHolder;BaseType_t xReturn = pdFALSE;/* 互斥鎖持有者不為空 */if(pxMutexHolder != NULL){/* 互斥鎖持有者優(yōu)先級(jí)小于當(dāng)前任務(wù)優(yōu)先級(jí) */if(pxMutexHolderTCB->uxPriority < pxCurrentTCB->uxPriority){/* 將互斥鎖持有者的事件列表項(xiàng)值(任務(wù)優(yōu)先級(jí))設(shè)置為當(dāng)前任務(wù)事件列表項(xiàng)值(任務(wù)優(yōu)先級(jí)) */if((listGET_LIST_ITEM_VALUE(&(pxMutexHolderTCB->xEventListItem)) & taskEVENT_LIST_ITEM_VALUE_IN_USE) == 0UL){listSET_LIST_ITEM_VALUE(&(pxMutexHolderTCB->xEventListItem), (TickType_t)configMAX_PRIORITIES - (TickType_t)pxCurrentTCB->uxPriority);}else{mtCOVERAGE_TEST_MARKER();}/* 判斷互斥鎖持有者是否就緒,就緒 */if(listIS_CONTAINED_WITHIN(&(pxReadyTasksLists[pxMutexHolderTCB->uxPriority]), &(pxMutexHolderTCB->xStateListItem)) != pdFALSE){/* 將互斥鎖持有者從就緒列表中移除,移除完后列表中沒(méi)有任務(wù) */if(uxListRemove(&(pxMutexHolderTCB->xStateListItem)) == (UBaseType_t)0){/* 檢查就緒列表中是否有任務(wù),如果沒(méi)有將該優(yōu)先級(jí)從當(dāng)前任務(wù)優(yōu)先級(jí)記錄中清除 */taskRESET_READY_PRIORITY(pxMutexHolderTCB->uxPriority);}else{mtCOVERAGE_TEST_MARKER();}/* 互斥鎖持有者優(yōu)先級(jí)設(shè)置為當(dāng)前任務(wù)優(yōu)先級(jí) */pxMutexHolderTCB->uxPriority = pxCurrentTCB->uxPriority;/* 將互斥鎖持有者重新插入新優(yōu)先級(jí)的就緒列表中 */prvAddTaskToReadyList(pxMutexHolderTCB);}/* 互斥鎖持有者并不在就緒態(tài) */else{/* 互斥鎖持有者優(yōu)先級(jí)設(shè)置為當(dāng)前任務(wù)優(yōu)先級(jí) */pxMutexHolderTCB->uxPriority = pxCurrentTCB->uxPriority;}traceTASK_PRIORITY_INHERIT(pxMutexHolderTCB, pxCurrentTCB->uxPriority);/* 返回繼承了優(yōu)先級(jí) */xReturn = pdTRUE;}/* 互斥鎖持有者優(yōu)先級(jí)不小于當(dāng)前任務(wù)優(yōu)先級(jí) */else{/* 互斥鎖持有者基礎(chǔ)優(yōu)先級(jí)小于當(dāng)前任務(wù)優(yōu)先級(jí),說(shuō)明繼承了其它任務(wù)優(yōu)先級(jí) */if(pxMutexHolderTCB->uxBasePriority < pxCurrentTCB->uxPriority){/* 返回繼承了優(yōu)先級(jí) */xReturn = pdTRUE;}/* 沒(méi)有繼承優(yōu)先級(jí) */else{mtCOVERAGE_TEST_MARKER();}}}else{mtCOVERAGE_TEST_MARKER();}return xReturn; }

?

prvGetDisinheritPriorityAfterTimeout和vTaskPriorityDisinheritAfterTimeout

用法

UBaseType_t uxHighestWaitingPriority;/* 獲取剩下所有等待互斥鎖任務(wù)的最高優(yōu)先級(jí) */ uxHighestWaitingPriority = prvGetDisinheritPriorityAfterTimeout(pxQueue); /* 超時(shí)之后剝奪繼承優(yōu)先級(jí) */ vTaskPriorityDisinheritAfterTimeout(pxQueue->u.xSemaphore.xMutexHolder, uxHighestWaitingPriority);

prvGetDisinheritPriorityAfterTimeout獲取超時(shí)后可能需要?jiǎng)儕Z的優(yōu)先級(jí)

1.獲取等待互斥鎖阻塞任務(wù)中的最高優(yōu)先級(jí)

/* 獲取剩下所有等待互斥鎖任務(wù)的最高優(yōu)先級(jí) */ static UBaseType_t prvGetDisinheritPriorityAfterTimeout(const Queue_t *const pxQueue) {UBaseType_t uxHighestPriorityOfWaitingTasks;/* 因?yàn)槟貌坏交コ怄i而阻塞的任務(wù)列表不為空 */if(listCURRENT_LIST_LENGTH(&(pxQueue->xTasksWaitingToReceive)) > 0U){/* 獲取隊(duì)列中優(yōu)先級(jí)最高的任務(wù) */uxHighestPriorityOfWaitingTasks = (UBaseType_t)configMAX_PRIORITIES - (UBaseType_t)listGET_ITEM_VALUE_OF_HEAD_ENTRY(&(pxQueue->xTasksWaitingToReceive));}/* 因?yàn)槟貌坏交コ怄i而阻塞的任務(wù)列表為空 */else{/* 最高的優(yōu)先級(jí)為空閑任務(wù)優(yōu)先級(jí) */uxHighestPriorityOfWaitingTasks = tskIDLE_PRIORITY;}return uxHighestPriorityOfWaitingTasks; }

vTaskPriorityDisinheritAfterTimeout超時(shí)后剝奪優(yōu)先級(jí)

1.先計(jì)算剝奪繼承當(dāng)前任務(wù)優(yōu)先級(jí)后,需要重新設(shè)置的繼承優(yōu)先級(jí)

2.檢查互斥鎖持有者的優(yōu)先級(jí)是否繼承自當(dāng)前任務(wù)

3.如果互斥鎖持有者的優(yōu)先級(jí)是否繼承自當(dāng)前任務(wù),那么就需要重新設(shè)置的繼承優(yōu)先級(jí)

4.設(shè)置新的優(yōu)先級(jí),并將互斥鎖持有者從原就緒列表中轉(zhuǎn)移到新的就緒列表中

注意:FreeRTOS中處理的并不完美,如果互斥鎖持有者如果持有不止一把鎖的話,即使互斥鎖持有者的優(yōu)先級(jí)是否繼承自當(dāng)前任務(wù)也不進(jìn)行剝奪,這可能導(dǎo)致互斥鎖的持有任務(wù)優(yōu)先級(jí)并不完全準(zhǔn)確。

/* 超時(shí)之后剝奪繼承優(yōu)先級(jí) */ void vTaskPriorityDisinheritAfterTimeout(TaskHandle_t const pxMutexHolder, UBaseType_t uxHighestPriorityWaitingTask) {TCB_t *const pxTCB = pxMutexHolder;UBaseType_t uxPriorityUsedOnEntry, uxPriorityToUse;const UBaseType_t uxOnlyOneMutexHeld = (UBaseType_t)1;/* 互斥鎖持有者不為空 */if(pxMutexHolder != NULL){configASSERT(pxTCB->uxMutexesHeld);/* 互斥鎖持有者基礎(chǔ)優(yōu)先級(jí)小于等待持有互斥鎖任務(wù)的最高優(yōu)先級(jí),說(shuō)明需要繼承優(yōu)先級(jí) */if(pxTCB->uxBasePriority < uxHighestPriorityWaitingTask){/* 將要被設(shè)置的優(yōu)先級(jí) */uxPriorityToUse = uxHighestPriorityWaitingTask;}/* 不需要繼承優(yōu)先級(jí) */else{/* 將要被設(shè)置的優(yōu)先級(jí) */uxPriorityToUse = pxTCB->uxBasePriority;}/* 互斥鎖持有者優(yōu)先級(jí)不等于剩下任務(wù)最高優(yōu)先級(jí),說(shuō)明之前互斥鎖持有者優(yōu)先級(jí)繼承于當(dāng)前任務(wù) */if(pxTCB->uxPriority != uxPriorityToUse){/* 互斥鎖持有者只持有一個(gè)互斥鎖 */if(pxTCB->uxMutexesHeld == uxOnlyOneMutexHeld){configASSERT(pxTCB != pxCurrentTCB);traceTASK_PRIORITY_DISINHERIT(pxTCB, pxTCB->uxBasePriority);/* 保存任務(wù)優(yōu)先級(jí) */uxPriorityUsedOnEntry = pxTCB->uxPriority;/* 互斥鎖持有者優(yōu)先級(jí)設(shè)置為剩下等待互斥鎖任務(wù)的最高優(yōu)先級(jí) */pxTCB->uxPriority = uxPriorityToUse;/* 將事件列表值也改成剩下等待互斥鎖任務(wù)的最高優(yōu)先級(jí) */if((listGET_LIST_ITEM_VALUE(&(pxTCB->xEventListItem)) & taskEVENT_LIST_ITEM_VALUE_IN_USE) == 0UL){listSET_LIST_ITEM_VALUE(&(pxTCB->xEventListItem), (TickType_t)configMAX_PRIORITIES - (TickType_t)uxPriorityToUse);}else{mtCOVERAGE_TEST_MARKER();}/* 把任務(wù)從當(dāng)前就緒列表中移除 */if(listIS_CONTAINED_WITHIN(&(pxReadyTasksLists[uxPriorityUsedOnEntry] ), &(pxTCB->xStateListItem)) != pdFALSE){if(uxListRemove(&(pxTCB->xStateListItem)) == (UBaseType_t)0){taskRESET_READY_PRIORITY(pxTCB->uxPriority);}else{mtCOVERAGE_TEST_MARKER();}/* 重新添加到新優(yōu)先級(jí)就緒列表中 */prvAddTaskToReadyList(pxTCB);}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();} }

?

xTaskPriorityDisinherit,剝奪優(yōu)先級(jí)繼承

1.先判斷是否繼承了優(yōu)先級(jí)

2.如果繼承了優(yōu)先級(jí),恢復(fù)基礎(chǔ)優(yōu)先級(jí),并將任務(wù)根據(jù)新優(yōu)先級(jí)從原就緒列表中轉(zhuǎn)移到新的就緒列表

注意:FreeRTOS中處理的并不完美,如果互斥鎖持有者如果持有不止一把鎖的話,并不會(huì)剝奪繼承優(yōu)先級(jí),這可能導(dǎo)致互斥鎖的持有任務(wù)優(yōu)先級(jí)并不完全準(zhǔn)確。

/* 剝奪繼承優(yōu)先級(jí) */ BaseType_t xTaskPriorityDisinherit(TaskHandle_t const pxMutexHolder) {TCB_t *const pxTCB = pxMutexHolder;BaseType_t xReturn = pdFALSE;/* 互斥鎖持有者不為空 */if(pxMutexHolder != NULL){configASSERT(pxTCB == pxCurrentTCB);configASSERT(pxTCB->uxMutexesHeld);/* 任務(wù)持有鎖數(shù)量減一 */(pxTCB->uxMutexesHeld)--;/* 任務(wù)優(yōu)先級(jí)不等于基礎(chǔ)優(yōu)先級(jí),說(shuō)明繼承了優(yōu)先級(jí) */if(pxTCB->uxPriority != pxTCB->uxBasePriority){/* 任務(wù)持有鎖數(shù)量為0 */if(pxTCB->uxMutexesHeld == (UBaseType_t)0){/* 將互斥鎖持有者從就緒列表中移除 */if(uxListRemove(&(pxTCB->xStateListItem)) == (UBaseType_t)0){/* 檢查就緒列表中是否有任務(wù),如果沒(méi)有將該優(yōu)先級(jí)從當(dāng)前任務(wù)優(yōu)先級(jí)記錄中清除 */taskRESET_READY_PRIORITY(pxTCB->uxPriority);}else{mtCOVERAGE_TEST_MARKER();}traceTASK_PRIORITY_DISINHERIT(pxTCB, pxTCB->uxBasePriority);/* 將任務(wù)優(yōu)先級(jí)復(fù)原為基礎(chǔ)優(yōu)先級(jí) */pxTCB->uxPriority = pxTCB->uxBasePriority;/* 將事件列表項(xiàng)值重新設(shè)為基礎(chǔ)優(yōu)先級(jí)值 */listSET_LIST_ITEM_VALUE(&(pxTCB->xEventListItem), (TickType_t)configMAX_PRIORITIES - (TickType_t)pxTCB->uxPriority);/* 將任務(wù)重新加入新優(yōu)先級(jí)任務(wù)列表 */prvAddTaskToReadyList(pxTCB);xReturn = pdTRUE;}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}}else{mtCOVERAGE_TEST_MARKER();}return xReturn; }

?

?

總結(jié)

以上是生活随笔為你收集整理的FreeRTOS互斥锁的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

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

91精品国自产在线观看 | 日本久久久久久久久久 | 免费观看的av | 色天天久久 | 国产亚洲精品久久久久久 | 国产精品成人国产乱 | 国产高清成人av | 午夜精品福利一区二区三区蜜桃 | 婷婷伊人综合亚洲综合网 | 亚洲第一av在线播放 | 国产日韩欧美综合在线 | 亚洲综合婷婷 | 久久精品视频在线观看 | 成人午夜毛片 | 亚洲欧美视频在线 | 韩国av一区二区三区 | 五月天堂网 | 黄色aaa级片 | 热久久在线视频 | 人人插人人射 | 色婷婷六月 | 色福利网站 | 精品美女久久久久久免费 | 丝袜av网站 | 国产精品国产亚洲精品看不卡 | 操高跟美女 | 中文字幕高清免费日韩视频在线 | 精品嫩模福利一区二区蜜臀 | 日韩欧美在线观看一区二区三区 | 人人爱人人做人人爽 | 久久国产品 | 伊人网综合在线观看 | 色诱亚洲精品久久久久久 | 国产精品久久久久9999 | 国产精品美女久久久久久久 | 992tv在线成人免费观看 | 中文字幕av在线 | 在线观看黄色av | 在线观看的av网站 | 久久久午夜精品福利内容 | 天天色天天爱天天射综合 | 一区二区亚洲精品 | 91精品国产自产在线观看 | 日韩电影中文,亚洲精品乱码 | 免费三级影片 | 久久艹艹 | 99国产视频| 日本久久久久久科技有限公司 | 五月天婷婷在线播放 | 99成人免费视频 | 人人干人人做 | 免费视频久久久 | 国产成人777777 | 亚洲视频一 | 亚洲1区 在线 | 97涩涩视频| 国产精品免费一区二区三区 | 婷婷伊人五月 | a色视频 | 久久综合色播五月 | 亚洲色图激情文学 | 欧美性做爰猛烈叫床潮 | 免费福利视频导航 | 欧美日韩视频在线一区 | 久草视频在线资源 | 美女视频黄免费 | 久久成| 五月婷婷丁香在线观看 | 国产专区欧美专区 | 国产视频一区二区三区在线 | 91在线九色| 精品久久久久久久久久 | 349k.cc看片app | 夜色资源站国产www在线视频 | 日韩影片在线观看 | 91视频高清免费 | 国产免费片 | 日韩欧美电影网 | 在线看片一区 | 亚洲国产免费网站 | 亚洲成人精品在线 | 久久国产精品久久久 | 久久视频免费在线观看 | 国产成人一区二区三区在线观看 | 美国av片在线观看 | 亚在线播放中文视频 | 国产系列 在线观看 | 麻豆系列在线观看 | 全久久久久久久久久久电影 | 国产精品毛片久久 | 久久久久久久久免费视频 | 精品欧美小视频在线观看 | 91亚色在线观看 | 午夜色场 | 九九九九精品 | 一区二区三区观看 | 国产福利小视频在线 | 福利一区在线 | 免费视频在线观看网站 | www.久热| 久久99热国产 | 免费在线一区二区 | 六月丁香激情综合 | 久久国产精品久久精品国产演员表 | 91看成人 | 免费日韩一区二区 | 一区二区精品在线观看 | 国产原创在线观看 | 成人综合婷婷国产精品久久免费 | 中中文字幕av在线 | 久久综合综合久久综合 | 国产一区免费观看 | 中文字幕av在线不卡 | 日韩精品无码一区二区三区 | 视频在线观看91 | 亚洲精品伦理在线 | 高清中文字幕 | 可以免费看av| 成人免费观看在线视频 | 久久精品一 | 天天干夜夜夜操天 | 黄色一级免费网站 | 91天堂素人约啪 | 麻豆果冻剧传媒在线播放 | 久久免费播放视频 | 国产高清不卡在线 | 午夜精品电影一区二区在线 | 99久热在线精品视频 | 亚洲精品裸体 | 九九色在线观看 | www亚洲精品 | 久草精品在线播放 | 欧美日韩国产综合一区二区 | 伊人国产女 | 中文乱幕日产无线码1区 | 精品91在线 | 久久精品国产成人 | 国产伦精品一区二区三区照片91 | 香蕉手机在线 | 九草在线观看 | 日韩av一区二区三区四区 | 高清av网 | 国产精品久久久久久婷婷天堂 | 91精品国自产在线偷拍蜜桃 | 伊人五月天.com | 日韩中文字幕在线观看 | 色综合久久精品 | 久久久久久免费 | 成片免费观看视频大全 | 久久精品免费观看 | 久久亚洲视频 | 国内精品久久久久影院优 | 香蕉视频在线网站 | 在线激情影院一区 | 91色在线观看视频 | 国产一区二区三区四区大秀 | 国产精品婷婷午夜在线观看 | 日韩精品一区二区三区免费视频观看 | 深爱婷婷网 | 特级毛片在线 | 91在线精品视频 | 日韩高清www | 国产精品18毛片一区二区 | www.午夜视频 | 三级午夜片 | 这里只有精品视频在线 | 色www精品视频在线观看 | 日韩特级黄色片 | 香蕉久草在线 | 国产亚洲高清视频 | 不卡的av在线| www国产亚洲| 国产亚州精品视频 | 国产一区二区在线精品 | 国产一区电影在线观看 | av爱干| 亚洲精品久久久蜜臀下载官网 | 中文字幕一区二区三区乱码不卡 | 亚洲黄色一级视频 | 日本三级香港三级人妇99 | 91精品国自产在线观看 | 久久久久久美女 | 九九热在线观看 | 国产精品久久久久免费a∨ 欧美一级性生活片 | 精品不卡av | 久久精品视频3 | 国产日本在线观看 | 97免费在线视频 | 丁香花中文在线免费观看 | 黄污视频网站大全 | 精品久久国产精品 | 丁香综合网 | 国产免费又粗又猛又爽 | 日韩欧美高清在线观看 | 91在线在线观看 | 国产亚洲婷婷免费 | 在线播放 日韩专区 | 国产精品乱码久久久 | 久久伦理 | 久久久不卡影院 | 中文字幕乱码日本亚洲一区二区 | 毛片99| 国产精品美女久久久久久久 | 久久久伊人网 | 中文字幕免费观看 | 一区二区三区在线视频观看58 | 黄色国产精品 | 国产又粗又猛又爽又黄的视频先 | 欧美一级艳片视频免费观看 | 欧美精品中文在线免费观看 | 99精品系列 | 亚洲精品女人久久久 | 特级黄色片免费看 | av 一区二区三区四区 | 免费在线观看成人av | 精品国产网址 | 国产成人精品午夜在线播放 | 毛片网站免费 | 夜夜操综合网 | 国产精品手机在线观看 | 国产又粗又猛又爽又黄的视频先 | 国产高清永久免费 | 特级西西www44高清大胆图片 | 久久国产精品免费观看 | 97在线看片 | 国产日韩精品在线观看 | 国产v在线 | 成人久久18免费网站图片 | 亚洲欧美乱综合图片区小说区 | 久久免费视频在线观看6 | 国产精品 亚洲精品 | 成人国产一区二区 | 91成人在线免费观看 | 国产精彩视频一区二区 | 国产色婷婷 | 91精品一区二区三区蜜桃 | 亚洲专区视频在线观看 | 91精品久久久久久久久久久久久 | 婷婷四房综合激情五月 | 黄色a大片 | 亚洲在线网址 | www.夜夜爱 | 国产精品高清一区二区三区 | 91黄色在线观看 | 91干干干| 又黄又爽又刺激视频 | 激情一区二区三区欧美 | 亚洲黄在线观看 | 97超碰网| 久久久免费高清视频 | 日本久久91| 日韩高清 一区 | 99精品在这里 | 久久亚洲精品国产亚洲老地址 | 国产在线观看网站 | 欧美日韩免费一区二区三区 | 天堂av高清 | 久久久久97国产 | 99一级片 | 国产精品欧美日韩 | 五月天丁香视频 | 超碰国产在线观看 | 在线观看中文字幕一区二区 | 国产精品久久久久一区二区国产 | 成人在线播放av | 亚洲成a人片77777kkkk1在线观看 | 色五月色开心色婷婷色丁香 | 久操免费视频 | 97成人在线观看 | 探花视频在线观看+在线播放 | 免费在线a | 黄色av观看 | 最近中文字幕国语免费高清6 | 国产精品自产拍在线观看蜜 | 久草在线综合 | 特级xxxxx欧美 | 成人试看120秒 | 天天干天天摸天天操 | a级片在线播放 | 婷婷激情综合网 | 色狠狠综合天天综合综合 | 日日射天天射 | 成人va视频 | 日韩免费精品 | 在线一二三区 | 亚洲午夜久久久影院 | 亚洲成人黄色av | 五月激情综合婷婷 | 国产精品9999久久久久仙踪林 | 超碰在线色 | 国产成人精品免费在线观看 | 夜夜躁日日躁狠狠久久av | 亚洲经典中文字幕 | 国产精品日韩在线播放 | 成年人黄色免费网站 | av成人免费网站 | 香蕉网站在线观看 | 亚洲精品午夜aaa久久久 | 国产精品免费视频网站 | 亚洲午夜精品久久久久久久久久久久 | 国产精品自产拍在线观看桃花 | 麻豆视频免费在线播放 | 欧美日韩国产一二三区 | 国产在线一线 | 久久人人插| 久久久久影视 | 最近更新的中文字幕 | 波多野结衣久久资源 | 日韩在线免费不卡 | 美女视频黄的免费的 | 中国一 片免费观看 | 丁香5月婷婷久久 | 激情中文字幕 | 夜夜骑首页 | 蜜臀久久99精品久久久久久网站 | 日韩在线观看视频一区二区三区 | 亚洲资源一区 | 久久精品免费电影 | 亚洲精品国产精品99久久 | 精品一二三区视频 | 国产原创av片 | 国产一区二区久久精品 | 最近免费中文视频 | 国产xvideos免费视频播放 | 天天操综合 | 青青草国产精品 | 天天综合天天综合 | 色九色| 91免费版成人 | 国产欧美日韩视频 | 久草在线中文888 | 精品国产成人av在线免 | 色久综合 | 亚洲精品久久激情国产片 | 亚洲欧美一区二区三区孕妇写真 | 久草在线免费新视频 | 久久久久久久久久久久久国产精品 | 操操日日 | 日韩欧美在线国产 | 欧美另类一二三四区 | 国产色网站 | 久久久国产电影 | 麻豆视频免费版 | 天天天天色综合 | 综合中文字幕 | 在线观看免费一区 | 五月开心六月婷婷 | 国产午夜精品免费一区二区三区视频 | 又黄又色又爽 | 久久国产视屏 | 国产视频精品视频 | 91麻豆精品国产91久久久无限制版 | 在线免费视频 你懂得 | 国产96在线 | 久久综合色天天久久综合图片 | 日韩av免费在线电影 | av电影中文字幕 | 久久最新网址 | 亚洲va综合va国产va中文 | 激情久久久久久久久久久久久久久久 | 日韩久久精品一区二区三区 | 亚洲国产成人精品电影在线观看 | 国产69久久精品成人看 | 国产免费国产 | 国产精品福利在线 | 亚洲成人av在线电影 | 久久久久国产成人免费精品免费 | 免费观看性生活大片3 | 天天操夜夜看 | 天天操天天操天天操天天 | 日韩电影在线视频 | 麻豆视频入口 | 久草免费在线 | 国产成人精品女人久久久 | 久久影院一区 | 日韩成人黄色 | 麻豆视频免费在线 | 2019精品手机国产品在线 | 国产精品不卡一区 | 国产一区二区久久久久 | 日本三级在线观看中文字 | 狠狠狠色丁香综合久久天下网 | 久久久色 | 精品国产中文字幕 | 久久久久成人精品 | 精品国产免费一区二区三区五区 | 亚洲精品88欧美一区二区 | 91看片在线免费观看 | 中国精品少妇 | 久久国产高清视频 | 国产一级二级av | 奇米影音四色 | 欧美日韩久久久 | 中文字幕免费高清 | 手机av网站 | 欧美黄在线 | 成人cosplay福利网站 | 欧美精品久久久久久久久久白贞 | 日日夜夜天天久久 | 能在线观看的日韩av | 98超碰在线观看 | 精品国产乱子伦一区二区 | 免费看一及片 | 亚洲激情电影在线 | 色综合色综合色综合 | 亚洲精品国产精品国 | 九九综合久久 | 国产香蕉97碰碰碰视频在线观看 | 91精品在线观看视频 | 久久国产精品影片 | 欧美伦理电影一区二区 | 97国产在线观看 | 欧美性极品xxxx做受 | 国产精品欧美精品 | 国产精品久久久久久吹潮天美传媒 | 日韩v在线| 午夜免费视频网站 | 久久伦理 | 热久精品| av一区二区在线观看中文字幕 | 中文字幕在线观看播放 | 99精品久久99久久久久 | 香蕉影院在线播放 | 日本韩国精品在线 | 久久伊人热| 天天操天天操天天操天天操天天操 | 国产精品无 | 91精品秘密在线观看 | 2018亚洲男人天堂 | 免费观看午夜视频 | 日韩影片在线观看 | 99爱视频在线观看 | 亚洲欧美在线视频免费 | 手机av观看| 国产成人a亚洲精品v | 天天天天综合 | 欧美成人一二区 | 久草网在线| 综合国产在线 | 国产精品 亚洲精品 | 91视频在线免费下载 | 免费久草视频 | 狠狠干网址 | 国产精品手机看片 | 久久精品欧美一 | 日韩在线播放欧美字幕 | 中文字幕日韩有码 | 中文字幕在线色 | 欧美成人播放 | 色橹橹欧美在线观看视频高清 | 日韩午夜在线观看 | 欧美一区在线观看视频 | 久久成年人网站 | 中文字幕在线久一本久 | 香蕉一区| 国产午夜精品理论片在线 | 天天综合色 | 国产精品视频 | 成人性生爱a∨ | 欧美色图亚洲图片 | 中文字幕观看视频 | 免费在线成人av | 一本一道久久a久久精品 | 日韩中文字幕视频在线 | 插插插色综合 | 视频一区亚洲 | 69人人| 精品美女久久 | 天天爱天天操天天干 | 成人激情开心网 | 日日夜夜婷婷 | 99精品在线 | 在线日韩视频 | 国产精品一区在线观看你懂的 | 99精品在线观看 | 国产不卡在线视频 | 亚洲少妇激情 | 国产午夜在线 | 天天射天天操天天色 | 日韩精品一区二区三区免费观看视频 | 69国产盗摄一区二区三区五区 | 丁香色天天 | 在线小视频你懂的 | 麻豆久久 | 国产视频精品视频 | 在线91播放 | 久在线| 国产综合小视频 | 欧美日韩国产色综合一二三四 | 色噜噜在线观看 | 精品国产1区 | 亚洲精品国产成人av在线 | 在线观看免费中文字幕 | 日日精品 | 天天操夜操视频 | 国产精品久久久久久妇 | 97在线免费观看 | 国产区在线 | 国产一区欧美一区 | 狠狠的干| 免费高清在线一区 | 欧美日韩另类在线观看 | 精品一二区 | 亚洲精品乱码久久 | 国产aa精品| 欧美日韩国产一二三区 | 国产成人久久精品一区二区三区 | 色噜噜日韩精品欧美一区二区 | 国产高清在线一区 | 中文伊人 | 狠狠色丁香久久婷婷综 | 久久久久国产精品免费免费搜索 | 亚洲精品美女在线观看播放 | 成人av在线看 | 精品国产网址 | 亚洲片在线观看 | 日韩欧美xxx | 中文字幕一区二区三区乱码在线 | 国产一级二级三级视频 | 91禁在线看 | 国产偷在线 | 久久激情小说 | 中文字幕观看av | 色中文字幕在线观看 | 午夜精品久久 | 97av在线视频 | 高清精品久久 | 在线高清 | 激情丁香综合五月 | 在线播放 日韩专区 | 毛片网站观看 | 欧美一级乱黄 | 99久热| 91精品一 | 亚洲欧美日本A∨在线观看 青青河边草观看完整版高清 | 成人在线观看免费 | 欧美日韩在线观看一区二区三区 | 免费不卡中文字幕视频 | 欧美a√大片 | 国内精品久久久久久 | 91视频最新网址 | 麻豆精品在线 | 黄色91免费观看 | 日韩在线观看的 | 精品国产乱码久久久久久浪潮 | 在线一区av | 久久精美视频 | 99这里只有精品视频 | 激情综合色图 | 国产经典三级 | 免费高清看电视网站 | 婷婷激情综合五月天 | 在线视频 成人 | 日韩网站免费观看 | 91中文字幕视频 | 国产福利在线免费 | 久久国产乱 | 夜添久久精品亚洲国产精品 | 2021久久| 久久成人午夜视频 | av中文字幕免费在线观看 | 日韩xxxx视频 | 99视频网址 | 久草在在线视频 | 亚洲春色综合另类校园电影 | 久草剧场 | 欧美午夜一区二区福利视频 | 国产精品免费久久久久影院仙踪林 | 亚洲午夜小视频 | 国产偷国产偷亚洲清高 | 在线观看日本高清mv视频 | 99国产精品一区二区 | 岛国片在线 | 中文字幕免费看 | 97精品国产97久久久久久久久久久久 | 免费看片色| 免费色网站| 国产精品毛片 | 午夜av不卡 | 欧美亚洲国产日韩 | 精品久久久久一区二区国产 | 国产高清在线免费 | 国产这里只有精品 | 91精品夜夜 | 亚洲一二区视频 | 夜夜躁日日躁狠狠久久av | 麻豆一区二区 | 国产精品久久久久久久久毛片 | 日韩免费小视频 | 亚a在线 | 狠狠狠色狠狠色综合 | 国产精品系列在线 | 久久久www成人免费毛片 | 日韩激情在线视频 | 欧美极度另类 | 国产精品免费久久久久久 | 91免费在线 | 久久爱资源网 | 精品日韩在线一区 | 99精品在线视频播放 | 色播五月激情综合网 | 色姑娘综合 | 九九天堂 | 国产在线无 | 蜜臀av性久久久久av蜜臀三区 | 亚洲国产精品一区二区久久,亚洲午夜 | 噜噜色官网 | 看片一区二区三区 | 五月婷婷综合在线视频 | 97在线观看 | 国产日韩三级 | av成人在线播放 | 99热这里只有精品国产首页 | 国产精品永久免费在线 | 麻豆视频免费入口 | 国产免费高清视频 | 五月天亚洲精品 | 免费黄色a网站 | 亚洲精品一区二区在线观看 | 久草在线免费电影 | 欧美日韩在线视频一区 | 91女人18片女毛片60分钟 | 亚洲视频中文 | 亚洲不卡123| av高清网站在线观看 | 中文字幕在线看视频国产中文版 | 一区二区不卡视频在线观看 | 一区二区三区不卡在线 | 一级成人免费视频 | 免费看国产曰批40分钟 | 欧美日韩精品电影 | 中文字幕免费国产精品 | 在线草| 国产国语在线 | 亚洲成年人免费网站 | 麻花传媒mv免费观看 | av一级一片 | 91成人在线观看高潮 | 免费精品在线观看 | 91在线亚洲 | 免费看一及片 | 人人干人人超 | 亚洲精品五月天 | 精品黄色在线观看 | 五月激情天 | 久久久久久中文字幕 | 日韩欧美精品在线观看 | 在线va网站 | 国产精品手机在线播放 | 欧美日韩精品在线播放 | 亚洲国产精品久久久久 | 亚洲精品自在在线观看 | 久久久久免费精品 | 天天干,夜夜爽 | 免费看一级| 黄色aa久久 | 在线黄网站 | 成全免费观看视频 | 中中文字幕av| www.国产高清 | 国产成人精品av久久 | 国产一级精品在线观看 | 亚洲免费在线观看视频 | 91精品视频播放 | 亚洲小视频在线 | 久久综合色天天久久综合图片 | 91av网址| 成人一区二区三区在线观看 | 久久人人爽爽人人爽人人片av | 中文字幕精品一区 | 国产成人精品日本亚洲999 | 一级一片免费观看 | 视频在线播放国产 | 亚洲精品视频在线观看免费视频 | 日韩精品欧美专区 | 久久激情电影 | 欧美午夜理伦三级在线观看 | 最近最新中文字幕视频 | 色综合久久中文字幕综合网 | 亚洲精品动漫在线 | 午夜电影一区 | 波多野结依在线观看 | 高清视频一区 | 毛片区| 亚洲欧美日韩一区二区三区在线观看 | 黄色在线网站噜噜噜 | 色五月成人 | 中文字幕国产精品一区二区 | 91视频久久久久久 | 婷婷精品国产欧美精品亚洲人人爽 | 一区在线观看 | 日韩一级片观看 | 中文区中文字幕免费看 | 午夜体验区 | 97人人精品 | 国产精品久久久久久久婷婷 | 国产精品激情在线观看 | 狠狠的操狠狠的干 | 国产高清视频在线 | 在线小视频 | 十八岁以下禁止观看的1000个网站 | 国产群p | 98超碰在线 | 欧美性高跟鞋xxxxhd | 国产小视频免费观看 | 亚洲精品国产综合久久 | www国产亚洲精品久久网站 | 欧洲在线免费视频 | 正在播放五月婷婷狠狠干 | 日韩美精品视频 | 精品国产亚洲日本 | 亚州精品天堂中文字幕 | 久久刺激视频 | 在线电影av| 亚洲精品久久久久久久不卡四虎 | 一区二区三区日韩视频在线观看 | 超碰在线97国产 | 日韩中文字幕免费视频 | 免费亚洲精品视频 | 精品999久久久 | 一区中文字幕在线观看 | 天天干天天看 | 91综合久久一区二区 | 国产 日韩 欧美 中文 在线播放 | 日本黄色黄网站 | 在线天堂8√| 久久综合之合合综合久久 | 97视频在线观看成人 | 天天射射天天 | 国产精品观看在线亚洲人成网 | 日韩欧美视频在线观看免费 | 成人资源在线 | 伊人激情网 | 午夜视频在线观看一区二区三区 | 久久国产精品免费一区二区三区 | 91在线免费观看国产 | 亚洲一级久久 | 久久精品这里精品 | 在线观看91网站 | 999成人国产 | 国产福利一区二区三区视频 | 国产精品资源在线 | 久久97久久97精品免视看 | 久久av网址 | 精品一区三区 | 91久久爱热色涩涩 | 永久免费精品视频 | 一本一道久久a久久精品 | 伊人色综合久久天天网 | 99视频偷窥在线精品国自产拍 | 久久精品艹 | 在线日本看片免费人成视久网 | 国产精品久久久久久久久久久免费看 | 狠狠操电影网 | 国产高清成人 | 2024国产精品视频 | 欧美日韩国产综合网 | 免费在线a | 97精品国产91久久久久久 | 国产视频一区精品 | 国产又粗又猛又黄 | 亚洲美女免费精品视频在线观看 | 国产亚洲欧美日韩高清 | 狂野欧美激情性xxxx欧美 | 午夜精品久久久久久久99无限制 | 国产在线精品区 | 人人干人人草 | 亚洲国产操 | 国内外激情视频 | 中文字幕日本电影 | 91精品在线观看视频 | 久久久久久国产精品美女 | 久久看看| 国产精品久久久久久久久大全 | 久久久精品国产一区二区 | 欧美日韩视频免费 | 久久精品亚洲一区二区三区观看模式 | 日韩电影中文字幕在线观看 | 免费美女av | 成人污视频在线观看 | 久草视频在线资源 | 国内丰满少妇猛烈精品播放 | 国产中文字幕在线播放 | 精品国产一区在线观看 | 最近日本字幕mv免费观看在线 | 久久久久久久久久免费视频 | 人人干人人草 | 国产高清精品在线观看 | www免费网站在线观看 | 又紧又大又爽精品一区二区 | 日本在线观看中文字幕无线观看 | 日日射天天射 | 免费看黄在线看 | av品善网 | 久久这里只有精品9 | 成人免费视频视频在线观看 免费 | 国产裸体无遮挡 | 亚州av免费 | 麻豆国产精品一区二区三区 | 久久黄色小说 | 日本在线中文在线 | 黄色视屏av | h网站免费在线观看 | 日韩av影片在线观看 | www.97视频 | 免费成视频 | 欧美一级片免费 | 久久精品国产亚洲精品 | 97超级碰碰碰视频在线观看 | 国产一级二级视频 | 99视频国产精品 | 亚洲黄色高清 | 久草在线免费在线观看 | 日韩中文字幕免费 | 六月久久婷婷 | 碰碰影院| 岛国片在线 | 韩国av不卡 | 精品视频免费久久久看 | 999在线视频| 97精品国产97久久久久久 | 热re99久久精品国产99热 | av在观看| www激情久久 | 三级av黄色 | 免费在线观看av片 | 亚洲色综合 | 免费视频国产 | 久久精品1区2区 | 四虎成人精品永久免费av九九 | 青青草视频精品 | 日本黄色免费电影网站 | 久久天堂亚洲 | 久久精品国产一区二区电影 | 国产原创在线视频 | 国产高清在线视频 | 中文字幕一区av | 国产xvideos免费视频播放 | 天天在线视频色 | 久热国产视频 | 在线观看视频色 | 在线 国产 亚洲 欧美 | 国产乱对白刺激视频不卡 | 午夜久久成人 | 久久国产精品电影 | 日韩黄色免费电影 | 色亚洲网 | 国产亚洲精品久久久久久久久久 | 国产福利午夜 | 99国产免费网址 | 99久久久国产免费 | 亚洲日本韩国一区二区 | 亚洲精品a区 | 国产一区欧美日韩 | 区一区二区三区中文字幕 | 精品国模一区二区三区 | 亚洲人久久 | 97超碰超碰久久福利超碰 | 免费黄在线观看 | 国产精品中文在线 | 操操综合 | 国产精品一区二区在线 | 日韩精品不卡 | 国产黄色免费看 | 99av国产精品欲麻豆 | 欧美午夜视频在线 | 成人资源在线 | 日韩高清在线不卡 | 97人人添人澡人人爽超碰动图 | 国产午夜在线 | 久久久受www免费人成 | 国产一区国产二区在线观看 | 91精品专区 | 亚洲丝袜一区 | 国产精品久久久久婷婷 | 最近最新中文字幕 | 不卡的av在线播放 | 视频国产一区二区三区 | 欧美成人xxxx | 91九色视频在线 | 国产不卡网站 | 人人干在线观看 | 视频国产 | 在线观看日韩精品视频 | 国产精品久久久久久久久软件 | 免费午夜av| 一二区av | 国产一级黄色片免费看 | 欧美精品一二三 | 成人18视频| 美女在线观看网站 | 91三级视频 | 久久影院中文字幕 | 久久精品123 | 三级av在线播放 | 欧美性生活久久 | 亚洲.www| 国产在线观看,日本 | 国产高清综合 | 免费黄色在线网址 | 国产精品专区在线 | www..com黄色片 | 97超碰免费在线 | 天天干天天操天天干 | 在线观看精品一区 | 日韩资源在线观看 | 三三级黄色片之日韩 | 国产999精品久久久久久 | 天堂网中文在线 | 欧美视频网址 | 韩国av免费观看 | 久久香蕉国产精品麻豆粉嫩av | 四虎免费在线观看 | 久久黄色小说 | 丁香九月激情综合 | 国产区 在线 | 亚洲久草网 | 国产xvideos免费视频播放 | 国产精品美女久久久免费 | 亚洲精品在线一区二区 | 片黄色毛片黄色毛片 | 久久久精品日本 | 97超碰人人模人人人爽人人爱 | 日韩精品一二三 | 99精品在线免费在线观看 | 菠萝菠萝蜜在线播放 | 天天摸天天干天天操天天射 | 在线国产欧美 | 五月花婷婷 | 999精品 | 五月天狠狠操 | 黄色毛片在线 | 四虎影视成人精品国库在线观看 | 美女一二三区 | av官网 | a在线免费 | 色婷婷亚洲精品 | 国产成人在线免费观看 | 在线观看亚洲视频 | 97超碰人人澡人人 | 久久精品国产精品亚洲 | 成人午夜性影院 | 久久www免费人成看片高清 | 久久九九精品 | 国产69精品久久久久99尤 | 不卡的av电影在线观看 | 91高清不卡 | 欧美老人xxxx18 | 亚洲成人动漫在线观看 | 国产精品色在线 | 天堂在线视频中文网 | 在线观看免费高清视频大全追剧 | 国产中文字幕大全 | 日韩精品视频免费专区在线播放 | 综合色站导航 | 激情欧美丁香 | 国产在线欧美 | 91麻豆精品久久久久久 | 久久综合婷婷 | 啪啪凸凸| 久久免费视频7 | 久久久久久久久久久免费视频 | 婷婷精品国产一区二区三区日韩 | 日日夜夜天天操 | 超级av在线 | 久久综合欧美精品亚洲一区 | 欧美日韩一区二区三区不卡 | 国产精品视频大全 | 国产一级大片免费看 | 91超国产 | 日韩动漫免费观看高清完整版在线观看 | 国产色视频一区二区三区qq号 | 99视频黄| 成人在线免费观看网站 | 色妞久久福利网 | 欧美日韩69| 美女在线免费视频 | 天天舔夜夜操 | 欧美aaa级片 | 97精品国产97久久久久久春色 | 国产成人精品免高潮在线观看 | a在线观看国产 | 91精品国产高清自在线观看 | 亚洲一区网 | 99在线免费观看 | 成人免费观看视频网站 | 成人在线免费小视频 | 亚洲国产网站 | 日韩av网页 | 久草电影网 | 久久精品专区 | 中文字幕视频网站 | 2021av在线| 五月激情视频 | 日韩a免费 | 99电影 | 成人免费在线观看入口 | 中文字幕乱码电影 |