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

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

?? tcp.c

?? 在freescale 的ne64上開發的源代碼
?? C
?? 第 1 頁 / 共 5 頁
字號:
			/* Is there unacked data?	*/
			
			if(soc->send_unacked == soc->send_next ) {
				/* There is no unacked data	*/
				
				soc->myflags = TCP_FLAG_ACK | TCP_FLAG_FIN;
				soc->send_next++;
				tcp_sendcontrol(sochandle);
				tcp_newstate(soc, TCP_STATE_FINW1);				
			} else {
				/* Can't do much but raise pollable flag to soc->flags		*/
				/* and process it on tcp_poll								*/
				
				soc->flags |= TCP_INTFLAGS_CLOSEPENDING;
				
				
				return(sochandle);
			}
		
			break;
	
		default:
			return(-1);
	}
	
	return(sochandle);

}



/** \brief Get current state of the socket
 *  \ingroup tcp_app_api
 * 	\author 
 *		\li Jari Lahti (jari.lahti@violasystems.com)
 *	\date 21.07.2002
 *	\param sochandle handle to the socket to be queried
 *	\return
 *		\li -1 - Error
 *		\li >0 - Socket state
 *
 *	Use this function for querying socket state. This is usually not needed
 *	directly, but could be usefull for some special purposes.
 */
INT8 tcp_getstate (INT8 sochandle)
{
	struct tcb* soc;

	if( sochandle > NO_OF_TCPSOCKETS ) {
//		//TCP_DEBUGOUT("Socket handle non-valid\r\n");
		return(-1);
	}
	
	if( sochandle < 0 ) {
//		//TCP_DEBUGOUT("Socket handle non-valid\r\n");
		return(-1);
	}
	
	soc = &tcp_socket[sochandle];		/* Get referense	*/	

	return(soc->state);

}


/** \brief Checks if it's possible to send data using given socket
 *  \ingroup tcp_app_api
 * 	\author 
 *		\li Jari Lahti (jari.lahti@violasystems.com)
 *	\date 23.07.2002
 *	\param sochandle handle to the socket to be inspected
 *	\return
 *		\li -1 - not possible to send over a socket (previously sent data is
 *		still not akcnowledged)
 *		\li >0 - it is possible to send data over a socket
 *
 *	Invoke this function to get information whether it is possible to send
 *	data or not. This may, sometimes, be preffered way of getting this type
 *	of information to waiting for #TCP_EVENT_ACK in event_listener function.
 */
INT16 tcp_checksend (INT8 sochandle)
{
	struct tcb* soc;

	if( sochandle > NO_OF_TCPSOCKETS ) {
//		//TCP_DEBUGOUT("Socket handle non-valid\r\n");
		return(-1);
	}
	
	soc = &tcp_socket[sochandle];		/* Get referense	*/	
	
	if(soc->state != TCP_STATE_CONNECTED)
		return(-1);

	if(soc->send_unacked == soc->send_next)
		return(soc->send_mtu);
	
	return(-1);


}



/** \brief Reset connection and place socket to closed state
 *  \ingroup tcp_app_api
 * 	\author 
 *		\li Jari Lahti (jari.lahti@violasystems.com)
 *	\date 21.07.2002
 *	\param sochandle handle to socket to be aborted
 *	\return
 *		\li -1 - error
 *		\li >=0 - OK (value represents handle to aborted socket)
 *
 *	Use this function in cases when TCP connection must be immediately closed.
 *	Note that the preffered (more elegant) way of closing the TCP connection
 *	is to invoke tcp_close() which starts a proper closing procedure.
 *	tcp_abort should be used only in cases when it is really necessary to 
 *	immediately and quickly close the connection.
 */
