亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? queue.c

?? Modbus協(xié)議的源代碼 Modbus協(xié)議的源代碼、 Modbus協(xié)議的源代碼 Modbus協(xié)議的源代碼
?? C
?? 第 1 頁 / 共 3 頁
字號:
static void prvUnlockQueue( xQueueHandle pxQueue )

{

	/* THIS FUNCTION MUST BE CALLED WITH THE SCHEDULER SUSPENDED. */



	/* The lock counts contains the number of extra data items placed or

	removed from the queue while the queue was locked.  When a queue is

	locked items can be added or removed, but the event lists cannot be

	updated. */

	taskENTER_CRITICAL();

	{

		--( pxQueue->xTxLock );



		/* See if data was added to the queue while it was locked. */

		if( pxQueue->xTxLock > queueUNLOCKED )

		{

			pxQueue->xTxLock = queueUNLOCKED;



			/* Data was posted while the queue was locked.  Are any tasks

			blocked waiting for data to become available? */

			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) )

			{

				/* Tasks that are removed from the event list will get added to

				the pending ready list as the scheduler is still suspended. */

				if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

				{

					/* The task waiting has a higher priority so record that a

					context	switch is required. */

					vTaskMissedYield();

				}

			}			

		}

	}

	taskEXIT_CRITICAL();



	/* Do the same for the Rx lock. */

	taskENTER_CRITICAL();

	{

		--( pxQueue->xRxLock );



		if( pxQueue->xRxLock > queueUNLOCKED )

		{

			pxQueue->xRxLock = queueUNLOCKED;



			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) )

			{

				if( xTaskRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

				{

					vTaskMissedYield();

				}

			}			

		}

	}

	taskEXIT_CRITICAL();

}

/*-----------------------------------------------------------*/



static signed portBASE_TYPE prvIsQueueEmpty( const xQueueHandle pxQueue )

{

signed portBASE_TYPE xReturn;



	taskENTER_CRITICAL();

		xReturn = ( pxQueue->uxMessagesWaiting == ( unsigned portBASE_TYPE ) 0 );

	taskEXIT_CRITICAL();



	return xReturn;

}

/*-----------------------------------------------------------*/



static signed portBASE_TYPE prvIsQueueFull( const xQueueHandle pxQueue )

{

signed portBASE_TYPE xReturn;



	taskENTER_CRITICAL();

		xReturn = ( pxQueue->uxMessagesWaiting == pxQueue->uxLength );

	taskEXIT_CRITICAL();



	return xReturn;

}

/*-----------------------------------------------------------*/



#if configUSE_CO_ROUTINES == 1

signed portBASE_TYPE xQueueCRSend( xQueueHandle pxQueue, const void *pvItemToQueue, portTickType xTicksToWait )

{

signed portBASE_TYPE xReturn;

		

	/* If the queue is already full we may have to block.  A critical section

	is required to prevent an interrupt removing something from the queue 

	between the check to see if the queue is full and blocking on the queue. */

	portDISABLE_INTERRUPTS();

	{

		if( prvIsQueueFull( pxQueue ) )

		{

			/* The queue is full - do we want to block or just leave without

			posting? */

			if( xTicksToWait > ( portTickType ) 0 )

			{

				/* As this is called from a coroutine we cannot block directly, but

				return indicating that we need to block. */

				vCoRoutineAddToDelayedList( xTicksToWait, &( pxQueue->xTasksWaitingToSend ) );				

				portENABLE_INTERRUPTS();

				return errQUEUE_BLOCKED;

			}

			else

			{

				portENABLE_INTERRUPTS();

				return errQUEUE_FULL;

			}

		}

	}

	portENABLE_INTERRUPTS();

		

	portNOP();



	portDISABLE_INTERRUPTS();

	{

		if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

		{

			/* There is room in the queue, copy the data into the queue. */			

			prvCopyQueueData( pxQueue, pvItemToQueue );		

			xReturn = pdPASS;



			/* Were any co-routines waiting for data to become available? */

			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) )

			{

				/* In this instance the co-routine could be placed directly 

				into the ready list as we are within a critical section.  

				Instead the same pending ready list mechansim is used as if

				the event were caused from within an interrupt. */

				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

				{

					/* The co-routine waiting has a higher priority so record 

					that a yield might be appropriate. */

					xReturn = errQUEUE_YIELD;

				}

			}

		}

		else

		{

			xReturn = errQUEUE_FULL;

		}

	}

	portENABLE_INTERRUPTS();



	return xReturn;

}

