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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? os_core.c

?? ARM7 based on STR71x, UCOS migration
?? C
?? 第 1 頁 / 共 3 頁
字號:
					} else {								// Yes, Leave 1 tick to prevent ...
						ptcb->OSTCBDly = 1;					// ... loosing the task when the ...
					}										// ... suspension is removed.
				}
			}
			ptcb = ptcb->OSTCBNext;							// Point at next TCB in TCB list
			OS_EXIT_CRITICAL();
		}
	}
}

/********************************************************************************************************
*											 GET VERSION
*
* Description: This function is used to return the version number of uC/OS-II.  The returned value
*			  corresponds to uC/OS-II's version number multiplied by 100.  In other words, version 2.00
*			  would be returned as 200.
* Arguments  : none
* Returns	: the version number of uC/OS-II multiplied by 100.
********************************************************************************************************/
INT16U OSVersion (void)
{
	return (OS_VERSION);
}

/********************************************************************************************************
*											DUMMY FUNCTION
*
* Description: This function doesn't do anything.  It is called by OSTaskDel().
* Arguments	: none
* Returns	: none
********************************************************************************************************/
#if OS_TASK_DEL_EN > 0
void  OS_Dummy (void)
{
}
#endif

/********************************************************************************************************
*							 MAKE TASK READY TO RUN BASED ON EVENT OCCURING
*
* Description: This function is called by other uC/OS-II services and is used to ready a task that was
*			  waiting for an event to occur.
*
* Arguments  : pevent	is a pointer to the event control block corresponding to the event.
*
*			  msg	   is a pointer to a message.  This pointer is used by message oriented services
*						such as MAILBOXEs and QUEUEs.  The pointer is not used when called by other
*						service functions.
*
*			  msk	   is a mask that is used to clear the status byte of the TCB.  For example,
*						OSSemPost() will pass OS_STAT_SEM, OSMboxPost() will pass OS_STAT_MBOX etc.
*
* Returns	: none
*
* Note	   : This function is INTERNAL to uC/OS-II and your application should not call it.
********************************************************************************************************/
#if OS_EVENT_EN > 0
INT8U  OS_EventTaskRdy (OS_EVENT *pevent, void *msg, INT8U msk)
{
	OS_TCB *ptcb;
	INT8U x;
	INT8U y;
	INT8U bitx;
	INT8U bity;
	INT8U prio;

	y = OSUnMapTbl[pevent->OSEventGrp];				// Find highest prio. task waiting for message
	bity = OSMapTbl[y];
	x = OSUnMapTbl[pevent->OSEventTbl[y]];
	bitx = OSMapTbl[x];
	prio = (INT8U)((y << 3) + x);					// Find priority of task getting the msg
	if ((pevent->OSEventTbl[y] &= ~bitx) == 0x00) {	// Remove this task from the waiting list
		pevent->OSEventGrp &= ~bity;				// Clr group bit if this was only task pending
	}
	ptcb =  OSTCBPrioTbl[prio];						// Point to this task's OS_TCB
	ptcb->OSTCBDly =  0;							// Prevent OSTimeTick() from readying task
	ptcb->OSTCBEventPtr = (OS_EVENT *)0;			// Unlink ECB from this task
#if ((OS_Q_EN > 0) && (OS_MAX_QS > 0)) || (OS_MBOX_EN > 0)
	ptcb->OSTCBMsg = msg;							// Send message directly to waiting task
#else
	msg = msg;										// Prevent compiler warning if not used
#endif
	ptcb->OSTCBStat &= ~msk;						// Clear bit associated with event type
	if (ptcb->OSTCBStat == OS_STAT_RDY) {			// See if task is ready (could be susp'd)
		OSRdyGrp |=  bity;							// Put task in the ready to run list
		OSRdyTbl[y] |=  bitx;
	}
	return (prio);
}
#endif

