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

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

?? tcp.c

?? 一個EP9315的redboot,希望對大家有用
?? C
?? 第 1 頁 / 共 2 頁
字號:
//==========================================================================////      net/tcp.c////      Stand-alone TCP networking support for RedBoot////==========================================================================//####ECOSGPLCOPYRIGHTBEGIN####// -------------------------------------------// This file is part of eCos, the Embedded Configurable Operating System.// Copyright (C) 1998, 1999, 2000, 2001, 2002 Red Hat, Inc.//// eCos is free software; you can redistribute it and/or modify it under// the terms of the GNU General Public License as published by the Free// Software Foundation; either version 2 or (at your option) any later version.//// eCos is distributed in the hope that it will be useful, but WITHOUT ANY// WARRANTY; without even the implied warranty of MERCHANTABILITY or// FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License// for more details.//// You should have received a copy of the GNU General Public License along// with eCos; if not, write to the Free Software Foundation, Inc.,// 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.//// As a special exception, if other files instantiate templates or use macros// or inline functions from this file, or you compile this file and link it// with other works to produce a work based on this file, this file does not// by itself cause the resulting work to be covered by the GNU General Public// License. However the source code for this file must still be made available// in accordance with section (3) of the GNU General Public License.//// This exception does not invalidate any other reasons why a work based on// this file might be covered by the GNU General Public License.//// Alternative licenses for eCos may be arranged by contacting Red Hat, Inc.// at http://sources.redhat.com/ecos/ecos-license/// -------------------------------------------//####ECOSGPLCOPYRIGHTEND####//==========================================================================//#####DESCRIPTIONBEGIN####//// Author(s):    gthomas// Contributors: gthomas// Date:         2000-07-14// Purpose:      // Description:  //              // This code is part of RedBoot (tm).////####DESCRIPTIONEND####////==========================================================================#include <net/net.h>#define MAX_TCP_SEGMENT (ETH_MAX_PKTLEN - (sizeof(eth_header_t) + sizeof(ip_header_t)))#define MAX_TCP_DATA    (MAX_TCP_SEGMENT - sizeof(tcp_header_t))/* sequence number comparison macros */#define SEQ_LT(a,b) ((int)((a)-(b)) < 0)#define SEQ_LE(a,b) ((int)((a)-(b)) <= 0)#define SEQ_GT(a,b) ((int)((a)-(b)) > 0)#define SEQ_GE(a,b) ((int)((a)-(b)) >= 0)/* Set a timer which will send an RST and abort a connection. */static timer_t abort_timer;static void do_retrans(void *p);static void do_close(void *p);#ifdef BSP_LOGstatic char *flags_to_str(octet f){    static char str[7], *p;    p = str;    if (f & TCP_FLAG_FIN)	*p++ = 'F';    if (f & TCP_FLAG_SYN)	*p++ = 'S';    if (f & TCP_FLAG_RST)	*p++ = 'R';    if (f & TCP_FLAG_PSH)	*p++ = 'P';    if (f & TCP_FLAG_ACK)	*p++ = 'A';    if (f & TCP_FLAG_URG)	*p++ = 'U';    *p = '\0';    return str;}#endif/* * A major assumption is that only a very small number of sockets will * active, so a simple linear search of those sockets is acceptible. */static tcp_socket_t *tcp_list;/* * Format and send an outgoing segment. */static voidtcp_send(tcp_socket_t *s, int flags, int resend){    tcp_header_t *tcp;    ip_header_t  *ip;    pktbuf_t     *pkt = &s->pkt;    unsigned short cksum;    dword         tcp_magic;    int           tcp_magic_size = sizeof(tcp_magic);    ip = pkt->ip_hdr;    tcp = pkt->tcp_hdr;    if (flags & TCP_FLAG_SYN) {	/* If SYN, assume no data and send MSS option in tcp header */	pkt->pkt_bytes = sizeof(tcp_header_t) + 4;	tcp->hdr_len = 6;        tcp_magic = htonl(0x02040000 | MAX_TCP_DATA);	memcpy((unsigned char *)(tcp+1), &tcp_magic, tcp_magic_size);	s->data_bytes = 0;    } else {	pkt->pkt_bytes = s->data_bytes + sizeof(tcp_header_t);	tcp->hdr_len = 5;    }    /* tcp header */    tcp->reserved = 0;    tcp->seqnum = htonl(s->seq);    tcp->acknum = htonl(s->ack);    tcp->checksum = 0;    if (!resend) {	tcp->src_port = htons(s->our_port);	tcp->dest_port = htons(s->his_port);	tcp->flags = flags;	/* always set PUSH flag if sending data */	if (s->data_bytes)	    tcp->flags |= TCP_FLAG_PSH;	tcp->window = htons(MAX_TCP_DATA);	tcp->urgent = 0;	/* fill in some pseudo-header fields */	memcpy(ip->source, __local_ip_addr, sizeof(ip_addr_t));	memcpy(ip->destination, s->his_addr.ip_addr, sizeof(ip_addr_t));	ip->protocol = IP_PROTO_TCP;    }    /* another pseudo-header field */    ip->length = htons(pkt->pkt_bytes);    /* compute tcp checksum */    cksum = __sum((word *)tcp, pkt->pkt_bytes, __pseudo_sum(ip));    tcp->checksum = htons(cksum);    __ip_send(pkt, IP_PROTO_TCP, &s->his_addr);    BSPLOG(bsp_log("tcp_send: state[%d] flags[%s] ack[%x] data[%d].\n",		   s->state, flags_to_str(tcp->flags), s->ack, s->data_bytes));    if (s->state == _TIME_WAIT) {        // If 'reuse' is set on socket, close after 1 second, otherwise 2 minutes        __timer_set(&s->timer, s->reuse ? 1000 : 120000, do_close, s);    }    else if ((tcp->flags & (TCP_FLAG_FIN | TCP_FLAG_SYN)) || s->data_bytes)	__timer_set(&s->timer, 1000, do_retrans, s);}static pktbuf_t ack_pkt;static word     ack_buf[ETH_MIN_PKTLEN/sizeof(word)];/* * Send an ack. */static voidsend_ack(tcp_socket_t *s){    tcp_header_t *tcp;    ip_header_t  *ip;    unsigned short cksum;    ack_pkt.buf = ack_buf;    ack_pkt.bufsize = sizeof(ack_buf);    ack_pkt.ip_hdr = ip = (ip_header_t *)ack_buf;    ack_pkt.tcp_hdr = tcp = (tcp_header_t *)(ip + 1);    ack_pkt.pkt_bytes = sizeof(tcp_header_t);    /* tcp header */    tcp->hdr_len = 5;    tcp->reserved = 0;    tcp->seqnum = htonl(s->seq);    tcp->acknum = htonl(s->ack);    tcp->checksum = 0;    tcp->src_port = htons(s->our_port);    tcp->dest_port = htons(s->his_port);    tcp->flags = TCP_FLAG_ACK;    tcp->window = htons(MAX_TCP_DATA);    tcp->urgent = 0;    /* fill in some pseudo-header fields */    memcpy(ip->source, __local_ip_addr, sizeof(ip_addr_t));    memcpy(ip->destination, s->his_addr.ip_addr, sizeof(ip_addr_t));    ip->protocol = IP_PROTO_TCP;    /* another pseudo-header field */    ip->length = htons(sizeof(tcp_header_t));    /* compute tcp checksum */    cksum = __sum((word *)tcp, sizeof(*tcp), __pseudo_sum(ip));    tcp->checksum = htons(cksum);    __ip_send(&ack_pkt, IP_PROTO_TCP, &s->his_addr);}/* * Send a reset for a bogus incoming segment. */static voidsend_reset(pktbuf_t *pkt, ip_route_t *r){    ip_header_t   *ip = pkt->ip_hdr;    tcp_header_t  *tcp = pkt->tcp_hdr;    dword         seq, ack;    word          src, dest;    word          cksum;    seq = ntohl(tcp->acknum);    ack = ntohl(tcp->seqnum);    src = ntohs(tcp->dest_port);    dest = ntohs(tcp->src_port);    tcp = (tcp_header_t *)(ip + 1);    pkt->pkt_bytes = sizeof(tcp_header_t);        /* tcp header */    tcp->hdr_len = 5;    tcp->reserved = 0;    tcp->seqnum = htonl(seq);    tcp->acknum = htonl(ack);    tcp->window = htons(1024);    tcp->urgent = 0;    tcp->checksum = 0;    tcp->src_port = htons(src);    tcp->dest_port = htons(dest);    tcp->flags = TCP_FLAG_RST | TCP_FLAG_ACK;    /* fill in some pseudo-header fields */    memcpy(ip->source, __local_ip_addr, sizeof(ip_addr_t));    memcpy(ip->destination, r->ip_addr, sizeof(ip_addr_t));    ip->protocol = IP_PROTO_TCP;    ip->length = htons(pkt->pkt_bytes);    /* compute tcp checksum */    cksum = __sum((word *)tcp, pkt->pkt_bytes, __pseudo_sum(ip));    tcp->checksum = htons(cksum);    __ip_send(pkt, IP_PROTO_TCP, r);}/* * Remove given socket from socket list. */static voidunlink_socket(tcp_socket_t *s){    tcp_socket_t *prev, *tp;    for (prev = NULL, tp = tcp_list; tp; prev = tp, tp = tp->next)	if (tp == s) {	    BSPLOG(bsp_log("unlink tcp socket.\n"));	    if (prev)		prev->next = s->next;	    else		tcp_list = s->next;	}}/* * Retransmit last packet. */static voiddo_retrans(void *p){    BSPLOG(bsp_log("tcp do_retrans.\n"));    tcp_send((tcp_socket_t *)p, 0, 1);}static voiddo_close(void *p){    BSPLOG(bsp_log("tcp do_close.\n"));    /* close connection */    ((tcp_socket_t *)p)->state = _CLOSED;    unlink_socket(p);}static voidfree_rxlist(tcp_socket_t *s){    pktbuf_t *p;    BSPLOG(bsp_log("tcp free_rxlist.\n"));    while ((p = s->rxlist) != NULL) {	s->rxlist = p->next;	__pktbuf_free(p);    }}/* * Handle a conection reset. */static voiddo_reset(tcp_socket_t *s){    /* close connection */    s->state = _CLOSED;    __timer_cancel(&s->timer);    free_rxlist(s);    unlink_socket(s);}/* * Extract data from incoming tcp segment. * Returns true if packet is queued on rxlist, false otherwise. */static inthandle_data(tcp_socket_t *s, pktbuf_t *pkt){    tcp_header_t  *tcp = pkt->tcp_hdr;    unsigned int  diff, seq;    int           data_len;    char          *data_ptr;    pktbuf_t      *p;    data_len = pkt->pkt_bytes - (tcp->hdr_len << 2);    data_ptr = ((char *)tcp)  + (tcp->hdr_len << 2);    seq = ntohl(tcp->seqnum);    BSPLOG(bsp_log("tcp data: seq[%x] len[%d].\n", seq, data_len));    if (SEQ_LE(seq, s->ack)) {	/*	 * Figure difference between which byte we're expecting and which byte	 * is sent first. Adjust data length and data pointer accordingly.	 */	diff = s->ack - seq;	data_len -= diff;	data_ptr += diff;	if (data_len > 0) {	    /* queue the new data */	    s->ack += data_len;	    pkt->next = NULL;	    if ((p = s->rxlist) != NULL) {		while (p->next)		    p = p->next;		p->next = pkt;		BSPLOG(bsp_log("tcp data: Add pkt[%x] len[%d].\n",			       pkt, data_len));	    } else {		s->rxlist = pkt;		s->rxcnt = data_len;		s->rxptr = data_ptr;		BSPLOG(bsp_log("tcp data: pkt[%x] len[%d].\n",			       pkt, data_len));	    }	    return 1;	}    }    return 0;}static voidhandle_ack(tcp_socket_t *s, pktbuf_t *pkt){    tcp_header_t *tcp = pkt->tcp_hdr;    dword        ack;    int          advance;    char         *dp;    /* process ack value in packet */    ack = ntohl(tcp->acknum);    BSPLOG(bsp_log("Rcvd tcp ACK %x\n", ack));    if (SEQ_GT(ack, s->seq)) {	__timer_cancel(&s->timer);	advance = ack - s->seq;	if (advance > s->data_bytes)	    advance = s->data_bytes;	BSPLOG(bsp_log("seq advance %d", advance));	if (advance > 0) {	    s->seq += advance;	    s->data_bytes -= advance;	    if (s->data_bytes) {		/* other end ack'd only part of the pkt */		BSPLOG(bsp_log(" %d bytes left", s->data_bytes));		dp = (char *)(s->pkt.tcp_hdr + 1);		memcpy(dp, dp + advance, s->data_bytes);	    }	}    }    BSPLOG(bsp_log("\n"));}/* * Handle incoming TCP packets. */void__tcp_handler(pktbuf_t *pkt, ip_route_t *r){    tcp_header_t *tcp = pkt->tcp_hdr;    ip_header_t  *ip = pkt->ip_hdr;    tcp_socket_t *prev,*s;    dword        ack;    int          queued = 0;    /* set length for pseudo sum calculation */    ip->length = htons(pkt->pkt_bytes);    if (__sum((word *)tcp, pkt->pkt_bytes, __pseudo_sum(ip)) == 0) {	for (prev = NULL, s = tcp_list; s; prev = s, s = s->next) {	    if (s->our_port == ntohs(tcp->dest_port)) {		if (s->his_port == 0)		    break;		if (s->his_port == ntohs(tcp->src_port) &&		    !memcmp(r->ip_addr, s->his_addr.ip_addr, sizeof(ip_addr_t)))		    break;	    }	}	if (s) {	    /* found the socket this packet belongs to */	    	    /* refresh his ethernet address */	    memcpy(s->his_addr.enet_addr, r->enet_addr, sizeof(enet_addr_t));	    if (s->state != _SYN_RCVD && tcp->flags & TCP_FLAG_RST) {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲国产精品二十页| 日本人妖一区二区| 亚洲成人精品影院| 极品少妇一区二区三区精品视频 | 国产成人午夜99999| 色综合久久中文综合久久97| 日韩精品一区二区三区四区视频| 中文字幕一区二区三区四区不卡| 91在线免费视频观看| 日韩久久久精品| 亚洲午夜久久久久| 成人高清免费观看| 久久综合九色欧美综合狠狠| 伊人夜夜躁av伊人久久| 国产成人精品免费视频网站| 欧美一区二区视频观看视频| 亚洲私人黄色宅男| 国产精品香蕉一区二区三区| 91精品国产综合久久久久久久 | 欧美日韩国产123区| 国产精品麻豆欧美日韩ww| 美女视频一区二区| 欧美日韩美少妇| 亚洲国产精品久久一线不卡| 成人免费毛片高清视频| 久久久亚洲国产美女国产盗摄 | 激情成人综合网| 日韩一区二区在线观看视频播放| 亚洲免费观看高清完整版在线观看熊 | 欧美日本在线观看| 亚洲精品一二三四区| 9人人澡人人爽人人精品| 久久精子c满五个校花| 久久超碰97中文字幕| 日韩欧美亚洲国产另类| 亚洲1区2区3区视频| 欧美性淫爽ww久久久久无| 亚洲欧美日本韩国| 色成人在线视频| 亚洲影院理伦片| 在线观看国产一区二区| 亚洲自拍偷拍九九九| 99久久精品久久久久久清纯| 成人欧美一区二区三区白人| 成人av电影在线网| 亚洲欧洲韩国日本视频| 成人黄色小视频| 中文字幕字幕中文在线中不卡视频| 成人白浆超碰人人人人| |精品福利一区二区三区| 91网站最新网址| 亚洲品质自拍视频网站| 欧美日韩午夜在线| 久久精品久久精品| 久久久www免费人成精品| 国产**成人网毛片九色| 成人综合婷婷国产精品久久免费| 亚洲国产精品成人久久综合一区| 国产91露脸合集magnet| 亚洲美腿欧美偷拍| 欧美精品xxxxbbbb| 激情五月婷婷综合| 中文字幕一区二区三区av| 欧美亚洲日本国产| 久久国产精品99久久人人澡| 日韩视频一区在线观看| 成人免费视频视频在线观看免费| 亚洲人成影院在线观看| 91精品国产91综合久久蜜臀| 国产乱人伦精品一区二区在线观看| 欧美国产精品v| 欧美无人高清视频在线观看| 久久99久久久欧美国产| 亚洲色图欧洲色图| 欧美日韩精品高清| 国产成人在线看| 亚洲国产成人av网| 国产午夜精品久久| 欧美日韩一区二区欧美激情| 国产一区二区电影| 亚洲午夜久久久久久久久电影院| 精品日韩成人av| 91黄视频在线| 国产精品12区| 午夜精品在线看| 亚洲国产成人自拍| 欧美一区二区日韩| 日本高清视频一区二区| 国内外成人在线| 婷婷成人综合网| 日韩毛片视频在线看| 2欧美一区二区三区在线观看视频 337p粉嫩大胆噜噜噜噜噜91av | 中文字幕精品一区二区精品绿巨人| 精品视频在线免费观看| 欧美成人伊人久久综合网| 日本道免费精品一区二区三区| 狠狠色2019综合网| 日韩精品电影一区亚洲| 亚洲欧美日韩国产综合| 国产亚洲视频系列| 日韩精品一区二区三区四区视频| 欧美亚洲高清一区二区三区不卡| 成人美女视频在线观看| 国产一区二区在线观看免费 | 国产精品久久久久aaaa| 欧美sm美女调教| 3751色影院一区二区三区| 色一区在线观看| eeuss鲁一区二区三区| 福利电影一区二区三区| 国产盗摄视频一区二区三区| 另类小说综合欧美亚洲| 视频一区欧美日韩| 亚洲韩国一区二区三区| 亚洲日本在线a| 亚洲欧美一区二区三区极速播放| 欧美国产一区在线| 欧美国产欧美亚州国产日韩mv天天看完整| 日韩欧美亚洲另类制服综合在线| 亚洲一区免费观看| 亚洲一区二区精品3399| 亚洲激情在线激情| 亚洲永久精品国产| 婷婷综合久久一区二区三区| 亚洲成人7777| 青青草伊人久久| 麻豆精品一二三| 国产乱码精品一品二品| 豆国产96在线|亚洲| caoporm超碰国产精品| 91麻豆免费观看| 欧美三区在线观看| 91精品国产91久久综合桃花| 91精品国产综合久久福利软件 | 成人av综合一区| 97精品国产露脸对白| 在线看不卡av| 日韩午夜激情视频| 国产日产欧美精品一区二区三区| 欧美国产一区在线| 一区二区三区欧美在线观看| 亚洲va中文字幕| 久久成人精品无人区| 成人黄色综合网站| 欧美日韩精品一区视频| 欧美成人一区二区三区片免费| 久久久久久久久久久久电影 | 欧美国产精品一区二区三区| 亚洲欧美另类综合偷拍| 五月天亚洲婷婷| 国内一区二区视频| 色综合咪咪久久| 日韩一区二区免费在线电影| 国产日韩av一区二区| 亚洲精品视频在线观看网站| 天堂成人免费av电影一区| 国产精品一二三区在线| 日本高清成人免费播放| 欧美电影免费观看高清完整版 | 国产精品免费免费| 午夜精品在线视频一区| 国产91丝袜在线18| 欧美另类久久久品| 国产精品嫩草99a| 奇米综合一区二区三区精品视频| 国产成人av福利| 欧美视频一区在线观看| 国产偷v国产偷v亚洲高清| 一区二区在线看| 国产成人免费高清| 欧美福利一区二区| 日韩一区在线看| 国产剧情在线观看一区二区| 欧美午夜不卡视频| 国产精品电影院| 激情综合色播五月| 欧美美女一区二区在线观看| 国产精品高潮呻吟| 国内成人免费视频| 91麻豆精品国产91久久久更新时间 | 国产白丝网站精品污在线入口| 欧美性极品少妇| 自拍偷拍欧美精品| 风间由美一区二区av101| 在线不卡a资源高清| 亚洲精品国产高清久久伦理二区| 国产成人综合在线观看| 精品奇米国产一区二区三区| 亚洲国产色一区| 色婷婷久久一区二区三区麻豆| 久久蜜臀中文字幕| 久久99久久久久久久久久久| 欧美精品自拍偷拍动漫精品| 一区二区在线电影| 一本色道久久综合亚洲aⅴ蜜桃 | 色婷婷精品大在线视频 | 国产一区二区在线影院| 制服丝袜亚洲精品中文字幕| 亚洲资源中文字幕| 欧美伊人久久大香线蕉综合69 |