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

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

?? tasklib.c

?? vxworks的完整的源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
* RETURNS: OK, or ERROR if the task cannot be suspended.** ERRNO: S_objLib_OBJ_ID_ERROR**/STATUS taskSuspend    (    int tid             /* task ID of task to suspend */    )    {#ifdef WV_INSTRUMENTATION    int realTid = (tid == 0 ? (int) taskIdCurrent : tid);    /* windview - level 1 event logging */    EVT_OBJ_1 (TASK, (WIND_TCB *)realTid, taskClassId, EVENT_TASKSUSPEND, realTid);#endif    if (kernelState)				/* defer work if in kernel */	{	if ((tid == 0) || (TASK_ID_VERIFY ((void *)tid) != OK))	    return (ERROR);	workQAdd1 ((FUNCPTR)windSuspend, tid);	/* add work to kernel work q */	return (OK);	}    if (tid == 0)	tid = (int) taskIdCurrent;    kernelState = TRUE;				/* KERNEL ENTER */    if (TASK_ID_VERIFY ((void *)tid) != OK)	/* verify task */	{	windExit ();				/* KERNEL EXIT */	return (ERROR);	}    windSuspend ((WIND_TCB *) tid);		/* suspend a task */    windExit ();				/* KERNEL EXIT */    return (OK);    }/********************************************************************************* taskResume - resume a task** This routine resumes a specified task.  Suspension is cleared, and* the task operates in the remaining state.** RETURNS: OK, or ERROR if the task cannot be resumed.** ERRNO: S_objLib_OBJ_ID_ERROR**/STATUS taskResume    (    int tid                     /* task ID of task to resume */    )    {#ifdef WV_INSTRUMENTATION    /* windview - level 1 event logging */    EVT_OBJ_2 (TASK, (WIND_TCB *)tid, taskClassId,	       EVENT_TASKRESUME, tid, ((WIND_TCB *)tid)->priority);#endif    if (kernelState)				/* defer work if in kernel */	{	if ((tid == 0) || (TASK_ID_VERIFY ((void *)tid) != OK))	    return (ERROR);#if	CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS	bzero ((char *) &((WIND_TCB *) tid)->excInfo, sizeof (EXC_INFO));#endif	/* CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS */	workQAdd1 ((FUNCPTR)windResume, tid);	/* add work to kernel work q */	return (OK);	}    if (tid == 0)				/* zero is calling task */	return (OK);				/* presumably we're running */    kernelState = TRUE;				/* KERNEL ENTER */    if (TASK_ID_VERIFY ((void *)tid) != OK)	/* check for invalid ID */	{	windExit ();				/* KERNEL EXIT */	return (ERROR);	}#if	CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS	bzero ((char *) &((WIND_TCB *) tid)->excInfo, sizeof (EXC_INFO));#endif	/* CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS */    windResume ((WIND_TCB *) tid);		/* resume task */    windExit ();				/* KERNEL EXIT */    return (OK);    }/********************************************************************************* taskRestart - restart a task** This routine "restarts" a task.  The task is first terminated, and then* reinitialized with the same ID, priority, options, original entry point,* stack size, and parameters it had when it was terminated.  Self-restarting* of a calling task is performed by the exception task.  The shell utilizes* this routine to restart itself when aborted.** NOTE* If the task has modified any of its start-up parameters, the restarted* task will start with the changed values.** RETURNS: OK, or ERROR if the task ID is invalid* or the task could not be restarted.** ERRNO: S_intLib_NOT_ISR_CALLABLE, S_objLib_OBJ_DELETED,*        S_objLib_OBJ_UNAVAILABLE, S_objLib_OBJ_ID_ERROR,*        S_smObjLib_NOT_INITIALIZED, S_memLib_NOT_ENOUGH_MEMORY,*        S_memLib_BLOCK_ERROR, S_taskLib_ILLEGAL_PRIORITY**/STATUS taskRestart    (    int tid                     /* task ID of task to restart */    )    {    char	*name;			/* task name */    ULONG	priority;		/* priority of task */    int		options;		/* task options */    char	*pStackBase;		/* bottom of stack */    int		stackSize;		/* stack size */    FUNCPTR	entry;			/* entry point of task */    int		pArgs[MAX_TASK_ARGS];	/* task's arguments */    BOOL	error;			/* TRUE if ERROR */    char	*rename = NULL;		/* place to keep rename */    int		sizeName;		/* size of task name */    WIND_TCB	*pTcb;			/* pointer to task control block */    if (INT_RESTRICT () != OK)			/* no ISR use */	return (ERROR);    if ((tid == 0) || (tid == (int)taskIdCurrent))	{	/* self restart not possible because we have we have no context	 * from which to sucessfully terminate or reinitialize ourself.	 * We defer all self restarts to the exception task.	 * To self restart within a critical section, we must TASK_UNSAFE ()	 * until the safeCnt == 0.  Otherwise, the excTask would block	 * forever trying to terminate us.	 */	while (taskIdCurrent->safeCnt > 0)	/* make task unsafe */	    TASK_UNSAFE ();#if	CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS	bzero ((char *) &taskIdCurrent->excInfo, sizeof (EXC_INFO));#endif	/* CPU==SIMSPARCSUNOS || CPU==SIMSPARCSOLARIS */	taskSpawn (restartTaskName, restartTaskPriority, restartTaskOptions,		   restartTaskStackSize, taskRestart, (int) taskIdCurrent,		   0, 0, 0, 0, 0, 0, 0, 0, 0);	FOREVER	    taskSuspend (0);			/* wait for restart */	}    /* the rest of this routine will only be executed by a task other than     * the one being restarted.     */    if ((pTcb = taskTcb (tid)) == NULL)		/* valid task ID? */	return (ERROR);    priority    = pTcb->priNormal;		/* get the normal priority */    options	= pTcb->options;		/* get the current options */    entry	= pTcb->entry;			/* get the entry point */    pStackBase	= pTcb->pStackBase;		/* get the bottom of stack */    stackSize	= (pTcb->pStackEnd - pTcb->pStackBase)*_STACK_DIR;    taskArgsGet (pTcb, pStackBase, pArgs);	/* get the arguments */    /* If task was named, its name was alloted from the task stack.  So we     * get a local copy from the stack so it won't be clobbered during task     * initialization.     */    if ((name = pTcb->name) != NULL)	{	sizeName = strlen(name) + 1;	rename = malloc(sizeName);	if (rename != NULL)	    strcpy (rename, name);		/* copy out name */	name = rename;				/* name points at name copy */	}    TASK_SAFE ();				/* TASK SAFE */    if (taskTerminate (tid) != OK)		/* terminate the task */	{	TASK_UNSAFE ();				/* TASK UNSAFE */	return (ERROR);	}    /* Reinitialize task with original name, stack, priority, options,     * arguments, and entry point.  Then activate it.     */#if	CPU==SIMSPARCSUNOS || CPU==SIMHPPA || CPU==SIMSPARCSOLARIS    bzero ((char *) &pTcb->excInfo, sizeof (EXC_INFO));#endif	/* CPU==SIMSPARCSUNOS || CPU==SIMHPPA || CPU==SIMSPARCSOLARIS */    error = ((taskInit (pTcb, name, (int)priority, options, pStackBase,			stackSize, entry, pArgs[0], pArgs[1], pArgs[2],			pArgs[3], pArgs[4], pArgs[5], pArgs[6], pArgs[7],			pArgs[8], pArgs[9]) != OK) ||	     (taskActivate ((int) pTcb) != OK));    TASK_UNSAFE ();				/* TASK UNSAFE */    free (rename);    return ((error) ? ERROR : OK);    }/********************************************************************************* taskPrioritySet - change the priority of a task** This routine changes a task's priority to a specified priority.* Priorities range from 0, the highest priority, to 255, the lowest priority.** RETURNS: OK, or ERROR if the task ID is invalid.** ERRNO: S_taskLib_ILLEGAL_PRIORITY, S_objLib_OBJ_ID_ERROR** SEE ALSO: taskPriorityGet()*/STATUS taskPrioritySet    (    int tid,                    /* task ID */    int newPriority             /* new priority */    )    {#ifdef WV_INSTRUMENTATION    int realTid = (tid == 0 ? (int) taskIdCurrent : tid);    /* windview - level 1 event logging */    EVT_OBJ_3 (TASK, (WIND_TCB *)realTid, taskClassId, EVENT_TASKPRIORITYSET,	realTid, newPriority, ((WIND_TCB *)realTid)->priority);#endif    /* make sure priority is in range 0-255 */    if (taskPriRangeCheck)	{        if ((newPriority & 0xffffff00) != 0)	/* ! (0 <= x <= 255) */	    {	    errno = S_taskLib_ILLEGAL_PRIORITY;	    return (ERROR);	    }	}    if (kernelState)					/* already in kernel? */        {	if ((tid == 0) ||	    (TASK_ID_VERIFY ((void *)tid) != OK))	/* verify task ID */	    return (ERROR);        workQAdd2 ((FUNCPTR)windPriNormalSet, tid, newPriority);	return (OK);	}    if (tid == 0)	tid = (int) taskIdCurrent;    kernelState = TRUE;					/* KERNEL ENTER */    if (TASK_ID_VERIFY ((void *)tid) != OK)			/* verify task ID */	{	windExit ();					/* KERNEL EXIT */	return (ERROR);	}    windPriNormalSet ((WIND_TCB *) tid, (UINT) newPriority);    windExit ();					/* KERNEL EXIT */    return (OK);    }/********************************************************************************* taskPriorityGet - examine the priority of a task** This routine determines the current priority of a specified task.* The current priority is copied to the integer pointed to by <pPriority>.** RETURNS: OK, or ERROR if the task ID is invalid.** ERRNO: S_objLib_OBJ_ID_ERROR** SEE ALSO: taskPrioritySet()*/STATUS taskPriorityGet    (    int tid,                    /* task ID */    int *pPriority              /* return priority here */    )    {    WIND_TCB *pTcb = taskTcb (tid);    if (pTcb == NULL)				/* invalid task ID */	return (ERROR);    *pPriority = (int) pTcb->priority;    return (OK);    }/********************************************************************************* taskLock - disable task rescheduling** This routine disables task context switching.  The task that calls this* routine will be the only task that is allowed to execute, unless the task* explicitly gives up the CPU by making itself no longer ready.  Typically* this call is paired with taskUnlock(); together they surround a critical* section of code.  These preemption locks are implemented with a counting* variable that allows nested preemption locks.  Preemption will not be* unlocked until taskUnlock() has been called as many times as taskLock().** This routine does not lock out interrupts; use intLock() to lock out* interrupts.** A taskLock() is preferable to intLock() as a means of mutual exclusion,* because interrupt lock-outs add interrupt latency to the system.** A semTake() is preferable to taskLock() as a means of mutual exclusion,* because preemption lock-outs add preemptive latency to the system.** The taskLock() routine is not callable from interrupt service routines.** RETURNS: OK or ERROR.** ERRNO: S_objLib_OBJ_ID_ERROR, S_intLib_NOT_ISR_CALLABLE** SEE ALSO: taskUnlock(), intLock(), taskSafe(), semTake()*/STATUS taskLock (void)    {    TASK_LOCK();					/

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产性色一区二区| 久久精品在这里| 东方aⅴ免费观看久久av| 亚洲精品菠萝久久久久久久| 精品sm捆绑视频| 欧美日韩一卡二卡三卡| 成人av片在线观看| 九色综合国产一区二区三区| 亚洲日本va午夜在线影院| 26uuu精品一区二区| 欧美日韩精品一区二区三区蜜桃| 丁香亚洲综合激情啪啪综合| 久久精品国产网站| 亚洲国产一区视频| 亚洲女女做受ⅹxx高潮| 久久精品人人做人人综合| 日韩亚洲国产中文字幕欧美| 色94色欧美sute亚洲线路一ni| 国产精品99久久久| 蜜臀99久久精品久久久久久软件| 亚洲国产日韩一级| 欧美日韩国产bt| 最好看的中文字幕久久| 欧美影院精品一区| av亚洲精华国产精华精| 国产精品 日产精品 欧美精品| 免费的国产精品| 肉丝袜脚交视频一区二区| 亚洲激情第一区| 一区二区三区四区视频精品免费| 中文字幕欧美三区| 国产精品无码永久免费888| 欧美va在线播放| 欧美一区国产二区| 欧美一三区三区四区免费在线看| 欧美日韩大陆在线| 欧美另类videos死尸| 欧美日韩中字一区| 欧美日本乱大交xxxxx| 欧美日韩国产在线观看| 在线综合亚洲欧美在线视频| 欧美日韩亚洲不卡| 欧美精品日韩综合在线| 久久人人97超碰com| 26uuu另类欧美亚洲曰本| 久久亚洲综合色| 久久久久久久久久久久电影| 欧美精品一区二区久久婷婷| 久久日一线二线三线suv| 欧美成人猛片aaaaaaa| 久久久久国产精品免费免费搜索| 2024国产精品| 亚洲国产精品成人综合色在线婷婷| 亚洲精品一区二区三区在线观看| 欧美精品一区视频| 中文字幕欧美日韩一区| 一级做a爱片久久| 午夜欧美视频在线观看| 麻豆精品蜜桃视频网站| 成人性视频网站| 色综合天天综合网天天狠天天 | 日韩高清国产一区在线| 日精品一区二区三区| 精品一区二区三区在线观看| 国产成人午夜视频| 日本韩国精品在线| 91麻豆精品国产91久久久| 精品久久久久av影院| 欧美国产成人精品| 亚洲国产成人va在线观看天堂| 美女视频黄免费的久久| 粉嫩高潮美女一区二区三区| 91国模大尺度私拍在线视频| 日韩一级欧美一级| 国产精品国产三级国产a | 一区二区三区在线观看国产| 亚洲mv在线观看| 国产精品一二三四五| 色域天天综合网| 精品国精品自拍自在线| 亚洲精品高清在线| 久久国产精品第一页| 色综合久久综合网97色综合| 日韩一区二区在线观看| 亚洲视频一区二区免费在线观看| 日韩成人一级片| av电影一区二区| 日韩三级在线观看| 亚洲欧美激情小说另类| 久久精品国产精品亚洲红杏| 91猫先生在线| 国产亚洲1区2区3区| 亚洲成人一区二区在线观看| 风间由美性色一区二区三区| 7777精品伊人久久久大香线蕉最新版 | 亚洲成人www| 经典三级一区二区| 欧美最猛黑人xxxxx猛交| 国产偷国产偷精品高清尤物| 亚洲成av人在线观看| 99精品热视频| 久久蜜桃av一区精品变态类天堂 | 亚洲精品一区二区三区在线观看| 一区二区三区日本| 国产91在线看| 精品久久一二三区| 亚洲大尺度视频在线观看| 99re热这里只有精品视频| 精品国内片67194| 免费观看日韩电影| 欧美亚洲动漫另类| 亚洲天堂精品视频| 成人黄色在线看| 精品国产精品一区二区夜夜嗨| 午夜欧美电影在线观看| 91国产丝袜在线播放| 国产精品国产自产拍高清av王其| 国产专区欧美精品| 欧美一区在线视频| 日本va欧美va欧美va精品| 色噜噜狠狠成人中文综合| 中文幕一区二区三区久久蜜桃| 久久99精品网久久| 欧美妇女性影城| 天天色天天爱天天射综合| 91电影在线观看| 亚洲蜜臀av乱码久久精品蜜桃| 国产成人亚洲综合a∨婷婷图片 | 亚洲欧美日韩一区二区 | 国产精品久久久久7777按摩 | 风间由美一区二区av101| 国产人成亚洲第一网站在线播放| 美女被吸乳得到大胸91| 日韩精品一区国产麻豆| 日韩精品免费专区| 8x8x8国产精品| 奇米影视一区二区三区| 91麻豆精品国产自产在线观看一区| 亚洲国产精品麻豆| 欧美另类久久久品| 奇米综合一区二区三区精品视频 | 精品日韩99亚洲| 老司机免费视频一区二区三区| 91精品国产综合久久久久久久久久 | 一区二区三区在线视频观看58| 91麻豆精品在线观看| 亚洲精品视频免费看| 色噜噜久久综合| 国产一区二区三区在线观看免费视频 | 中文文精品字幕一区二区| 东方aⅴ免费观看久久av| 综合色天天鬼久久鬼色| 色婷婷综合久久久久中文一区二区| 亚洲一区二区三区四区在线免费观看| 日本高清视频一区二区| 亚洲成人你懂的| 精品成人一区二区| 成人av在线观| 亚洲国产日韩一区二区| 欧美电影免费观看完整版| 高清不卡一区二区| 一区二区在线免费| 日韩一区和二区| 成人精品gif动图一区| 亚洲夂夂婷婷色拍ww47| 日韩午夜av电影| 成人黄色一级视频| 天堂一区二区在线| 久久久久久久久久久久电影| 91丨porny丨首页| 日本aⅴ亚洲精品中文乱码| 久久久蜜桃精品| 色婷婷综合久久| 久久99热这里只有精品| 国产精品久久看| 91豆麻精品91久久久久久| 精品一区二区三区久久久| 国产精品国产自产拍在线| 91精品在线一区二区| 国产精品综合二区| 亚洲福利视频一区| 久久精品亚洲精品国产欧美| 欧美系列在线观看| 国产精品一区二区三区四区| 亚洲在线视频一区| 国产日韩综合av| 欧美三级电影在线看| 成人在线视频首页| 秋霞成人午夜伦在线观看| 亚洲三级在线看| 精品国产成人系列| 欧美亚洲国产怡红院影院| 国产精选一区二区三区| 日韩av成人高清| 亚洲人成精品久久久久| 久久亚洲二区三区| 欧美精品乱码久久久久久按摩| 成a人片亚洲日本久久| 韩国午夜理伦三级不卡影院| 亚洲一二三区在线观看|