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

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

?? tcpsock.c

?? uCLinux下的一個TCP/IP協議棧源碼
?? C
字號:
#include "global.h"
#include "tcp.h"
#include "socket.h"
#include "usock.h"

static void s_trcall(struct tcb *tcb,int32 cnt);
static void s_tscall(struct tcb *tcb,int old,int new);
static void s_ttcall(struct tcb *tcb,int32 cnt);
static void trdiscard(struct tcb *tcb,int32 cnt);
static void autobind(struct usock *up);

uint16 Lport = 1024;

int
so_tcp(struct usock *up,int protocol)
{
	up->type = TYPE_TCP;
	return 0;
}
int
so_tcp_listen(struct usock *up,int backlog)
{
	struct sockaddr_in *local;
	struct socket lsock;

	if(up->name == NULL)
		autobind(up);

	local = (struct sockaddr_in *)up->name;
	lsock.address = local->sin_addr.s_addr;
	lsock.port = local->sin_port;
	up->cb.tcb = open_tcp(&lsock,NULL,
	 backlog ? TCP_SERVER:TCP_PASSIVE,0,
	s_trcall,s_ttcall,s_tscall,up->tos,up->index);
	return 0;
}
int
so_tcp_conn(struct usock *up)
{
	int s;
	struct tcb *tcb;
	struct socket lsock,fsock;
	struct sockaddr_in *local,*remote;

	if(up->name == NULL){
		autobind(up);
	}
	
	if(checkipaddr(up->peername,up->peernamelen) == -1){
		errno = EAFNOSUPPORT;
		return -1;
	}
	s = up->index;
	/* Construct the TCP-style ports from the sockaddr structs */
	local = (struct sockaddr_in *)up->name;
	remote = (struct sockaddr_in *)up->peername;

	if(local->sin_addr.s_addr == INADDR_ANY)
		/* Choose a local address */
		local->sin_addr.s_addr = locaddr(remote->sin_addr.s_addr);

	lsock.address = local->sin_addr.s_addr;
	lsock.port = local->sin_port;
	fsock.address = remote->sin_addr.s_addr;
	fsock.port = remote->sin_port;

	/* Open the TCB in active mode */
	up->cb.tcb = open_tcp(&lsock,&fsock,TCP_ACTIVE,0,
	 s_trcall,s_ttcall,s_tscall,up->tos,s);

	/* Wait for the connection to complete */
	while((tcb = up->cb.tcb) != NULL && tcb->state != TCP_ESTABLISHED){
		if(up->noblock){
			errno = EWOULDBLOCK;
			return -1;
		} else if((errno = kwait(up)) != 0){
			return -1;
		}
	}
	if(tcb == NULL){
		/* Probably got refused */
		FREE(up->peername);
		errno = ECONNREFUSED;
		return -1;
	}
	return 0;
}
int
so_tcp_recv(struct usock *up,struct mbuf **bpp,struct sockaddr *from,
 int *fromlen)
{
	long cnt;
	struct tcb *tcb;

	while((tcb = up->cb.tcb) != NULL && tcb->r_upcall != trdiscard
	 && (cnt = recv_tcp(tcb,bpp,0)) == -1){
		if(up->noblock){
			errno = EWOULDBLOCK;
			return -1;
		} else if((errno = kwait(up)) != 0){
			return -1;
		}
	}
	if(tcb == NULL){
		/* Connection went away */
		errno = ENOTCONN;
		return -1;
	} else if(tcb->r_upcall == trdiscard){
		/* Receive shutdown has been done */
		errno = ENOTCONN;	/* CHANGE */
		return -1;
	}
	return cnt;
}
int
so_tcp_send(struct usock *up,struct mbuf **bpp,struct sockaddr *to)
{
	struct tcb *tcb;
	long cnt;

	if((tcb = up->cb.tcb) == NULL){
		free_p(bpp);
		errno = ENOTCONN;
		return -1;
	}		
	cnt = send_tcp(tcb,bpp);

	while((tcb = up->cb.tcb) != NULL &&
	 tcb->sndcnt > tcb->window){
		/* Send queue is full */
		if(up->noblock){
			errno = EWOULDBLOCK;
			return -1;
		} else if((errno = kwait(up)) != 0){
			return -1;
		}
	}
	if(tcb == NULL){
		errno = ENOTCONN;
		return -1;
	}
	return cnt;
}
int
so_tcp_qlen(struct usock *up,int rtx)
{
	int len;

	switch(rtx){
	case 0:
		len = up->cb.tcb->rcvcnt;
		break;
	case 1:
		len = up->cb.tcb->sndcnt;
		break;
	}
	return len;
}
int
so_tcp_kick(struct usock *up)
{
	kick_tcp(up->cb.tcb);
	return 0;
}
int
so_tcp_shut(struct usock *up,int how)
{
	switch(how){
	case 0:	/* No more receives -- replace upcall */
		up->cb.tcb->r_upcall = trdiscard;
		break;
	case 1:	/* Send EOF */
		close_tcp(up->cb.tcb);
		break;
	case 2:	/* Blow away TCB */
		reset_tcp(up->cb.tcb);
		up->cb.tcb = NULL;
		break;
	}
	return 0;
}
int
so_tcp_close(struct usock *up)
{
	if(up->cb.tcb != NULL){	/* In case it's been reset */
		up->cb.tcb->r_upcall = trdiscard;
		/* Tell the TCP_CLOSED upcall there's no more socket */
		up->cb.tcb->user = -1;
		close_tcp(up->cb.tcb);
	}
	return 0;
}
/* TCP receive upcall routine */
static void
s_trcall(struct tcb *tcb,int32 cnt)
{
	/* Wake up anybody waiting for data, and let them run */
	ksignal(itop(tcb->user),1);
	kwait(NULL);
}
/* TCP transmit upcall routine */
static void
s_ttcall(struct tcb *tcb,int32 cnt)
{
	/* Wake up anybody waiting to send data, and let them run */
	ksignal(itop(tcb->user),1);
	kwait(NULL);
}
/* TCP state change upcall routine */
static void
s_tscall(struct tcb *tcb,int old,int new)
{
	int s,ns;
	struct usock *up,*nup,*oup;
	union sp sp;

	s = tcb->user;
	oup = up = itop(s);

	switch(new){
	case TCP_CLOSED:
		/* Clean up. If the user has already closed the socket,
		 * then up will be null (s was set to -1 by the close routine).
		 * If not, then this is an abnormal close (e.g., a reset)
		 * and clearing out the pointer in the socket structure will
		 * prevent any further operations on what will be a freed
		 * control block. Also wake up anybody waiting on events
		 * related to this tcb so they will notice it disappearing.
		 */
		if(up != NULL){
			up->cb.tcb = NULL;
			up->errcodes[0] = tcb->reason;
			up->errcodes[1] = tcb->type;
			up->errcodes[2] = tcb->code;
			ksignal(up,0); /* Wake up anybody waiting */
		}
		del_tcp(tcb);
		break;
	case TCP_SYN_RECEIVED:
		/* Handle an incoming connection. If this is a server TCB,
		 * then we're being handed a "clone" TCB and we need to
		 * create a new socket structure for it. In either case,
		 * find out who we're talking to and wake up the guy waiting
		 * for the connection.
		 */
		if(tcb->flags.clone){
			/* Clone the socket */
			ns = socket(AF_INET,SOCK_STREAM,0);
			nup = itop(ns);
			ASSIGN(*nup,*up);
			tcb->user = ns;
			nup->cb.tcb = tcb;
			/* Allocate new memory for the name areas */
			nup->name = mallocw(SOCKSIZE);
			nup->peername = mallocw(SOCKSIZE);
			nup->index = ns;
			/* Store the new socket # in the old one */
			up->rdysock = ns;
			up = nup;
			s = ns;
		} else {
			/* Allocate space for the peer's name */
			up->peername = mallocw(SOCKSIZE);
			/* Store the old socket # in the old socket */
			up->rdysock = s;
		}
		/* Load the addresses. Memory for the name has already
		 * been allocated, either above or in the original bind.
		 */
		sp.sa = up->name;
		sp.in->sin_family = AF_INET;
		sp.in->sin_addr.s_addr = up->cb.tcb->conn.local.address;
		sp.in->sin_port = up->cb.tcb->conn.local.port;
		up->namelen = SOCKSIZE;

		sp.sa = up->peername;
		sp.in->sin_family = AF_INET;
		sp.in->sin_addr.s_addr = up->cb.tcb->conn.remote.address;
		sp.in->sin_port = up->cb.tcb->conn.remote.port;
		up->peernamelen = SOCKSIZE;

		/* Wake up the guy accepting it, and let him run */
		ksignal(oup,1);
		kwait(NULL);
		break;
	default:	/* Ignore all other state transitions */
		break;
	}
	ksignal(up,0);	/* In case anybody's waiting */
}
/* Discard data received on a TCP connection. Used after a receive shutdown or
 * close_s until the TCB disappears.
 */