INT8 tcp_abort (INT8 sochandle)
{
	struct tcb* soc;
	
//	//TCP_DEBUGOUT("FUNCTION: tcp_abort\r\n");

	if( sochandle > NO_OF_TCPSOCKETS ) {
//		//TCP_DEBUGOUT("Socket handle non-valid\r\n");
		return(-1);
	}
	
	if( sochandle < 0 ) {
//		//TCP_DEBUGOUT("Socket handle non-valid\r\n");
		return(-1);
	}
	
	soc = &tcp_socket[sochandle];		/* Get referense	*/	

	switch (soc->state)	{
		case TCP_STATE_FREE:
			return(-1);
			
		case TCP_STATE_RESERVED:
		case TCP_STATE_CLOSED:
			return(sochandle);
		
		case TCP_STATE_TIMED_WAIT:
		case TCP_STATE_LISTENING:
			tcp_newstate(soc, TCP_STATE_CLOSED);
			return(sochandle);
		
		case TCP_STATE_SYN_SENT:
		case TCP_STATE_SYN_RECEIVED:
		case TCP_STATE_CONNECTED:
		case TCP_STATE_FINW1:
		case TCP_STATE_FINW2:
		case TCP_STATE_CLOSING:
		case TCP_STATE_LAST_ACK:
		
			soc->myflags = TCP_FLAG_RESET;
			tcp_sendcontrol(sochandle);
			tcp_newstate(soc, TCP_STATE_CLOSED);
			return(sochandle);
			
		default:
			return(-1);
	}
	

}



/** \brief Poll TCP sockets periodically
 *	\ingroup periodic_functions
 * 	\author 
 *		\li Jari Lahti (jari.lahti@violasystems.com)
 *	\date 19.07.2002
 *	\warning
 *		\li This function <b>must be</b> invoked periodically from 
 *		the main loop. See main_demo.c for an example.
 *
 *	This function checks all TCP sockets and performs various actions 
 * 	if timeouts occur. What kind of action is performed is defined by the
 *	state of the TCP socket.
 */