#endif

/*-----------------------------------------------------------*/



#if configUSE_CO_ROUTINES == 1

signed portBASE_TYPE xQueueCRReceive( xQueueHandle pxQueue, void *pvBuffer, portTickType xTicksToWait )

{

signed portBASE_TYPE xReturn;



	/* If the queue is already empty we may have to block.  A critical section

	is required to prevent an interrupt adding something to the queue 

	between the check to see if the queue is empty and blocking on the queue. */

	portDISABLE_INTERRUPTS();

	{

		if( prvIsQueueEmpty( pxQueue ) )

		{

			/* There are no messages in the queue, do we want to block or just

			leave with nothing? */			

			if( xTicksToWait > ( portTickType ) 0 )

			{

				/* As this is a co-routine we cannot block directly, but return

				indicating that we need to block. */

				vCoRoutineAddToDelayedList( xTicksToWait, &( pxQueue->xTasksWaitingToReceive ) );

				portENABLE_INTERRUPTS();

				return errQUEUE_BLOCKED;

			}

			else

			{

				portENABLE_INTERRUPTS();

				return errQUEUE_FULL;

			}

		}

	}

	portENABLE_INTERRUPTS();



	portNOP();



	portDISABLE_INTERRUPTS();

	{

		if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

		{

			/* Data is available from the queue. */

			pxQueue->pcReadFrom += pxQueue->uxItemSize;

			if( pxQueue->pcReadFrom >= pxQueue->pcTail )

			{

				pxQueue->pcReadFrom = pxQueue->pcHead;

			}

			--( pxQueue->uxMessagesWaiting );

			memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->pcReadFrom, ( unsigned ) pxQueue->uxItemSize );



			xReturn = pdPASS;



			/* Were any co-routines waiting for space to become available? */

			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) )

			{

				/* In this instance the co-routine could be placed directly 

				into the ready list as we are within a critical section.  

				Instead the same pending ready list mechansim is used as if

				the event were caused from within an interrupt. */

				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

				{

					xReturn = errQUEUE_YIELD;

				}

			}	

		}

		else

		{

			xReturn = pdFAIL;

		}

	}

	portENABLE_INTERRUPTS();



	return xReturn;

}

#endif

/*-----------------------------------------------------------*/







#if configUSE_CO_ROUTINES == 1

signed portBASE_TYPE xQueueCRSendFromISR( xQueueHandle pxQueue, const void *pvItemToQueue, signed portBASE_TYPE xCoRoutinePreviouslyWoken )

{

	/* Cannot block within an ISR so if there is no space on the queue then

	exit without doing anything. */

	if( pxQueue->uxMessagesWaiting < pxQueue->uxLength )

	{

		prvCopyQueueData( pxQueue, pvItemToQueue );



		/* We only want to wake one co-routine per ISR, so check that a 

		co-routine has not already been woken. */

		if( !xCoRoutinePreviouslyWoken )		

		{

			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToReceive ) ) )

			{

				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToReceive ) ) != pdFALSE )

				{

					return pdTRUE;

				}

			}

		}

	}



	return xCoRoutinePreviouslyWoken;

}

#endif

/*-----------------------------------------------------------*/



#if configUSE_CO_ROUTINES == 1

signed portBASE_TYPE xQueueCRReceiveFromISR( xQueueHandle pxQueue, void *pvBuffer, signed portBASE_TYPE *pxCoRoutineWoken )