static void
trdiscard(struct tcb *tcb,int32 cnt)
{
	struct mbuf *bp;

	recv_tcp(tcb,&bp,cnt);
	free_p(&bp);
}

/* Issue an automatic bind of a local address */
static void
autobind(struct usock *up)
{
	struct sockaddr_in local;

	local.sin_family = AF_INET;
	local.sin_addr.s_addr = INADDR_ANY;
	local.sin_port = Lport++;
	bind(up->index,(struct sockaddr *)&local,sizeof(struct sockaddr_in));
}
char *
tcpstate(struct usock *up)
{
	if(up->cb.tcb == NULL)
		return NULL;
	return Tcpstates[up->cb.tcb->state];
}
int
so_tcp_stat(struct usock *up)
{
	st_tcp(up->cb.tcb);
	return 0;
}

struct inet {
	struct inet *next;
	struct tcb *tcb;
	char *name;
	int stack;
	void (*task)(int,void *,void *);
};
#define	NULLINET	(struct inet *)0
struct inet *Inet_list;

static void i_upcall(struct tcb *tcb,int oldstate,int newstate);


/* Start a TCP server. Create TCB in listen state and post upcall for
 * when a connection comes in
 */ 
int
start_tcp(uint16 port,char *name,void (*task)(int,void *,void *),int stack)
{
	struct inet *in;
	struct socket lsocket;

	in = (struct inet *)calloc(1,sizeof(struct inet));
	lsocket.address = INADDR_ANY;
	lsocket.port = port;
	in->tcb = open_tcp(&lsocket,NULL,TCP_SERVER,0,NULL,NULL,i_upcall,0,-1);
	if(in->tcb == NULL){
		free(in);
		return -1;
	}
	in->stack = stack;
	in->task = task;
	in->name = strdup(name);
	in->next = Inet_list;
	Inet_list = in;
	return 0;
}