void tcp_poll (void)
{
	struct tcb* soc;
	static UINT8 handle = 0;
	UINT8 i;
	INT32 temp;
	UINT8 old_retries;
	
	for(i=0; i < NO_OF_TCPSOCKETS; i++ ) {
		
		if(handle > NO_OF_TCPSOCKETS)
			handle = 0;

		soc = &tcp_socket[handle];
		
		switch(soc->state) {
			case TCP_STATE_FREE:
			case TCP_STATE_RESERVED:
			case TCP_STATE_CLOSED:
			case TCP_STATE_LISTENING:
				
				break;
				
			case TCP_STATE_CONNECTED:
			
				/* In CONNECTED State we have					*/ 
				/* something to do only if we have unacked data	*/
				/* or if connection has been IDLE too long or 	*/
				/* unserved close is isuued by user				*/
				
				/*if(soc->send_next > soc->send_unacked)
					temp = soc->send_next - soc->send_unacked;
				else
					temp = soc->send_unacked - soc->send_next;
				*/
				
				temp = soc->send_next - soc->send_unacked;
				
				/* Unserved Close?			*/
				
				if(soc->flags & TCP_INTFLAGS_CLOSEPENDING) {
					/* Can we send the close now	*/
					
					if(temp == 0) {
						soc->myflags = TCP_FLAG_ACK | TCP_FLAG_FIN;
						soc->send_next++;
						tcp_sendcontrol(handle);
						tcp_newstate(soc, TCP_STATE_FINW1);	
						soc->flags ^= TCP_INTFLAGS_CLOSEPENDING;
						
						handle++;
						
						return;		
						
					}
				}
				
				/* Socket timeout?			*/
				
				if(check_timer((UINT8)(soc->persist_timerh)) == 0) 
				{
				
					soc->myflags = TCP_FLAG_ACK | TCP_FLAG_FIN;
					soc->send_next++;
					tcp_sendcontrol(handle);
					tcp_newstate(soc, TCP_STATE_FINW1);	
					
					/* Inform application	*/
					
					(void)soc->event_listener(handle, TCP_EVENT_CLOSE, soc->rem_ip, soc->remport);
					
					handle++;
		
					return;			
				}	
				
				/* Is there unacked data?	*/
				
				if(temp == 0)
					break;
				
				/* Is there timeout?					*/
				
				if( check_timer((UINT8)(soc->retransmit_timerh)) != 0 )
					break;
				
				/* De we have retries left				*/
				
				if(soc->retries_left == 0) {
					/* No retries, must reset	*/
					
	//				//TCP_DEBUGOUT("Retries used up, resetting\r\n");
					
					soc->myflags = TCP_FLAG_RESET;
					tcp_sendcontrol(handle);
					
					/* Inform application	*/

					(void)soc->event_listener(handle, TCP_EVENT_ABORT, soc->rem_ip, soc->remport);
				
					if(soc->type & TCP_TYPE_SERVER )
						tcp_newstate(soc, TCP_STATE_LISTENING);
					else
						tcp_newstate(soc, TCP_STATE_CLOSED);
					
					handle++;
		
					return;										
				}
				
				soc->retries_left--;
				init_timer((UINT8)(soc->retransmit_timerh), TCP_DEF_RETRY_TOUT*TIMERTIC);
								
				/* Yep, there is unacked data			*/
				/* Application should send the old data	*/
				
				if(temp>soc->send_mtu)
					temp = soc->send_mtu;
				
				/* Rewind Send Next because the send process will adjust it			*/
				/* So cheat the tcp_send to think there is no unacked data			*/
				
				soc->send_next = soc->send_unacked;
				
				/* tcp_send will set the retiries_left to maximum but this is		*/
				/* retransmitting already so we need to retain it in order to 		*/
				/* avoid dead-lock													*/
				
				old_retries = soc->retries_left;
				
				temp = soc->event_listener(handle, TCP_EVENT_REGENERATE, (UINT32)temp, 0);
				soc->retries_left = old_retries;
			
				if(temp <= 0) {
					
					/* No data by application, must be something wrong	*/
					soc->myflags = TCP_FLAG_RESET;
					tcp_sendcontrol(handle);
					
					/* Inform application	*/

					(void)soc->event_listener(handle, TCP_EVENT_ABORT, soc->rem_ip, soc->remport);
									
					if(soc->type & TCP_TYPE_SERVER )
						tcp_newstate(soc, TCP_STATE_LISTENING);
					else
						tcp_newstate(soc, TCP_STATE_CLOSED);
					
					handle++;
		
					return;					
					
				}
				
				/* Application has send data	*/
				
				handle++;
		
				return;
				
			
			case TCP_STATE_SYN_SENT:
			case TCP_STATE_SYN_RECEIVED:
			
				/* Is there timeout?	*/
				if( check_timer((UINT8)(soc->retransmit_timerh)) != 0 )
					break;
					
	//			//TCP_DEBUGOUT("Timeout\r\n");
					
				/* Yep, timeout. Is there reties left?	*/
				if( soc->retries_left ) {
					soc->retries_left--;
					if(soc->state == TCP_STATE_SYN_SENT)
						init_timer((UINT8)(soc->retransmit_timerh), TCP_SYN_RETRY_TOUT*TIMERTIC);
					else
						init_timer((UINT8)(soc->retransmit_timerh), TCP_DEF_RETRY_TOUT*TIMERTIC);

					tcp_sendcontrol(handle);
					
					handle++;
		
					return;				
				} else {
					/* Retries used up	*/
//					//TCP_DEBUGOUT("Retries used up, resetting\r\n");
					
					if(soc->type & TCP_TYPE_SERVER )
						tcp_newstate(soc, TCP_STATE_LISTENING);
					else
						tcp_newstate(soc, TCP_STATE_CLOSED);
					
					soc->myflags = TCP_FLAG_RESET;
					tcp_sendcontrol(handle);
					
					/* Inform application	*/

					(void)soc->event_listener(handle, TCP_EVENT_ABORT, soc->rem_ip, soc->remport);
					
					handle++;
		
					return;
				}
				
				break;
				
			case TCP_STATE_TIMED_WAIT:
				
				/* Is there timeout?	*/
				
				if( check_timer((UINT8)(soc->retransmit_timerh)) != 0 )
					break;
					
//				//TCP_DEBUGOUT("Timeout\r\n");
				
				if(soc->retries_left) {
					soc->retries_left--;
					init_timer((UINT8)(soc->retransmit_timerh), TCP_DEF_RETRY_TOUT*TIMERTIC);
					break;
				}
				
				if(soc->type & TCP_TYPE_SERVER )
					tcp_newstate(soc, TCP_STATE_LISTENING);
				else
					tcp_newstate(soc, TCP_STATE_CLOSED);
					
				break;
			
			case TCP_STATE_LAST_ACK:
			case TCP_STATE_FINW1:
			case TCP_STATE_CLOSING:
			
				/* Is there timeout?	*/
				
				if( check_timer((UINT8)(soc->retransmit_timerh)) != 0 )
					break;
					
//				//TCP_DEBUGOUT("Timeout\r\n");		
						
				/* Yep, timeout. Is there reties left?	*/
				
				if( soc->retries_left ) {
					soc->retries_left--;
					init_timer((UINT8)(soc->retransmit_timerh), TCP_DEF_RETRY_TOUT*TIMERTIC);
					soc->myflags = TCP_FLAG_FIN | TCP_FLAG_ACK;
					tcp_sendcontrol(handle);
					
					handle++;
		

					return;				
				} else {
					/* Retries used up	*/
//					//TCP_DEBUGOUT("Retries used up, resetting\r\n");
					
					if(soc->type & TCP_TYPE_SERVER )
						tcp_newstate(soc, TCP_STATE_LISTENING);
					else
						tcp_newstate(soc, TCP_STATE_CLOSED);
					
					soc->myflags = TCP_FLAG_RESET;
					tcp_sendcontrol(handle);
					
					/* Inform application	*/

					(void)soc->event_listener(handle, TCP_EVENT_ABORT, soc->rem_ip, soc->remport);
					
					handle++;
		
					return;
				}			
				
				break;
			
			case TCP_STATE_FINW2:
			
				/* Is there timeout?	*/
				
				if( check_timer((UINT8)(soc->retransmit_timerh)) != 0 )
					break;
					
//				//TCP_DEBUGOUT("Timeout\r\n");		
						
				/* Yep, timeout. Is there reties left?	*/
				
				if( soc->retries_left )	{
					/* Still keep waiting for FIN	*/
				
					soc->retries_left--;
					init_timer((UINT8)(soc->retransmit_timerh), TCP_DEF_RETRY_TOUT*TIMERTIC);
					break;			
				} else {
					/* Retries used up	*/
//					//TCP_DEBUGOUT("Retries used up, resetting\r\n");
					
					if(soc->type & TCP_TYPE_SERVER )
						tcp_newstate(soc, TCP_STATE_LISTENING);
					else
						tcp_newstate(soc, TCP_STATE_CLOSED);
					
					soc->myflags = TCP_FLAG_RESET;
					tcp_sendcontrol(handle);
					
					/* Inform application	*/

					(void)soc->event_listener(handle, TCP_EVENT_ABORT, soc->rem_ip, soc->remport);
				
					handle++;
		
					return;
				}	

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久夜| 日韩一区在线看| 国产精品欧美一区二区三区| 中文字幕一区二区三区四区| 日韩精品中文字幕在线一区| 欧美经典三级视频一区二区三区| 亚洲v日本v欧美v久久精品| 国内不卡的二区三区中文字幕| 色综合久久中文字幕| 精品国产精品网麻豆系列| 一卡二卡欧美日韩| 国产成人免费视频一区| 欧美丰满美乳xxx高潮www| 国产精品国产自产拍高清av | 欧美最猛性xxxxx直播| 久久亚洲精品小早川怜子| 午夜日韩在线电影| aaa国产一区| 国产女同互慰高潮91漫画| 精品国产91乱码一区二区三区| 悠悠色在线精品| 国产成人av自拍| 精品国产凹凸成av人导航| 日韩在线a电影| 欧美日韩亚洲综合一区二区三区 | 欧美久久一二区| 亚洲欧美国产三级| 成a人片亚洲日本久久| 国产成人丝袜美腿| 欧美电视剧免费全集观看| 亚洲国产精品久久艾草纯爱| 99精品视频在线播放观看| 久久精品综合网| 国产成人精品免费在线| www国产成人免费观看视频 深夜成人网| 午夜精品一区二区三区免费视频| 在线一区二区三区做爰视频网站| 1024国产精品| 日本亚洲视频在线| 日韩手机在线导航| 久久成人麻豆午夜电影| 欧美成人精品二区三区99精品| 久久狠狠亚洲综合| 久久综合色8888| 国产成人亚洲综合a∨婷婷| 久久精品一区蜜桃臀影院| 国产.欧美.日韩| 亚洲欧美日韩久久| 欧美午夜理伦三级在线观看| 日韩一区二区三区在线| 激情综合网av| 日韩毛片精品高清免费| 精品视频全国免费看| 天堂精品中文字幕在线| 日韩一级在线观看| 久久9热精品视频| 色就色 综合激情| 亚洲激情综合网| 欧美中文字幕亚洲一区二区va在线| 精品国产网站在线观看| 欧美极品美女视频| aaa亚洲精品| 亚洲丶国产丶欧美一区二区三区| 欧美三级视频在线观看| 亚洲18色成人| 精品久久久久久无| 蜜乳av一区二区三区| 精品av久久707| 处破女av一区二区| 亚洲人成在线观看一区二区| 色哟哟亚洲精品| 欧美一二三四在线| 国产成人高清在线| 亚洲黄网站在线观看| 欧美区在线观看| 久久99国产精品免费| 国产精品网站在线| 丁香婷婷深情五月亚洲| 亚洲国产精品高清| 欧美三级视频在线观看| 免费观看91视频大全| 亚洲素人一区二区| 欧美日韩亚洲另类| 久久精品在这里| 在线视频你懂得一区| 日产国产高清一区二区三区| 亚洲精品在线免费播放| 一本大道久久a久久综合婷婷 | 成人在线综合网| 亚洲美女淫视频| 日韩一级片网站| av电影一区二区| 久久精品国产秦先生| 国产精品欧美一级免费| 欧美久久久久久蜜桃| 精品一区二区三区免费播放| 亚洲卡通欧美制服中文| 久久综合色8888| 欧美日韩美少妇| 不卡的电视剧免费网站有什么| 午夜激情一区二区| 亚洲视频网在线直播| 欧美zozo另类异族| 成人精品视频.| 美女脱光内衣内裤视频久久网站| 亚洲欧洲精品天堂一级 | 欧美综合一区二区| 国产一区二区影院| 日本欧美加勒比视频| 亚洲丝袜美腿综合| 67194成人在线观看| 丁香桃色午夜亚洲一区二区三区| 日韩在线一区二区三区| 亚洲欧美日韩在线| 欧美国产1区2区| 精品国产麻豆免费人成网站| 69堂国产成人免费视频| 欧洲激情一区二区| aaa国产一区| 成人激情免费网站| av亚洲精华国产精华精| 国产成人免费视| 国产视频不卡一区| 26uuu成人网一区二区三区| 日韩三级视频在线观看| 欧美日韩精品一区二区三区蜜桃| 色悠悠久久综合| 日本高清不卡视频| 亚洲福利视频导航| 一二三区精品福利视频| 亚洲码国产岛国毛片在线| 成人欧美一区二区三区小说| 久久亚洲春色中文字幕久久久| 日韩精品综合一本久道在线视频| 欧美一区二区三区人| 日韩午夜在线观看视频| 欧美一级理论性理论a| 欧美三区在线视频| 欧美放荡的少妇| 日韩三级视频在线观看| 极品美女销魂一区二区三区| 久久99精品国产91久久来源| 国产在线乱码一区二区三区| 国产毛片精品视频| 国产福利91精品| 国产麻豆91精品| 欧洲一区在线电影| 7777精品伊人久久久大香线蕉超级流畅| 91精品国产综合久久精品| 3d成人h动漫网站入口| 中文av字幕一区| 国产精品女同互慰在线看 | 国产亚洲精品bt天堂精选| 久久人人爽人人爽| 久久蜜桃香蕉精品一区二区三区| 国产精品精品国产色婷婷| 亚洲女人的天堂| 日韩激情视频在线观看| 极品少妇xxxx精品少妇| 成人丝袜高跟foot| 在线观看欧美日本| 精品久久免费看| 亚洲国产视频在线| 久久99精品国产.久久久久| 成人理论电影网| av中文字幕亚洲| 欧美日韩高清影院| 国产人成亚洲第一网站在线播放| 亚洲色图另类专区| 日韩**一区毛片| www.欧美精品一二区| 99久久婷婷国产| 国产三级一区二区三区| 一区二区免费视频| 国产尤物一区二区| 欧美午夜电影网| 日本一区二区三区四区| 亚洲va欧美va天堂v国产综合| 久久激情五月婷婷| 欧美日韩精品高清| 国产精品女同互慰在线看| 日本va欧美va精品发布| 成人福利视频网站| 91精品免费观看| 中文字幕一区二区三区精华液| 天天色天天操综合| 国内精品自线一区二区三区视频| av男人天堂一区| 久久久99久久| 日本不卡123| 在线精品视频一区二区三四 | 欧美丰满少妇xxxxx高潮对白 | 国产成人av电影在线| 欧美大片在线观看一区二区| 亚洲欧洲日韩av| 国产盗摄女厕一区二区三区| 日韩视频中午一区| 亚洲成a人片在线不卡一二三区| 国产精品18久久久久久久久久久久| 91成人免费在线|