{

signed portBASE_TYPE xReturn;



	/* We cannot block from an ISR, so check there is data available. If

	not then just leave without doing anything. */

	if( pxQueue->uxMessagesWaiting > ( unsigned portBASE_TYPE ) 0 )

	{

		/* Copy the data from the queue. */

		pxQueue->pcReadFrom += pxQueue->uxItemSize;

		if( pxQueue->pcReadFrom >= pxQueue->pcTail )

		{

			pxQueue->pcReadFrom = pxQueue->pcHead;

		}

		--( pxQueue->uxMessagesWaiting );

		memcpy( ( void * ) pvBuffer, ( void * ) pxQueue->pcReadFrom, ( unsigned ) pxQueue->uxItemSize );



		if( !( *pxCoRoutineWoken ) )

		{

			if( !listLIST_IS_EMPTY( &( pxQueue->xTasksWaitingToSend ) ) )

			{

				if( xCoRoutineRemoveFromEventList( &( pxQueue->xTasksWaitingToSend ) ) != pdFALSE )

				{

					*pxCoRoutineWoken = pdTRUE;

				}

			}

		}



		xReturn = pdPASS;

	}

	else

	{

		xReturn = pdFAIL;

	}



	return xReturn;

}

#endif

/*-----------------------------------------------------------*/



