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

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

?? nettimer.c

?? 一個tcp/ip協(xié)議棧,帶有PPP、IP、TCP、UDP等協(xié)議
?? C
字號:
/*****************************************************************************
* nettimer.c - Timer Services program file.
*
* Copyright (c) 1998 by Global Election Systems Inc.
*
* The authors hereby grant permission to use, copy, modify, distribute,
* and license this software and its documentation for any purpose, provided
* that existing copyright notices are retained in all copies and that this
* notice and the following disclaimer are included verbatim in any 
* distributions. No written agreement, license, or royalty fee is required
* for any of the authorized uses.
*
* THIS SOFTWARE IS PROVIDED BY THE CONTRIBUTORS *AS IS* AND ANY EXPRESS OR
* IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. 
* IN NO EVENT SHALL THE CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
* INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
* NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
* DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
* THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
* THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*
******************************************************************************
* REVISION HISTORY
*
* 98-01-23 Guy Lancaster <lancasterg@acm.org>, Global Election Systems Inc.
*	Original.
* 2001-05-18 Mads Christiansen <mads@mogi.dk>, Partner Voxtream 
*       Added support for running uC/IP in a single proces and on ethernet.
*****************************************************************************/

#include <string.h>
#include "netconf.h"
#include "net.h"
#include "netbuf.h"
#include "nettimer.h"

//#include <string.h>
#include <stdio.h>
#include "netdebug.h"
#include "netos.h"


/*************************/
/*** LOCAL DEFINITIONS ***/
/*************************/
#define TIMER_STACK_SIZE	NETSTACK	/* Timers are used for network protocols. */
#define MAXFREETIMERS 4					/* Number of free timers allocated. */

                                                                    
/***********************************/
/*** LOCAL FUNCTION DECLARATIONS ***/
/***********************************/
static void nullTimer(void *);

#if (defined (OS_DEPENDENT) || (ONETASK_SUPPORT > 0))
static void timerTask(void *data);
#endif

/*****************************/
/*** LOCAL DATA STRUCTURES ***/
/*****************************/
#ifdef OS_DEPENDENT
static OS_EVENT *mutex;
#endif

#ifdef OS_DEPENDENT
static char timerStack[TIMER_STACK_SIZE];
#endif
static Timer timerHead;					/* Sentinal for timer queue. */
static Timer *timerFree;				/* The free list pointer. */
static Timer timerHeap[MAXFREETIMERS];	/* The free timer records. */


/***********************************/
/*** PUBLIC FUNCTION DEFINITIONS ***/
/***********************************/
/*
 * timerInit - Initialize the timer timer subsystem.
 */
void timerInit(void)
{
	int i;
	
	/* Initialize the timer queue sentinal. */
	memset(&timerHead, 0, sizeof(Timer));
	timerHead.timerNext = &timerHead;
	timerHead.timerPrev = &timerHead;
	timerHead.expiryTime = OSTimeGet() + MAXJIFFYDELAY;
	timerHead.timerHandler = nullTimer;
	
	/* Initialize the timer free list. */
	timerFree = &timerHeap[0];
	memset(timerFree, 0, sizeof(timerHeap));
	for (i = 0; i < MAXFREETIMERS; i++) {
		timerHeap[i].timerFlags = TIMERFLAG_TEMP;
		timerHeap[i].timerNext = &timerHeap[i + 1];
	}
	timerHeap[MAXFREETIMERS - 1].timerNext = NULL;
	
	/* Start the timer task. */
#ifdef OS_DEPENDENT
	mutex = OSSemCreate(1);
	OSTaskCreate(timerTask, NULL, timerStack+TIMER_STACK_SIZE, PRI_TIMER);
#endif
}


/*
 * timeoutJiffy - Set a timer for a timeout in Jiffy time.  
 * A Jiffy is a system clock tick.  The timer will time out at the
 * specified system time.
 * RETURNS: Zero if OK, otherwise an error code.
 */