/*********************************************************************************************************
*								   MAKE TASK WAIT FOR EVENT TO OCCUR
*
* Description: This function is called by other uC/OS-II services to suspend a task because an event has
*			  not occurred.
*
* Arguments  : pevent   is a pointer to the event control block for which the task will be waiting for.
*
* Returns	: none
*
* Note	   : This function is INTERNAL to uC/OS-II and your application should not call it.
********************************************************************************************************/
#if OS_EVENT_EN > 0
void  OS_EventTaskWait (OS_EVENT *pevent)
{
	OSTCBCur->OSTCBEventPtr = pevent;			// Store pointer to event control block in TCB
	if ((OSRdyTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0x00) {	// Task no longer ready
		OSRdyGrp &= ~OSTCBCur->OSTCBBitY;		// Clear event grp bit if this was only task pending
	}
	pevent->OSEventTbl[OSTCBCur->OSTCBY] |= OSTCBCur->OSTCBBitX;		// Put task in waiting list
	pevent->OSEventGrp |= OSTCBCur->OSTCBBitY;
}
#endif

/*********************************************************************************************************
*							  MAKE TASK READY TO RUN BASED ON EVENT TIMEOUT
*
* Description: This function is called by other uC/OS-II services to make a task ready to run because a
*			  timeout occurred.
*
* Arguments  : pevent   is a pointer to the event control block which is readying a task.
*
* Returns	: none
*
* Note	   : This function is INTERNAL to uC/OS-II and your application should not call it.
********************************************************************************************************/
#if OS_EVENT_EN > 0
void  OS_EventTO (OS_EVENT *pevent)
{
	if ((pevent->OSEventTbl[OSTCBCur->OSTCBY] &= ~OSTCBCur->OSTCBBitX) == 0x00) {
		pevent->OSEventGrp &= ~OSTCBCur->OSTCBBitY;
	}
	OSTCBCur->OSTCBStat = OS_STAT_RDY;			// Set status to ready
	OSTCBCur->OSTCBEventPtr = (OS_EVENT *)0;	// No longer waiting for event
}
#endif

/*********************************************************************************************************
*								 INITIALIZE EVENT CONTROL BLOCK'S WAIT LIST
*
* Description: This function is called by other uC/OS-II services to initialize the event wait list.
*
* Arguments  : pevent	is a pointer to the event control block allocated to the event.
*
* Returns	: none
*
* Note	   : This function is INTERNAL to uC/OS-II and your application should not call it.
********************************************************************************************************/
#if ((OS_Q_EN > 0) && (OS_MAX_QS > 0)) || (OS_MBOX_EN > 0) || (OS_SEM_EN > 0) || (OS_MUTEX_EN > 0)
void  OS_EventWaitListInit (OS_EVENT *pevent)
{
	INT8U  *ptbl;

	pevent->OSEventGrp = 0x00;					// No task waiting on event
	ptbl = &pevent->OSEventTbl[0];

#if OS_EVENT_TBL_SIZE > 0
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 1
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 2
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 3
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 4
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 5
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 6
	*ptbl++ = 0x00;
#endif

#if OS_EVENT_TBL_SIZE > 7
	*ptbl = 0x00;
#endif
}
#endif

/*********************************************************************************************************
*											 INITIALIZATION
*						   INITIALIZE THE FREE LIST OF EVENT CONTROL BLOCKS
*
* Description: This function is called by OSInit() to initialize the free list of event control blocks.
*
* Arguments  : none
*
* Returns	: none
********************************************************************************************************/
static void OS_InitEventList (void)
{
#if (OS_EVENT_EN > 0) && (OS_MAX_EVENTS > 0)
#if (OS_MAX_EVENTS > 1)
	INT16U i;
	OS_EVENT *pevent1;
	OS_EVENT *pevent2;

	pevent1 = &OSEventTbl[0];
	pevent2 = &OSEventTbl[1];
	for (i = 0; i < (OS_MAX_EVENTS - 1); i++) {				// Init. list of free EVENT control blocks
		pevent1->OSEventType = OS_EVENT_TYPE_UNUSED;
		pevent1->OSEventPtr  = pevent2;
		pevent1++;
		pevent2++;
	}
	pevent1->OSEventType = OS_EVENT_TYPE_UNUSED;
	pevent1->OSEventPtr  = (OS_EVENT *)0;
	OSEventFreeList = &OSEventTbl[0];
#else
	OSEventFreeList = &OSEventTbl[0];						// Only have ONE event control block
	OSEventFreeList->OSEventType = OS_EVENT_TYPE_UNUSED;
	OSEventFreeList->OSEventPtr  = (OS_EVENT *)0;
#endif
#endif
}

/********************************************************************************************************
*											 INITIALIZATION
*									INITIALIZE MISCELLANEOUS VARIABLES
*
* Description: This function is called by OSInit() to initialize miscellaneous variables.
*
* Arguments  : none
*
* Returns	: none
********************************************************************************************************/
static void OS_InitMisc (void)
{
#if OS_TIME_GET_SET_EN > 0
	OSTime = 0L;											// Clear the 32-bit system clock
#endif

	OSIntNesting  = 0;										// Clear the interrupt nesting counter
	OSLockNesting = 0;										// Clear the scheduling lock counter

	OSTaskCtr = 0;											// Clear the number of tasks

	OSRunning = FALSE;										// Indicate that multitasking not started
	
	OSCtxSwCtr = 0;											// Clear the context switch counter
	OSIdleCtr = 0L;											// Clear the 32-bit idle counter

#if (OS_TASK_STAT_EN > 0) && (OS_TASK_CREATE_EXT_EN > 0)
	OSIdleCtrRun  = 0L;
	OSIdleCtrMax  = 0L;
	OSStatRdy = FALSE;										// Statistic task is not ready
#endif
}

/********************************************************************************************************
*											 INITIALIZATION
*									   INITIALIZE THE READY LIST
*
* Description: This function is called by OSInit() to initialize the Ready List.
*
* Arguments  : none
*
* Returns	: none
********************************************************************************************************/
static void OS_InitRdyList (void)
{
	INT16U i;
	INT8U *prdytbl;

	OSRdyGrp = 0x00;							// Clear the ready list
	prdytbl = &OSRdyTbl[0];
	for (i = 0; i < OS_RDY_TBL_SIZE; i++) {
		*prdytbl++ = 0x00;
	}

	OSPrioCur = 0;
	OSPrioHighRdy = 0;

	OSTCBHighRdy  = (OS_TCB *)0;
	OSTCBCur = (OS_TCB *)0;
}

/********************************************************************************************************
*											 INITIALIZATION
*										 CREATING THE IDLE TASK
*
* Description: This function creates the Idle Task.
*
* Arguments  : none
*
* Returns	: none
********************************************************************************************************/
static  void  OS_InitTaskIdle (void)
{
#if OS_TASK_CREATE_EXT_EN > 0
	#if OS_STK_GROWTH == 1
	(void)OSTaskCreateExt(OS_TaskIdle,
						  (void *)0,								// No arguments passed to OS_TaskIdle()
						  &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1],// Set Top-Of-Stack
						  OS_IDLE_PRIO,								// Lowest priority level
						  OS_TASK_IDLE_ID,
						  &OSTaskIdleStk[0],						// Set Bottom-Of-Stack
						  OS_TASK_IDLE_STK_SIZE,
						  (void *)0,								// No TCB extension
						  OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);// Enable stack checking + clear stack
	#else
	(void)OSTaskCreateExt(OS_TaskIdle,
						  (void *)0,								// No arguments passed to OS_TaskIdle()
						  &OSTaskIdleStk[0],						// Set Top-Of-Stack
						  OS_IDLE_PRIO,								// Lowest priority level
						  OS_TASK_IDLE_ID,
						  &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1],// Set Bottom-Of-Stack
						  OS_TASK_IDLE_STK_SIZE,
						  (void *)0,								// No TCB extension
						  OS_TASK_OPT_STK_CHK | OS_TASK_OPT_STK_CLR);// Enable stack checking + clear stack
	#endif