?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美制服丝袜第一页| 国产盗摄一区二区三区| 欧美久久久久久蜜桃| 五月激情综合网| 日韩视频免费观看高清完整版 | 欧美日韩和欧美的一区二区| 一二三区精品福利视频| 欧美一区二区在线视频| 麻豆久久一区二区| 国产日韩欧美在线一区| 99国产一区二区三精品乱码| 亚洲与欧洲av电影| 亚洲视频香蕉人妖| 欧美午夜在线观看| 老司机免费视频一区二区| 国产午夜精品久久久久久久| 91丨九色丨蝌蚪丨老版| 天天影视涩香欲综合网| 久久久亚洲欧洲日产国码αv| av午夜一区麻豆| 亚洲电影一级黄| 久久综合色鬼综合色| 99精品视频在线观看免费| 午夜久久久影院| 中文字幕免费不卡| 欧美精品视频www在线观看| 国产精品77777竹菊影视小说| 亚洲精品成人悠悠色影视| 日韩三级免费观看| 99国产精品一区| 久久99精品久久久久久久久久久久 | 亚洲激情第一区| 日韩一区二区在线看片| 成年人网站91| 免费观看在线色综合| 成人欧美一区二区三区视频网页 | 精品系列免费在线观看| 亚洲欧美成aⅴ人在线观看| 日韩三级免费观看| 91久久精品一区二区三| 国产一区二区三区黄视频 | 亚洲人亚洲人成电影网站色| 欧美一级理论性理论a| 91在线免费播放| 国产麻豆精品久久一二三| 亚洲高清不卡在线| 亚洲视频资源在线| 久久久久成人黄色影片| 日韩一区二区三区在线观看| 色婷婷综合久色| 国产成人精品影视| 麻豆精品视频在线观看免费| 日韩午夜精品视频| 337p日本欧洲亚洲大胆精品| 欧美日韩在线三级| 91美女精品福利| 久久综合久久鬼色中文字| 欧美日精品一区视频| 91麻豆精品在线观看| 成人性视频网站| 国产一区二区三区| 国产在线精品免费| 久久精品国产色蜜蜜麻豆| 五月天国产精品| 日日夜夜免费精品视频| 午夜精品久久久久久久久| 亚洲一区二区在线视频| 亚洲精品写真福利| 亚洲精品国产第一综合99久久| 国产欧美一区二区三区沐欲| 久久综合九色综合97婷婷女人| 在线91免费看| 欧美一区二区三区成人| 日韩欧美一区在线| 日韩欧美亚洲国产另类| 91麻豆精品久久久久蜜臀| 91精品国产综合久久久久久久| 欧美日韩高清不卡| 制服丝袜激情欧洲亚洲| 日韩免费成人网| 精品黑人一区二区三区久久 | 色婷婷综合久久久中文一区二区| av电影在线观看完整版一区二区| 成人av在线一区二区| 欧美成人性福生活免费看| 欧美一级二级三级乱码| 久久人人爽人人爽| 国产蜜臀av在线一区二区三区| 国产精品女同一区二区三区| 亚洲欧洲精品一区二区三区| 一区二区三区在线观看欧美| 亚洲福利视频一区二区| 美女一区二区视频| 国产在线播精品第三| 成人黄色一级视频| 91在线视频观看| 欧美高清hd18日本| 精品国精品自拍自在线| 国产精品欧美久久久久一区二区| 亚洲人妖av一区二区| 婷婷综合久久一区二区三区| 精品一区二区三区在线播放视频| 国产99精品在线观看| 91碰在线视频| 日韩午夜在线播放| 国产精品久久久久久妇女6080| 一区av在线播放| 韩国视频一区二区| 色偷偷成人一区二区三区91| 日韩欧美一二区| 中文字幕一区二区三| 日本欧美一区二区| 波波电影院一区二区三区| 欧美日韩国产色站一区二区三区| 精品国产乱码久久久久久蜜臀| 一区免费观看视频| 麻豆一区二区三| voyeur盗摄精品| 日韩一区二区影院| 国产成人精品一区二| 在线观看日韩一区| 久久午夜羞羞影院免费观看| 亚洲影视资源网| 国产福利不卡视频| 制服丝袜av成人在线看| 国产精品久久久久久妇女6080| 日韩av一区二| 99vv1com这只有精品| 精品久久久久久综合日本欧美| 亚洲视频免费在线观看| 国产一区二区三区四| 欧美日本韩国一区二区三区视频| 国产欧美一区二区精品秋霞影院| 亚洲电影在线免费观看| 岛国精品在线观看| 日韩免费成人网| 五月婷婷综合在线| 91蝌蚪porny| 国产亚洲一二三区| 免费不卡在线视频| 欧美剧情片在线观看| 亚洲啪啪综合av一区二区三区| 国产精品中文字幕欧美| 91精品国产综合久久久蜜臀粉嫩| 亚洲精品国产精华液| 成人黄动漫网站免费app| 精品国产免费一区二区三区香蕉| 亚洲图片欧美综合| 在线观看一区二区精品视频| 中文字幕一区二区三区四区不卡| 国产资源精品在线观看| 日韩精品在线一区| 日韩国产精品大片| 欧美高清性hdvideosex| 亚洲国产一区二区a毛片| 91国在线观看| 亚洲欧美另类综合偷拍| www.av亚洲| 亚洲特级片在线| av电影在线观看完整版一区二区| 中文字幕的久久| 粉嫩在线一区二区三区视频| 国产欧美精品国产国产专区| 国产自产2019最新不卡| 久久丝袜美腿综合| 国产精品一级在线| 欧美国产一区在线| www.综合网.com| 自拍av一区二区三区| av不卡在线播放| 亚洲美女精品一区| 欧美午夜精品久久久| 午夜视频在线观看一区二区三区| 欧美无砖专区一中文字| 婷婷中文字幕一区三区| 欧美一区二区三区在线| 美国精品在线观看| 精品国产一二三| 国产成人在线视频网址| 国产精品毛片大码女人| 99re视频这里只有精品| 91亚洲资源网| 亚洲精品国产第一综合99久久| 欧美在线不卡视频| 日韩国产精品大片| 精品国产91乱码一区二区三区| 国产精品一二三四五| 专区另类欧美日韩| 在线播放亚洲一区| 精品制服美女丁香| 国产精品精品国产色婷婷| 色噜噜夜夜夜综合网| 人人狠狠综合久久亚洲| 久久欧美一区二区| 91国产丝袜在线播放| 美日韩一区二区三区| 国产精品人人做人人爽人人添 | 欧美三级欧美一级| 久久成人免费网| 亚洲欧美日本在线|