INT timeoutJiffy
(
	Timer *timerHdr,			/* Pointer to timer record. */
	ULONG timeout,				/* The timeout in Jiffy time. */
	TIMER_HANDLER_FUNCTION timerHandler,	/* The timer handler function. */
	void *timerArg				/* Arg passed to handler. */
)
{
	Timer *nextTimer;
#ifdef OS_DEPENDENT
    UBYTE err;
#endif
	INT st = 0;
	
	/* Validate parameters. */
	if (!timerHdr || !timerHandler)
		st = -1;
	else {
#ifdef OS_DEPENDENT
		OSSemPend(mutex, 0, &err);
#endif
		/* Check that the timer is not active already. */
		if (timerHdr->timerPrev != NULL) {
			(timerHdr->timerNext)->timerPrev = timerHdr->timerPrev;
			(timerHdr->timerPrev)->timerNext = timerHdr->timerNext;
		}
		
		/* Load the timer record. */
	    timerHdr->expiryTime = timeout;
	    timerHdr->timerHandler = timerHandler;
	    timerHdr->timerArg = timerArg;
	    
	    /* Insert the record in the timer queue. */
		for (nextTimer = timerHead.timerNext;
			nextTimer != &timerHead 
				&& (long)(timerHdr->expiryTime - nextTimer->expiryTime) > 0;
			nextTimer = nextTimer->timerNext
		);
		timerHdr->timerNext = nextTimer;
		(timerHdr->timerPrev = nextTimer->timerPrev)->timerNext = timerHdr;
		nextTimer->timerPrev = timerHdr;
		
#ifdef OS_DEPENDENT
		OSSemPost(mutex);
#endif
	}
	return st;
}



/*
 * timerJiffys - Set a timer in Jiffys.  A Jiffy is a system clock
 * tick.  A delay of zero will invoke the timer handler on the next 
 * Jiffy interrupt.
 * RETURNS: Zero if OK, otherwise an error code.
 */
INT timerJiffys
(
	Timer *timerHdr,				/* Pointer to timer record. */
	ULONG timerDelay,				/* The delay value in Jiffys. */
	TIMER_HANDLER_FUNCTION timerHandler,	/* The timer handler function. */
	void *timerArg					/* Arg passed to handler. */
)
{
	INT st = 0;
	
	/* Validate parameters. */
	if (timerDelay > MAXJIFFYDELAY)
		st = -1;
	else 
		st = timeoutJiffy(timerHdr, timerDelay + OSTimeGet(), timerHandler, timerArg);
		
	return st;
}


/*
 * timerSeconds - Set a timer in seconds.  A delay of zero will
 * invoke the timer handler on the next Jiffy interrupt.
 * RETURNS: Zero if OK, otherwise an error code.
 */
INT timerSeconds
(
	Timer *timerHdr,				/* Pointer to timer record. */
	ULONG timerDelay,				/* The delay value in seconds. */
	TIMER_HANDLER_FUNCTION timerHandler,	/* The timer handler function. */
	void *timerArg					/* Arg passed to handler. */
)
{
    return timeoutJiffy(
    			timerHdr, 
    			OSTimeGet() + timerDelay * TICKSPERSEC, 
    			timerHandler, 
    			timerArg);
}


/*
 * timerTempSeconds - Get a temporary timer from the free list and set
 * it in seconds.  Note that you don't get a handle on the timer record.
 * The record will be automatically returned to the free list when either
 * it expires or it is cancelled.
 *  RETURNS: Zero if OK, otherwise an error code.
 */
INT timerTempSeconds
(
	ULONG timerDelay,				/* The delay value in seconds. */
	TIMER_HANDLER_FUNCTION timerHandler,	/* The timer handler function. */
	void *timerArg					/* Arg passed to handler. */
)
{
	INT st;
#ifdef OS_DEPENDENT
    UBYTE err;
	OSSemPend(mutex, 0, &err);
#endif
	if (timerFree == NULL) {
#ifdef OS_DEPENDENT
		OSSemPost(mutex);
#endif
		TIMERDEBUG((LOG_ERR, "timerTempSeconds: No free timer"));
		st = -1;					/* XXX An allocation error code? */
	}
	else {
		Timer *curTimer = timerFree;
		
		timerFree = timerFree->timerNext;
#ifdef OS_DEPENDENT
		OSSemPost(mutex);
#endif
		
		st = timerJiffys(curTimer, timerDelay * TICKSPERSEC, timerHandler, timerArg);
	}
	return st;
}


/*
 * timerClear() - Clear the given timer.
 */