#else
	#if OS_STK_GROWTH == 1
	(void)OSTaskCreate(OS_TaskIdle,
					   (void *)0,
					   &OSTaskIdleStk[OS_TASK_IDLE_STK_SIZE - 1],
					   OS_IDLE_PRIO);
	#else
	(void)OSTaskCreate(OS_TaskIdle,
					   (void *)0,

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美一区二区性放荡片| 久久精品国产澳门| 亚洲香肠在线观看| 日韩高清不卡在线| 国产成人精品综合在线观看| 精品成人一区二区三区| 26uuu亚洲婷婷狠狠天堂| 国产一区二区三区日韩| 成人av网在线| 色综合视频一区二区三区高清| 一本久久a久久精品亚洲| 中文字幕亚洲精品在线观看| 久久人人爽人人爽| 亚洲国产欧美一区二区三区丁香婷| 精品中文字幕一区二区| 色综合久久六月婷婷中文字幕| 欧美另类变人与禽xxxxx| 欧美韩国日本不卡| 美女视频黄频大全不卡视频在线播放 | 国产一区二区精品久久99| 色哟哟一区二区| 日本一区二区视频在线| 91久久国产最好的精华液| 日产国产高清一区二区三区 | 久久―日本道色综合久久| 日日摸夜夜添夜夜添国产精品 | 狠狠色伊人亚洲综合成人| 欧美日韩www| 亚洲一区二区三区四区在线| 日韩欧美国产系列| av综合在线播放| 亚洲人成7777| zzijzzij亚洲日本少妇熟睡| 亚洲成人午夜电影| 日本一区二区三区四区| 欧美日韩国产精品成人| 成人免费视频国产在线观看| 日韩精品久久久久久| 欧美国产一区视频在线观看| 欧美日韩国产欧美日美国产精品| 国产精品亚洲成人| 首页欧美精品中文字幕| 国产精品家庭影院| 欧美精品一区二区三区在线 | ●精品国产综合乱码久久久久| 欧美日韩国产首页在线观看| 欧美国产激情一区二区三区蜜月| 欧美色综合网站| 国产91在线观看| 另类成人小视频在线| 一区二区欧美国产| 中文字幕不卡在线| 欧美精品一区二区久久婷婷| 欧美日韩一区二区三区四区| 成人做爰69片免费看网站| 麻豆freexxxx性91精品| 亚洲国产精品久久人人爱| 天堂影院一区二区| 欧美日韩久久不卡| 色悠悠亚洲一区二区| 国产精选一区二区三区| 麻豆国产91在线播放| 午夜精品久久久久久不卡8050| 日产欧产美韩系列久久99| 色综合久久六月婷婷中文字幕| 从欧美一区二区三区| 精品制服美女丁香| 日韩精品欧美成人高清一区二区| 亚洲精品国产无天堂网2021| 中文字幕中文字幕中文字幕亚洲无线| 精品国产乱码久久| 日韩欧美电影在线| 日韩亚洲欧美中文三级| 欧美精品一二三| 欧美嫩在线观看| 欧美区视频在线观看| 欧美日韩国产一二三| 欧美日韩国产经典色站一区二区三区| 在线观看一区不卡| 色诱视频网站一区| 亚洲欧美日韩综合aⅴ视频| 日本一区二区电影| 中国av一区二区三区| 国产精品麻豆久久久| 成人免费小视频| 亚洲精品中文在线| 亚洲自拍偷拍欧美| 亚洲亚洲人成综合网络| 亚洲亚洲精品在线观看| 三级一区在线视频先锋| 蜜臀va亚洲va欧美va天堂 | 成人av在线电影| 亚洲综合色成人| 亚洲成人动漫在线观看| 亚洲国产日产av| 久久精品国内一区二区三区| 国产自产视频一区二区三区| 懂色av中文字幕一区二区三区| 99久久精品国产一区| 一本大道综合伊人精品热热 | 国产呦萝稀缺另类资源| 国产福利电影一区二区三区| 欧美亚日韩国产aⅴ精品中极品| 成人免费视频免费观看| 一本久久a久久免费精品不卡| 欧美日韩情趣电影| 精品日韩成人av| 国产精品久久久久三级| 亚洲自拍偷拍av| 久久99精品久久久久| 床上的激情91.| 欧美日韩亚洲综合在线| 久久伊人中文字幕| 亚洲免费观看高清完整| 日本大胆欧美人术艺术动态| 26uuu欧美| 亚洲美女视频一区| 久久成人免费电影| 99久久国产免费看| 欧美日韩黄色影视| 国产日韩欧美a| 亚洲成人精品影院| 成人午夜激情影院| 7777精品伊人久久久大香线蕉超级流畅 | 国产一区二区精品久久99| 99r国产精品| 日韩视频免费观看高清完整版| 国产精品每日更新| 另类小说一区二区三区| 色综合天天天天做夜夜夜夜做| 日韩欧美一二三| 亚洲精品国产一区二区精华液 | 波多野结衣视频一区| 在线成人av影院| 最新热久久免费视频| 精品综合久久久久久8888| 欧美日韩精品专区| 亚洲免费在线观看视频| 国产传媒欧美日韩成人| 666欧美在线视频| 亚洲欧美一区二区三区国产精品 | 亚洲国产精品ⅴa在线观看| 一区二区三区成人在线视频| 国产一区二区视频在线播放| 538prom精品视频线放| 亚洲色图另类专区| 国产精品亚洲а∨天堂免在线| 欧美一级艳片视频免费观看| 亚洲另类色综合网站| 国产盗摄精品一区二区三区在线| 欧美一区二区三区色| 亚洲图片欧美综合| 91一区二区三区在线播放| 久久精品日韩一区二区三区| 色婷婷国产精品久久包臀| 在线观看不卡一区| 中文字幕一区二区三区在线不卡| 国产一区二区在线观看免费| 日韩一区二区电影在线| 三级一区在线视频先锋 | 亚洲成人综合视频| 色香蕉久久蜜桃| 亚洲另类在线视频| 日本久久一区二区三区| 亚洲啪啪综合av一区二区三区| 北条麻妃一区二区三区| 国产精品久久久久aaaa| 99国产精品视频免费观看| 日本一区二区动态图| 国产mv日韩mv欧美| 亚洲国产电影在线观看| 成人午夜免费av| 国产精品传媒视频| 99精品视频在线播放观看| 亚洲欧洲日韩一区二区三区| 成人国产精品免费| 亚洲少妇30p| 欧洲精品视频在线观看| 亚洲午夜成aⅴ人片| 欧美日韩国产在线观看| 午夜视频久久久久久| 日韩午夜电影av| 激情综合色综合久久| 国产精品1024| 亚洲欧美在线aaa| 色综合久久综合| 日本午夜一本久久久综合| 日韩欧美第一区| 99精品黄色片免费大全| 国产精品久久国产精麻豆99网站| 91在线看国产| 日韩中文字幕1| xnxx国产精品| 99综合电影在线视频| 亚洲亚洲精品在线观看| 日韩精品一区二区三区中文不卡| 国产精品一区二区x88av| 国产成人亚洲综合色影视| 欧美伊人久久久久久午夜久久久久| 偷拍自拍另类欧美|