/* State change upcall that takes incoming TCP connections */
static void
i_upcall(struct tcb *tcb,int oldstate,int newstate)
{
	struct inet *in;
	struct sockaddr_in sock;
	struct usock *up;
	int s;

	if(oldstate != TCP_LISTEN)
		return;	/* "can't happen" */
	if(newstate == TCP_CLOSED){
		/* Called when server is shut down */
		del_tcp(tcb);
		return;
	}
	for(in = Inet_list;in != NULLINET;in = in->next)
		if(in->tcb->conn.local.port == tcb->conn.local.port)
			break;
	if(in == NULLINET)
		return;	/* not in table - "can't happen" */

	/* Create a socket, hook it up with the TCB */
	s = socket(AF_INET,SOCK_STREAM,0);
	up = itop(s);
	sock.sin_family = AF_INET;
	sock.sin_addr.s_addr = tcb->conn.local.address;
	sock.sin_port = tcb->conn.local.port;
	bind(s,(struct sockaddr *)&sock,SOCKSIZE);

	sock.sin_addr.s_addr = tcb->conn.remote.address;
	sock.sin_port = tcb->conn.remote.port;
	up->peernamelen = SOCKSIZE;
	up->peername = mallocw(up->peernamelen);
	memcpy(up->peername,&sock,SOCKSIZE);
	up->cb.tcb = tcb;
	tcb->user = s;

	/* Set the normal upcalls */
	tcb->r_upcall = s_trcall;
	tcb->t_upcall = s_ttcall;
	tcb->s_upcall = s_tscall;

	/* And spawn the server task */
	newproc(in->name,in->stack,in->task,s,NULL,NULL,0);
}
/* Close down a TCP server created earlier by inet_start */
int
stop_tcp(uint16 port)
{
	struct inet *in,*inprev;

	inprev = NULLINET;
	for(in = Inet_list;in != NULLINET;inprev=in,in = in->next)
		if(in->tcb->conn.local.port == port)
			break;
	if(in == NULLINET)
		return -1;
	close_tcp(in->tcb);
	free(in->name);
	if(inprev != NULLINET)
		inprev->next = in->next;
	else
		Inet_list = in->next;
	free(in);
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91精品在线麻豆| 91黄色激情网站| 视频一区中文字幕| 亚洲精品久久7777| 亚洲九九爱视频| 一区二区成人在线| 一区二区三区中文字幕电影| 亚洲精品成人在线| 亚洲第一精品在线| 日韩精品五月天| 激情小说欧美图片| 国产高清亚洲一区| 99久久免费视频.com| 日本久久电影网| 欧美色图片你懂的| 精品国产乱码久久久久久牛牛| 欧美一级欧美三级| 久久久久久麻豆| 最新欧美精品一区二区三区| 一区二区三区四区乱视频| 亚洲国产你懂的| 青青草视频一区| 国产黄色精品视频| 色天天综合久久久久综合片| 91精品综合久久久久久| 国产日产亚洲精品系列| 亚洲品质自拍视频| 日韩电影免费在线| 懂色av一区二区三区免费看| 91极品视觉盛宴| 日韩视频免费观看高清完整版| www日韩大片| 亚洲激情一二三区| 国产一区二区三区免费在线观看| 成人av午夜电影| 欧美精品99久久久**| 欧美激情一二三区| 日本在线不卡视频一二三区| 成人99免费视频| 欧美一级在线免费| 自拍偷在线精品自拍偷无码专区| 青娱乐精品视频在线| 91亚洲大成网污www| 日韩精品影音先锋| 亚洲精品国产精品乱码不99| 国产精品996| 欧美区在线观看| 亚洲欧美国产毛片在线| 久久福利视频一区二区| 欧美日韩中字一区| 国产精品美女久久久久久久久| 麻豆视频一区二区| 欧美亚男人的天堂| 国产精品蜜臀在线观看| 九色综合国产一区二区三区| 欧美亚洲国产一区二区三区va| 国产亚洲午夜高清国产拍精品| 日韩电影在线一区二区三区| 日本精品免费观看高清观看| 国产精品色一区二区三区| 精品亚洲porn| 欧美日韩黄色一区二区| 亚洲另类春色国产| 成人va在线观看| 中文字幕不卡的av| 国产成人免费9x9x人网站视频| 欧美草草影院在线视频| 日日夜夜精品视频免费| 欧美日韩综合在线| 亚洲高清免费观看| 欧美日韩国产在线观看| 亚洲午夜激情网页| 欧美在线色视频| 亚洲综合色区另类av| 在线一区二区三区四区| 一区二区三区欧美日韩| 91麻豆福利精品推荐| 亚洲欧美另类综合偷拍| 99视频国产精品| 国产精品国产精品国产专区不蜜| av在线不卡观看免费观看| 中文字幕一区二区不卡| 9人人澡人人爽人人精品| 亚洲欧洲精品一区二区精品久久久| 国产91综合网| 亚洲图片欧美激情| 在线看国产一区| 亚洲一区二区欧美激情| 欧美日韩国产小视频在线观看| 五月天激情综合网| 欧美成人猛片aaaaaaa| 国产精品中文字幕欧美| 国产精品第五页| 欧美性猛片xxxx免费看久爱| 日韩电影一区二区三区四区| 欧美精品一区二区不卡| av动漫一区二区| 丝袜a∨在线一区二区三区不卡| 欧美一级片免费看| 成人精品一区二区三区四区| 亚洲精品视频在线观看网站| 欧美挠脚心视频网站| 精品无码三级在线观看视频 | 精品国偷自产国产一区| 国产成人在线观看| 亚洲综合色区另类av| 精品国产一区久久| 日本韩国欧美一区二区三区| 免费在线观看一区| 国产精品国产精品国产专区不蜜| 欧美性大战久久久| 国产精品538一区二区在线| 亚洲精品国产成人久久av盗摄 | 亚洲猫色日本管| 日韩视频一区在线观看| 色综合天天综合网国产成人综合天| 午夜影院在线观看欧美| 国产精品久久久一本精品| 欧美一级午夜免费电影| 99久久99久久精品国产片果冻| 青草av.久久免费一区| 亚洲视频你懂的| 久久久久青草大香线综合精品| 欧美亚洲国产bt| 不卡视频一二三四| 国产美女精品一区二区三区| 亚洲午夜精品久久久久久久久| 久久精品夜色噜噜亚洲a∨| 欧美男女性生活在线直播观看| 国产91丝袜在线播放0| 日本成人在线视频网站| 亚洲精品菠萝久久久久久久| 久久久久国产精品麻豆ai换脸| 欧美高清www午色夜在线视频| 9l国产精品久久久久麻豆| 国产电影精品久久禁18| 青椒成人免费视频| 日日摸夜夜添夜夜添国产精品| 日韩理论片一区二区| 国产清纯白嫩初高生在线观看91| 欧美一区二区视频网站| 在线观看日韩高清av| 91一区二区三区在线播放| 成人三级在线视频| 国产盗摄精品一区二区三区在线| 精品在线播放免费| 久久不见久久见免费视频7| 美腿丝袜在线亚洲一区| 看片的网站亚洲| 麻豆精品久久久| 久久国产精品99精品国产| 精油按摩中文字幕久久| 美女在线视频一区| 精品在线播放午夜| 国产精品18久久久| 成人免费高清视频| 99在线精品视频| 色88888久久久久久影院野外| 91小视频免费观看| 日本国产一区二区| 欧美日韩高清一区二区| 欧美一区二区播放| 精品久久一区二区| 日本一区二区三区免费乱视频| 久久久久久免费毛片精品| 国产精品嫩草99a| 亚洲三级视频在线观看| 五月综合激情网| 美国毛片一区二区| 国产精品系列在线播放| 不卡的av在线播放| 欧美色精品天天在线观看视频| 欧美日韩国产中文| 精品国产自在久精品国产| 国产农村妇女毛片精品久久麻豆 | 色婷婷精品大视频在线蜜桃视频| 99精品热视频| 91精品欧美福利在线观看| 欧美变态tickle挠乳网站| 欧美高清一级片在线观看| 亚洲午夜精品在线| 久久99最新地址| 91日韩一区二区三区| 宅男噜噜噜66一区二区66| 国产日韩欧美精品电影三级在线| 亚洲人午夜精品天堂一二香蕉| 亚洲成人免费电影| 国产高清精品在线| 欧美精品一级二级三级| 久久精品人人做人人综合| 一区二区三区中文免费| 激情丁香综合五月| 欧美性xxxxxxxx| 国产精品嫩草影院com| 久久精品国产一区二区三| 91首页免费视频| 亚洲精品在线观看网站| 亚洲国产美女搞黄色| 成人免费视频一区二区| 精品欧美一区二区三区精品久久|