void timerClear
(
	Timer *timerHdr					/* Pointer to timer record. */
)
{
#ifdef OS_DEPENDENT
    UBYTE err;
#endif
	/* 
	 * Since the queue is circular, a null prev link means the timer is not
	 * on the queue (the free list only uses next).  Otherwise we extract it
	 * and if it's a temporary timer, put it back on the free list.
	 */
#ifdef OS_DEPENDENT
	OSSemPend(mutex, 0, &err);
#endif
	if (timerHdr->timerPrev) {
		(timerHdr->timerNext)->timerPrev = timerHdr->timerPrev;
		(timerHdr->timerPrev)->timerNext = timerHdr->timerNext;
		timerHdr->timerPrev = NULL;
		
		if (timerHdr->timerFlags & TIMERFLAG_TEMP) {
			timerHdr->timerNext = timerFree;
			timerFree = timerHdr;
		}
	}
#ifdef OS_DEPENDENT
	OSSemPost(mutex);
#endif
}

/*
 *	timerCancel - Clear the first matching timer for the given function
 *	pointer and argument.
 */
void timerCancel(
	TIMER_HANDLER_FUNCTION timerHandler,	/* The timer handler function. */
	void *timerArg					/* Arg passed to handler. */
)
{
	Timer *curTimer;
#ifdef OS_DEPENDENT
    UBYTE err;
	OSSemPend(mutex, 0, &err);
#endif
	for (curTimer = timerHead.timerNext;
		curTimer != &timerHead 
			&& (curTimer->timerHandler != timerHandler
				|| curTimer->timerArg != timerArg);
		curTimer = curTimer->timerNext
	);
	if (curTimer != &timerHead) {
		(curTimer->timerNext)->timerPrev = curTimer->timerPrev;
		(curTimer->timerPrev)->timerNext = curTimer->timerNext;
		curTimer->timerPrev = NULL;
		
		if (curTimer->timerFlags & TIMERFLAG_TEMP) {
			curTimer->timerNext = timerFree;
			timerFree = curTimer;
		}
	}
#ifdef OS_DEPENDENT
	OSSemPost(mutex);
#endif
}


/*
 * timerCheck - If there are any expired timers, wake up the timer task.
 * This is designed to be called from within the Jiffy timer interrupt so
 * it has to have minimal overhead.
 */
void timerCheck(void)
{
#ifdef OS_DEPENDENT
    if ((long)(timerHead.timerNext->expiryTime - OSTimeGet()) <= 0)
//	if (timerHead.timerNext->expiryTime < OSTimeGet())
//	if (timerHead.timerNext->expiryTime < jiffyTime())
    {
#ifdef ISS_OS
		PROC_CONTEXT *p;
		p=getThread(timerThreadId);
		ADL_ithreadWake(p);
#else
		(void) OSTaskResume(PRI_TIMER);
#endif
    }
#endif
#if ONETASK_SUPPORT > 0
  // Support for non multitasking environment
  // Call timerTask if a timer has expired
	if ((long)(timerHead.timerNext->expiryTime - OSTimeGet()) <= 0)	timerTask(NULL);
#endif
}


/**********************************/
/*** LOCAL FUNCTION DEFINITIONS ***/
/**********************************/
/*
 * nullTimer - Do nothing.  Used as the timer handler for the sentinal record.
 * This means that the timer interrupt handler doesn't need to do a separate 
 * test for the timer queue being empty.
 */
static void nullTimer(void *x)
{
}

/*
 * The timer handler task.  This is used to service timer handlers that take
 * non-trivial time.
 */
#if (defined (OS_DEPENDENT) || (ONETASK_SUPPORT > 0))
static void timerTask(void *data)
{	
	Timer *thisTimer;
	TIMER_HANDLER_FUNCTION timerHandler;
	void *timerArg;
    UBYTE err;

	for (;;) {
		/* If no ready timers, wait for one.  Note that the mutex is just
		 * to protect the timer queue.  Somebody needs to wake us up when
		 * a timer expires. */
#ifdef OS_DEPENDENT
		OSSemPend(mutex, 0, &err);
#endif
		thisTimer = timerHead.timerNext;
		if ((long)(thisTimer->expiryTime - OSTimeGet()) > 0) {
#ifdef OS_DEPENDENT
			OSSemPost(mutex);

#ifdef ISS_OS
			threadSleep();
#else
			(void) OSTaskSuspend(OS_PRIO_SELF);
#endif
#endif
#if ONETASK_SUPPORT > 0
      // In non multitasking environment - return
      // We don't want to loop for ever!
      return;
#endif
		}
		else {
			/* If the timer is the sentinal, reset the expiry time to the
			 * maximum delay.  This way the timer interrupt handler doesn't
			 * need to do a separate test for the timer queue being empty.
			 */
			if (thisTimer == &timerHead) {
				timerHead.expiryTime = OSTimeGet() + MAXJIFFYDELAY;
			}
			else {
				/* Remove the timer from the queue and if it's marked
				 * as temporary, put it back on the free list. */
				thisTimer = timerHead.timerNext;
				(timerHead.timerNext = thisTimer->timerNext)->timerPrev = &timerHead;
				thisTimer->timerPrev = NULL;
				if (thisTimer->timerFlags & TIMERFLAG_TEMP) {
					thisTimer->timerNext = timerFree;
					timerFree = thisTimer;
				}
			}
			
			/* Update timer counter - used as activity counter for
			 * development purposes. */
			thisTimer->timerCount++;
			
			/* Get the handler parameters which could change when
			 * we post the mutex. */
			timerHandler = thisTimer->timerHandler;
			timerArg = thisTimer->timerArg;
			
			/* Invoke the timer handler.  Make sure that we post the mutex 
			 * first so that we don't deadlock if the handler tries to reset
			 * the timer. */
#ifdef OS_DEPENDENT
			OSSemPost(mutex);
#endif
			timerHandler(timerArg);
		}
	}
}
#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线欧美一区二区| 91久久国产综合久久| 9l国产精品久久久久麻豆| a级精品国产片在线观看| 日韩欧美的一区二区| 美女免费视频一区| 日韩综合一区二区| 欧美高清www午色夜在线视频| 欧美aaaaaa午夜精品| 国产日韩av一区| 国产呦精品一区二区三区网站| 久久青草欧美一区二区三区| 欧美影片第一页| 国产麻豆欧美日韩一区| 亚洲三级小视频| 欧美精选在线播放| 国产麻豆精品在线观看| 婷婷综合在线观看| 国产精品传媒在线| 成熟亚洲日本毛茸茸凸凹| 秋霞午夜av一区二区三区| 国产精品视频看| 日韩精品一区在线| 91影院在线观看| 青椒成人免费视频| 亚洲精品菠萝久久久久久久| 欧美sm极限捆绑bd| 欧美日本韩国一区二区三区视频| 亚洲精品综合在线| 日本一区二区免费在线| 欧美一级一区二区| 欧美性大战xxxxx久久久| www.在线欧美| 成人免费av网站| 国产成人h网站| 久久99国产精品免费| 亚洲免费在线电影| 国产精品美女一区二区在线观看| 欧美精品一区男女天堂| 51精品秘密在线观看| 欧美亚洲图片小说| 成人aaaa免费全部观看| 国产盗摄女厕一区二区三区| 久久99国产精品免费网站| 午夜精品aaa| 欧美一区二区三区四区在线观看| 国产精品一线二线三线| 美美哒免费高清在线观看视频一区二区| 欧美一区永久视频免费观看| 国产一区二区在线影院| 亚洲精品va在线观看| 精品欧美久久久| 一本大道av伊人久久综合| 五月天一区二区三区| 国产色产综合色产在线视频| 在线电影院国产精品| 亚洲国产高清在线| www激情久久| 久久久国际精品| 亚洲女女做受ⅹxx高潮| 亚洲免费av高清| 狠狠色丁香九九婷婷综合五月| 欧美视频一区在线| 久久一留热品黄| 激情文学综合丁香| 激情综合网激情| 日本少妇一区二区| 91理论电影在线观看| 大桥未久av一区二区三区中文| 亚洲一二三级电影| 高清国产一区二区三区| 波多野结衣亚洲| 欧美性色黄大片| 欧美一区二区大片| 国产欧美日韩综合| 一区二区在线观看不卡| 亚洲国产成人91porn| 久久精品国产久精国产爱| 麻豆久久一区二区| 99精品1区2区| 国产麻豆精品在线观看| 国产精品人妖ts系列视频| 亚洲va韩国va欧美va| 秋霞电影网一区二区| 欧美色图免费看| 在线观看三级视频欧美| 亚洲最大色网站| 久久精品一区二区三区不卡| 国产精品午夜免费| 一级女性全黄久久生活片免费| 亚洲一二三区视频在线观看| 视频在线观看91| 全部av―极品视觉盛宴亚洲| 韩国精品免费视频| 97久久人人超碰| 99久久亚洲一区二区三区青草| 色婷婷综合久久| 欧美一区二区三区的| 国产精品毛片无遮挡高清| 亚洲婷婷国产精品电影人久久| 中文字幕一区二区不卡| 亚洲国产va精品久久久不卡综合| 男女性色大片免费观看一区二区| 韩国av一区二区三区在线观看| 不卡一卡二卡三乱码免费网站| aaa亚洲精品| 正在播放一区二区| 中文字幕av一区 二区| 亚洲午夜av在线| 国模娜娜一区二区三区| 国产精品自拍在线| 色欧美88888久久久久久影院| 精品国精品自拍自在线| 亚洲精品乱码久久久久久黑人| 精品一区二区三区免费视频| 欧美主播一区二区三区美女| 久久久综合视频| 天天综合色天天综合| www.av精品| 精品国产免费一区二区三区四区| 国产精品久久久久久一区二区三区| 亚洲3atv精品一区二区三区| 中文字幕一区二区三区四区 | 欧美一a一片一级一片| 日韩精品一区在线| 国产精品色一区二区三区| 韩国女主播成人在线| 欧美伊人精品成人久久综合97| 中文字幕日韩av资源站| 国产福利精品导航| 欧美日本韩国一区二区三区视频| 日韩理论在线观看| 国产乱人伦偷精品视频不卡| 精品粉嫩超白一线天av| 丝袜美腿亚洲综合| 91麻豆精品国产无毒不卡在线观看 | 狠狠色丁香婷婷综合久久片| 欧美视频精品在线观看| 亚洲一区视频在线| 91在线精品一区二区| 中文字幕一区二区三| 丰满少妇久久久久久久| 精品国产91乱码一区二区三区 | 日本va欧美va欧美va精品| 欧美乱妇一区二区三区不卡视频| 一区精品在线播放| 国产成人av福利| 国产精品久久久久影视| 国产成人一级电影| 国产精品久久久久久久岛一牛影视| 狠狠色丁香久久婷婷综合_中| 欧美精品在线一区二区| 理论片日本一区| 制服丝袜亚洲色图| 国产一区二区精品久久| 精品国产伦一区二区三区观看方式| 亚洲国产欧美日韩另类综合 | 国产高清亚洲一区| 国产精品护士白丝一区av| 国产.精品.日韩.另类.中文.在线.播放| 国产日韩欧美综合在线| 成人国产精品免费观看视频| 国产精品亲子乱子伦xxxx裸| 在线观看免费一区| 污片在线观看一区二区| 精品国产乱子伦一区| 国产a区久久久| 久久一区二区三区四区| 99久久伊人精品| 国产精品久久久久四虎| 欧美色欧美亚洲另类二区| 天堂一区二区在线| 久久人人爽爽爽人久久久| 丁香六月久久综合狠狠色| 亚洲综合精品自拍| 91精品国产91久久久久久一区二区 | 99精品欧美一区| 亚洲一区二区免费视频| 欧美色涩在线第一页| 久久精品国产99国产精品| 久久精品亚洲精品国产欧美| 色一情一乱一乱一91av| 丝袜美腿亚洲色图| 国产精品美女久久久久久| 91福利精品第一导航| 狠狠色丁香久久婷婷综| 最新成人av在线| 日韩美女视频在线| 成熟亚洲日本毛茸茸凸凹| 五月天国产精品| 国产日产欧产精品推荐色| 欧美性极品少妇| 国产激情一区二区三区四区| 亚洲人成网站影音先锋播放| 91精品国产免费久久综合| 激情综合网天天干| 亚洲黄色录像片| 在线免费精品视频| 大胆亚洲人体视频| 五月婷婷激情综合网|