提交 9634d903 编写于 作者: B blueswir1

Use const and static as needed, disable unused code


git-svn-id: svn://svn.savannah.nongnu.org/qemu/trunk@3452 c046a42c-6fe2-441c-8c8c-71466251a162
上级 31a60e22
...@@ -149,7 +149,7 @@ static void bootp_reply(struct bootp_t *bp) ...@@ -149,7 +149,7 @@ static void bootp_reply(struct bootp_t *bp)
if ((m = m_get()) == NULL) if ((m = m_get()) == NULL)
return; return;
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
rbp = (struct bootp_t *)m->m_data; rbp = (struct bootp_t *)m->m_data;
m->m_data += sizeof(struct udpiphdr); m->m_data += sizeof(struct udpiphdr);
memset(rbp, 0, sizeof(struct bootp_t)); memset(rbp, 0, sizeof(struct bootp_t));
......
...@@ -92,9 +92,9 @@ ttystats(ttyp) ...@@ -92,9 +92,9 @@ ttystats(ttyp)
lprint(" \r\n"); lprint(" \r\n");
if (if_comp & IF_COMPRESS) if (IF_COMP & IF_COMPRESS)
strcpy(buff, "on"); strcpy(buff, "on");
else if (if_comp & IF_NOCOMPRESS) else if (IF_COMP & IF_NOCOMPRESS)
strcpy(buff, "off"); strcpy(buff, "off");
else else
strcpy(buff, "off (for now)"); strcpy(buff, "off (for now)");
......
...@@ -7,9 +7,6 @@ ...@@ -7,9 +7,6 @@
#include <slirp.h> #include <slirp.h>
int if_mtu, if_mru;
int if_comp;
int if_maxlinkhdr;
int if_queued = 0; /* Number of packets queued so far */ int if_queued = 0; /* Number of packets queued so far */
int if_thresh = 10; /* Number of packets queued before we start sending int if_thresh = 10; /* Number of packets queued before we start sending
* (to prevent allocing too many mbufs) */ * (to prevent allocing too many mbufs) */
...@@ -41,23 +38,6 @@ ifs_remque(ifm) ...@@ -41,23 +38,6 @@ ifs_remque(ifm)
void void
if_init() if_init()
{ {
#if 0
/*
* Set if_maxlinkhdr to 48 because it's 40 bytes for TCP/IP,
* and 8 bytes for PPP, but need to have it on an 8byte boundary
*/
#ifdef USE_PPP
if_maxlinkhdr = 48;
#else
if_maxlinkhdr = 40;
#endif
#else
/* 2 for alignment, 14 for ethernet, 40 for TCP/IP */
if_maxlinkhdr = 2 + 14 + 40;
#endif
if_mtu = 1500;
if_mru = 1500;
if_comp = IF_AUTOCOMP;
if_fastq.ifq_next = if_fastq.ifq_prev = &if_fastq; if_fastq.ifq_next = if_fastq.ifq_prev = &if_fastq;
if_batchq.ifq_next = if_batchq.ifq_prev = &if_batchq; if_batchq.ifq_next = if_batchq.ifq_prev = &if_batchq;
// sl_compress_init(&comp_s); // sl_compress_init(&comp_s);
......
...@@ -13,12 +13,25 @@ ...@@ -13,12 +13,25 @@
#define IF_AUTOCOMP 0x04 /* Autodetect (default) */ #define IF_AUTOCOMP 0x04 /* Autodetect (default) */
#define IF_NOCIDCOMP 0x08 /* CID compression */ #define IF_NOCIDCOMP 0x08 /* CID compression */
/* Needed for FreeBSD */ #define IF_MTU 1500
#undef if_mtu #define IF_MRU 1500
extern int if_mtu; #define IF_COMP IF_AUTOCOMP /* Flags for compression */
extern int if_mru; /* MTU and MRU */
extern int if_comp; /* Flags for compression */ #if 0
extern int if_maxlinkhdr; /*
* Set if_maxlinkhdr to 48 because it's 40 bytes for TCP/IP,
* and 8 bytes for PPP, but need to have it on an 8byte boundary
*/
#ifdef USE_PPP
#define IF_MAXLINKHDR 48
#else
#define IF_MAXLINKHDR 40
#endif
#else
/* 2 for alignment, 14 for ethernet, 40 for TCP/IP */
#define IF_MAXLINKHDR (2 + 14 + 40)
#endif
extern int if_queued; /* Number of packets queued so far */ extern int if_queued; /* Number of packets queued so far */
extern int if_thresh; /* Number of packets queued before we start sending extern int if_thresh; /* Number of packets queued before we start sending
* (to prevent allocing too many mbufs) */ * (to prevent allocing too many mbufs) */
......
...@@ -312,6 +312,4 @@ extern struct ipstat ipstat; ...@@ -312,6 +312,4 @@ extern struct ipstat ipstat;
extern struct ipq ipq; /* ip reass. queue */ extern struct ipq ipq; /* ip reass. queue */
extern u_int16_t ip_id; /* ip packet ctr, for ids */ extern u_int16_t ip_id; /* ip packet ctr, for ids */
extern int ip_defttl; /* default IP ttl */
#endif #endif
...@@ -46,7 +46,7 @@ struct icmpstat icmpstat; ...@@ -46,7 +46,7 @@ struct icmpstat icmpstat;
char icmp_ping_msg[] = "This is a psuedo-PING packet used by Slirp to emulate ICMP ECHO-REQUEST packets.\n"; char icmp_ping_msg[] = "This is a psuedo-PING packet used by Slirp to emulate ICMP ECHO-REQUEST packets.\n";
/* list of actions for icmp_error() on RX of an icmp message */ /* list of actions for icmp_error() on RX of an icmp message */
static int icmp_flush[19] = { static const int icmp_flush[19] = {
/* ECHO REPLY (0) */ 0, /* ECHO REPLY (0) */ 0,
1, 1,
1, 1,
......
...@@ -45,14 +45,19 @@ ...@@ -45,14 +45,19 @@
#include <slirp.h> #include <slirp.h>
#include "ip_icmp.h" #include "ip_icmp.h"
int ip_defttl;
#ifdef LOG_ENABLED #ifdef LOG_ENABLED
struct ipstat ipstat; struct ipstat ipstat;
#endif #endif
struct ipq ipq; struct ipq ipq;
static struct ip *ip_reass(register struct ipasfrag *ip,
register struct ipq *fp);
static void ip_freef(struct ipq *fp);
static void ip_enq(register struct ipasfrag *p,
register struct ipasfrag *prev);
static void ip_deq(register struct ipasfrag *p);
/* /*
* IP initialization: fill in IP protocol switch table. * IP initialization: fill in IP protocol switch table.
* All protocols not implemented in kernel go to raw IP protocol handler. * All protocols not implemented in kernel go to raw IP protocol handler.
...@@ -64,7 +69,6 @@ ip_init() ...@@ -64,7 +69,6 @@ ip_init()
ip_id = tt.tv_sec & 0xffff; ip_id = tt.tv_sec & 0xffff;
udp_init(); udp_init();
tcp_init(); tcp_init();
ip_defttl = IPDEFTTL;
} }
/* /*
...@@ -239,10 +243,8 @@ bad: ...@@ -239,10 +243,8 @@ bad:
* reassembly of this datagram already exists, then it * reassembly of this datagram already exists, then it
* is given as fp; otherwise have to make a chain. * is given as fp; otherwise have to make a chain.
*/ */
struct ip * static struct ip *
ip_reass(ip, fp) ip_reass(register struct ipasfrag *ip, register struct ipq *fp)
register struct ipasfrag *ip;
register struct ipq *fp;
{ {
register struct mbuf *m = dtom(ip); register struct mbuf *m = dtom(ip);
register struct ipasfrag *q; register struct ipasfrag *q;
...@@ -398,9 +400,8 @@ dropfrag: ...@@ -398,9 +400,8 @@ dropfrag:
* Free a fragment reassembly header and all * Free a fragment reassembly header and all
* associated datagrams. * associated datagrams.
*/ */
void static void
ip_freef(fp) ip_freef(struct ipq *fp)
struct ipq *fp;
{ {
register struct ipasfrag *q, *p; register struct ipasfrag *q, *p;
...@@ -418,9 +419,8 @@ ip_freef(fp) ...@@ -418,9 +419,8 @@ ip_freef(fp)
* Put an ip fragment on a reassembly chain. * Put an ip fragment on a reassembly chain.
* Like insque, but pointers in middle of structure. * Like insque, but pointers in middle of structure.
*/ */
void static void
ip_enq(p, prev) ip_enq(register struct ipasfrag *p, register struct ipasfrag *prev)
register struct ipasfrag *p, *prev;
{ {
DEBUG_CALL("ip_enq"); DEBUG_CALL("ip_enq");
DEBUG_ARG("prev = %lx", (long)prev); DEBUG_ARG("prev = %lx", (long)prev);
...@@ -433,9 +433,8 @@ ip_enq(p, prev) ...@@ -433,9 +433,8 @@ ip_enq(p, prev)
/* /*
* To ip_enq as remque is to insque. * To ip_enq as remque is to insque.
*/ */
void static void
ip_deq(p) ip_deq(register struct ipasfrag *p)
register struct ipasfrag *p;
{ {
((struct ipasfrag *)(p->ipf_prev))->ipf_next = p->ipf_next; ((struct ipasfrag *)(p->ipf_prev))->ipf_next = p->ipf_next;
((struct ipasfrag *)(p->ipf_next))->ipf_prev = p->ipf_prev; ((struct ipasfrag *)(p->ipf_next))->ipf_prev = p->ipf_prev;
......
...@@ -96,7 +96,7 @@ ip_output(so, m0) ...@@ -96,7 +96,7 @@ ip_output(so, m0)
/* /*
* If small enough for interface, can just send directly. * If small enough for interface, can just send directly.
*/ */
if ((u_int16_t)ip->ip_len <= if_mtu) { if ((u_int16_t)ip->ip_len <= IF_MTU) {
ip->ip_len = htons((u_int16_t)ip->ip_len); ip->ip_len = htons((u_int16_t)ip->ip_len);
ip->ip_off = htons((u_int16_t)ip->ip_off); ip->ip_off = htons((u_int16_t)ip->ip_off);
ip->ip_sum = 0; ip->ip_sum = 0;
...@@ -116,7 +116,7 @@ ip_output(so, m0) ...@@ -116,7 +116,7 @@ ip_output(so, m0)
goto bad; goto bad;
} }
len = (if_mtu - hlen) &~ 7; /* ip databytes per packet */ len = (IF_MTU - hlen) &~ 7; /* ip databytes per packet */
if (len < 8) { if (len < 8) {
error = -1; error = -1;
goto bad; goto bad;
...@@ -140,7 +140,7 @@ ip_output(so, m0) ...@@ -140,7 +140,7 @@ ip_output(so, m0)
STAT(ipstat.ips_odropped++); STAT(ipstat.ips_odropped++);
goto sendorfree; goto sendorfree;
} }
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
mhip = mtod(m, struct ip *); mhip = mtod(m, struct ip *);
*mhip = *ip; *mhip = *ip;
......
...@@ -42,7 +42,6 @@ extern char *username; ...@@ -42,7 +42,6 @@ extern char *username;
extern char *socket_path; extern char *socket_path;
extern int towrite_max; extern int towrite_max;
extern int ppp_exit; extern int ppp_exit;
extern int so_options;
extern int tcp_keepintvl; extern int tcp_keepintvl;
extern uint8_t client_ethaddr[6]; extern uint8_t client_ethaddr[6];
......
...@@ -21,27 +21,20 @@ struct mbuf *mbutl; ...@@ -21,27 +21,20 @@ struct mbuf *mbutl;
char *mclrefcnt; char *mclrefcnt;
int mbuf_alloced = 0; int mbuf_alloced = 0;
struct mbuf m_freelist, m_usedlist; struct mbuf m_freelist, m_usedlist;
int mbuf_thresh = 30; #define MBUF_THRESH 30
int mbuf_max = 0; int mbuf_max = 0;
int msize;
/*
* Find a nice value for msize
* XXX if_maxlinkhdr already in mtu
*/
#define MSIZE (IF_MTU + IF_MAXLINKHDR + sizeof(struct m_hdr ) + 6)
void void
m_init() m_init()
{ {
m_freelist.m_next = m_freelist.m_prev = &m_freelist; m_freelist.m_next = m_freelist.m_prev = &m_freelist;
m_usedlist.m_next = m_usedlist.m_prev = &m_usedlist; m_usedlist.m_next = m_usedlist.m_prev = &m_usedlist;
msize_init();
}
void
msize_init()
{
/*
* Find a nice value for msize
* XXX if_maxlinkhdr already in mtu
*/
msize = (if_mtu>if_mru?if_mtu:if_mru) +
if_maxlinkhdr + sizeof(struct m_hdr ) + 6;
} }
/* /*
...@@ -61,10 +54,10 @@ m_get() ...@@ -61,10 +54,10 @@ m_get()
DEBUG_CALL("m_get"); DEBUG_CALL("m_get");
if (m_freelist.m_next == &m_freelist) { if (m_freelist.m_next == &m_freelist) {
m = (struct mbuf *)malloc(msize); m = (struct mbuf *)malloc(MSIZE);
if (m == NULL) goto end_error; if (m == NULL) goto end_error;
mbuf_alloced++; mbuf_alloced++;
if (mbuf_alloced > mbuf_thresh) if (mbuf_alloced > MBUF_THRESH)
flags = M_DOFREE; flags = M_DOFREE;
if (mbuf_alloced > mbuf_max) if (mbuf_alloced > mbuf_max)
mbuf_max = mbuf_alloced; mbuf_max = mbuf_alloced;
...@@ -78,7 +71,7 @@ m_get() ...@@ -78,7 +71,7 @@ m_get()
m->m_flags = (flags | M_USEDLIST); m->m_flags = (flags | M_USEDLIST);
/* Initialise it */ /* Initialise it */
m->m_size = msize - sizeof(struct m_hdr); m->m_size = MSIZE - sizeof(struct m_hdr);
m->m_data = m->m_dat; m->m_data = m->m_dat;
m->m_len = 0; m->m_len = 0;
m->m_nextpkt = 0; m->m_nextpkt = 0;
......
...@@ -135,7 +135,6 @@ extern struct mbuf m_freelist, m_usedlist; ...@@ -135,7 +135,6 @@ extern struct mbuf m_freelist, m_usedlist;
extern int mbuf_max; extern int mbuf_max;
void m_init _P((void)); void m_init _P((void));
void msize_init _P((void));
struct mbuf * m_get _P((void)); struct mbuf * m_get _P((void));
void m_free _P((struct mbuf *)); void m_free _P((struct mbuf *));
void m_cat _P((register struct mbuf *, register struct mbuf *)); void m_cat _P((register struct mbuf *, register struct mbuf *));
......
...@@ -8,8 +8,7 @@ ...@@ -8,8 +8,7 @@
#define WANT_SYS_IOCTL_H #define WANT_SYS_IOCTL_H
#include <slirp.h> #include <slirp.h>
u_int curtime, time_fasttimo, last_slowtimo, detach_time; u_int curtime, time_fasttimo, last_slowtimo;
u_int detach_wait = 600000; /* 10 minutes */
#if 0 #if 0
int x_port = -1; int x_port = -1;
...@@ -214,10 +213,7 @@ strerror(error) ...@@ -214,10 +213,7 @@ strerror(error)
#ifdef _WIN32 #ifdef _WIN32
int int
fork_exec(so, ex, do_pty) fork_exec(struct socket *so, const char *ex, int do_pty)
struct socket *so;
char *ex;
int do_pty;
{ {
/* not implemented */ /* not implemented */
return 0; return 0;
...@@ -225,6 +221,7 @@ fork_exec(so, ex, do_pty) ...@@ -225,6 +221,7 @@ fork_exec(so, ex, do_pty)
#else #else
#ifndef CONFIG_QEMU
int int
slirp_openpty(amaster, aslave) slirp_openpty(amaster, aslave)
int *amaster, *aslave; int *amaster, *aslave;
...@@ -289,6 +286,7 @@ slirp_openpty(amaster, aslave) ...@@ -289,6 +286,7 @@ slirp_openpty(amaster, aslave)
return (-1); return (-1);
#endif #endif
} }
#endif
/* /*
* XXX This is ugly * XXX This is ugly
...@@ -302,23 +300,20 @@ slirp_openpty(amaster, aslave) ...@@ -302,23 +300,20 @@ slirp_openpty(amaster, aslave)
* do_ptr = 2 Fork/exec using pty * do_ptr = 2 Fork/exec using pty
*/ */
int int
fork_exec(so, ex, do_pty) fork_exec(struct socket *so, const char *ex, int do_pty)
struct socket *so;
char *ex;
int do_pty;
{ {
int s; int s;
struct sockaddr_in addr; struct sockaddr_in addr;
int addrlen = sizeof(addr); int addrlen = sizeof(addr);
int opt; int opt;
int master; int master = -1;
char *argv[256]; char *argv[256];
#if 0 #if 0
char buff[256]; char buff[256];
#endif #endif
/* don't want to clobber the original */ /* don't want to clobber the original */
char *bptr; char *bptr;
char *curarg; const char *curarg;
int c, i, ret; int c, i, ret;
DEBUG_CALL("fork_exec"); DEBUG_CALL("fork_exec");
...@@ -327,10 +322,12 @@ fork_exec(so, ex, do_pty) ...@@ -327,10 +322,12 @@ fork_exec(so, ex, do_pty)
DEBUG_ARG("do_pty = %lx", (long)do_pty); DEBUG_ARG("do_pty = %lx", (long)do_pty);
if (do_pty == 2) { if (do_pty == 2) {
#if 0
if (slirp_openpty(&master, &s) == -1) { if (slirp_openpty(&master, &s) == -1) {
lprint("Error: openpty failed: %s\n", strerror(errno)); lprint("Error: openpty failed: %s\n", strerror(errno));
return 0; return 0;
} }
#endif
} else { } else {
addr.sin_family = AF_INET; addr.sin_family = AF_INET;
addr.sin_port = 0; addr.sin_port = 0;
...@@ -390,7 +387,7 @@ fork_exec(so, ex, do_pty) ...@@ -390,7 +387,7 @@ fork_exec(so, ex, do_pty)
dup2(s, 0); dup2(s, 0);
dup2(s, 1); dup2(s, 1);
dup2(s, 2); dup2(s, 2);
for (s = 3; s <= 255; s++) for (s = getdtablesize() - 1; s >= 3; s--)
close(s); close(s);
i = 0; i = 0;
......
...@@ -12,12 +12,12 @@ struct ex_list { ...@@ -12,12 +12,12 @@ struct ex_list {
int ex_pty; /* Do we want a pty? */ int ex_pty; /* Do we want a pty? */
int ex_addr; /* The last byte of the address */ int ex_addr; /* The last byte of the address */
int ex_fport; /* Port to telnet to */ int ex_fport; /* Port to telnet to */
char *ex_exec; /* Command line of what to exec */ const char *ex_exec; /* Command line of what to exec */
struct ex_list *ex_next; struct ex_list *ex_next;
}; };
extern struct ex_list *exec_list; extern struct ex_list *exec_list;
extern u_int curtime, time_fasttimo, last_slowtimo, detach_time, detach_wait; extern u_int curtime, time_fasttimo, last_slowtimo;
extern int (*lprint_print) _P((void *, const char *, va_list)); extern int (*lprint_print) _P((void *, const char *, va_list));
extern char *lprint_ptr, *lprint_ptr2, **lprint_arg; extern char *lprint_ptr, *lprint_ptr2, **lprint_arg;
...@@ -74,7 +74,7 @@ inline void slirp_insque _P((void *, void *)); ...@@ -74,7 +74,7 @@ inline void slirp_insque _P((void *, void *));
inline void slirp_remque _P((void *)); inline void slirp_remque _P((void *));
int add_exec _P((struct ex_list **, int, char *, int, int)); int add_exec _P((struct ex_list **, int, char *, int, int));
int slirp_openpty _P((int *, int *)); int slirp_openpty _P((int *, int *));
int fork_exec _P((struct socket *, char *, int)); int fork_exec(struct socket *so, const char *ex, int do_pty);
void snooze_hup _P((int)); void snooze_hup _P((int));
void snooze _P((void)); void snooze _P((void));
void relay _P((int)); void relay _P((int));
......
...@@ -7,6 +7,8 @@ ...@@ -7,6 +7,8 @@
#include <slirp.h> #include <slirp.h>
static void sbappendsb(struct sbuf *sb, struct mbuf *m);
/* Done as a macro in socket.h */ /* Done as a macro in socket.h */
/* int /* int
* sbspace(struct sockbuff *sb) * sbspace(struct sockbuff *sb)
...@@ -133,10 +135,8 @@ sbappend(so, m) ...@@ -133,10 +135,8 @@ sbappend(so, m)
* Copy the data from m into sb * Copy the data from m into sb
* The caller is responsible to make sure there's enough room * The caller is responsible to make sure there's enough room
*/ */
void static void
sbappendsb(sb, m) sbappendsb(struct sbuf *sb, struct mbuf *m)
struct sbuf *sb;
struct mbuf *m;
{ {
int len, n, nn; int len, n, nn;
......
...@@ -25,7 +25,6 @@ void sbfree _P((struct sbuf *)); ...@@ -25,7 +25,6 @@ void sbfree _P((struct sbuf *));
void sbdrop _P((struct sbuf *, int)); void sbdrop _P((struct sbuf *, int));
void sbreserve _P((struct sbuf *, int)); void sbreserve _P((struct sbuf *, int));
void sbappend _P((struct socket *, struct mbuf *)); void sbappend _P((struct socket *, struct mbuf *));
void sbappendsb _P((struct sbuf *, struct mbuf *));
void sbcopy _P((struct sbuf *, int, int, char *)); void sbcopy _P((struct sbuf *, int, int, char *));
#endif #endif
...@@ -12,7 +12,7 @@ struct in_addr special_addr; ...@@ -12,7 +12,7 @@ struct in_addr special_addr;
/* virtual address alias for host */ /* virtual address alias for host */
struct in_addr alias_addr; struct in_addr alias_addr;
const uint8_t special_ethaddr[6] = { static const uint8_t special_ethaddr[6] = {
0x52, 0x54, 0x00, 0x12, 0x35, 0x00 0x52, 0x54, 0x00, 0x12, 0x35, 0x00
}; };
...@@ -130,7 +130,7 @@ static int get_dns_addr(struct in_addr *pdns_addr) ...@@ -130,7 +130,7 @@ static int get_dns_addr(struct in_addr *pdns_addr)
#endif #endif
#ifdef _WIN32 #ifdef _WIN32
void slirp_cleanup(void) static void slirp_cleanup(void)
{ {
WSACleanup(); WSACleanup();
} }
......
...@@ -280,6 +280,9 @@ extern int do_echo; ...@@ -280,6 +280,9 @@ extern int do_echo;
#define DEFAULT_BAUD 115200 #define DEFAULT_BAUD 115200
#define SO_OPTIONS DO_KEEPALIVE
#define TCP_MAXIDLE (TCPTV_KEEPCNT * TCPTV_KEEPINTVL)
/* cksum.c */ /* cksum.c */
int cksum(struct mbuf *m, int len); int cksum(struct mbuf *m, int len);
...@@ -290,10 +293,6 @@ void if_output _P((struct socket *, struct mbuf *)); ...@@ -290,10 +293,6 @@ void if_output _P((struct socket *, struct mbuf *));
/* ip_input.c */ /* ip_input.c */
void ip_init _P((void)); void ip_init _P((void));
void ip_input _P((struct mbuf *)); void ip_input _P((struct mbuf *));
struct ip * ip_reass _P((register struct ipasfrag *, register struct ipq *));
void ip_freef _P((struct ipq *));
void ip_enq _P((register struct ipasfrag *, register struct ipasfrag *));
void ip_deq _P((register struct ipasfrag *));
void ip_slowtimo _P((void)); void ip_slowtimo _P((void));
void ip_stripoptions _P((register struct mbuf *, struct mbuf *)); void ip_stripoptions _P((register struct mbuf *, struct mbuf *));
...@@ -301,10 +300,7 @@ void ip_stripoptions _P((register struct mbuf *, struct mbuf *)); ...@@ -301,10 +300,7 @@ void ip_stripoptions _P((register struct mbuf *, struct mbuf *));
int ip_output _P((struct socket *, struct mbuf *)); int ip_output _P((struct socket *, struct mbuf *));
/* tcp_input.c */ /* tcp_input.c */
int tcp_reass _P((register struct tcpcb *, register struct tcpiphdr *, struct mbuf *));
void tcp_input _P((register struct mbuf *, int, struct socket *)); void tcp_input _P((register struct mbuf *, int, struct socket *));
void tcp_dooptions _P((struct tcpcb *, u_char *, int, struct tcpiphdr *));
void tcp_xmit_timer _P((register struct tcpcb *, int));
int tcp_mss _P((register struct tcpcb *, u_int)); int tcp_mss _P((register struct tcpcb *, u_int));
/* tcp_output.c */ /* tcp_output.c */
...@@ -317,7 +313,6 @@ void tcp_template _P((struct tcpcb *)); ...@@ -317,7 +313,6 @@ void tcp_template _P((struct tcpcb *));
void tcp_respond _P((struct tcpcb *, register struct tcpiphdr *, register struct mbuf *, tcp_seq, tcp_seq, int)); void tcp_respond _P((struct tcpcb *, register struct tcpiphdr *, register struct mbuf *, tcp_seq, tcp_seq, int));
struct tcpcb * tcp_newtcpcb _P((struct socket *)); struct tcpcb * tcp_newtcpcb _P((struct socket *));
struct tcpcb * tcp_close _P((register struct tcpcb *)); struct tcpcb * tcp_close _P((register struct tcpcb *));
void tcp_drain _P((void));
void tcp_sockclosed _P((struct tcpcb *)); void tcp_sockclosed _P((struct tcpcb *));
int tcp_fconnect _P((struct socket *)); int tcp_fconnect _P((struct socket *));
void tcp_connect _P((struct socket *)); void tcp_connect _P((struct socket *));
......
...@@ -13,12 +13,16 @@ ...@@ -13,12 +13,16 @@
#include <sys/filio.h> #include <sys/filio.h>
#endif #endif
void static void sofcantrcvmore(struct socket *so);
static void sofcantsendmore(struct socket *so);
#if 0
static void
so_init() so_init()
{ {
/* Nothing yet */ /* Nothing yet */
} }
#endif
struct socket * struct socket *
solookup(head, laddr, lport, faddr, fport) solookup(head, laddr, lport, faddr, fport)
...@@ -421,7 +425,7 @@ sorecvfrom(so) ...@@ -421,7 +425,7 @@ sorecvfrom(so)
int len, n; int len, n;
if (!(m = m_get())) return; if (!(m = m_get())) return;
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
/* /*
* XXX Shouldn't FIONREAD packets destined for port 53, * XXX Shouldn't FIONREAD packets destined for port 53,
...@@ -604,12 +608,13 @@ solisten(port, laddr, lport, flags) ...@@ -604,12 +608,13 @@ solisten(port, laddr, lport, flags)
return so; return so;
} }
#if 0
/* /*
* Data is available in so_rcv * Data is available in so_rcv
* Just write() the data to the socket * Just write() the data to the socket
* XXX not yet... * XXX not yet...
*/ */
void static void
sorwakeup(so) sorwakeup(so)
struct socket *so; struct socket *so;
{ {
...@@ -622,12 +627,13 @@ sorwakeup(so) ...@@ -622,12 +627,13 @@ sorwakeup(so)
* We have room for a read() if we want to * We have room for a read() if we want to
* For now, don't read, it'll be done in the main loop * For now, don't read, it'll be done in the main loop
*/ */
void static void
sowwakeup(so) sowwakeup(so)
struct socket *so; struct socket *so;
{ {
/* Nothing, yet */ /* Nothing, yet */
} }
#endif
/* /*
* Various session state calls * Various session state calls
...@@ -652,9 +658,8 @@ soisfconnected(so) ...@@ -652,9 +658,8 @@ soisfconnected(so)
so->so_state |= SS_ISFCONNECTED; /* Clobber other states */ so->so_state |= SS_ISFCONNECTED; /* Clobber other states */
} }
void static void
sofcantrcvmore(so) sofcantrcvmore(struct socket *so)
struct socket *so;
{ {
if ((so->so_state & SS_NOFDREF) == 0) { if ((so->so_state & SS_NOFDREF) == 0) {
shutdown(so->s,0); shutdown(so->s,0);
...@@ -669,9 +674,8 @@ sofcantrcvmore(so) ...@@ -669,9 +674,8 @@ sofcantrcvmore(so)
so->so_state |= SS_FCANTRCVMORE; so->so_state |= SS_FCANTRCVMORE;
} }
void static void
sofcantsendmore(so) sofcantsendmore(struct socket *so)
struct socket *so;
{ {
if ((so->so_state & SS_NOFDREF) == 0) { if ((so->so_state & SS_NOFDREF) == 0) {
shutdown(so->s,1); /* send FIN to fhost */ shutdown(so->s,1); /* send FIN to fhost */
......
...@@ -81,7 +81,6 @@ struct iovec { ...@@ -81,7 +81,6 @@ struct iovec {
}; };
#endif #endif
void so_init _P((void));
struct socket * solookup _P((struct socket *, struct in_addr, u_int, struct in_addr, u_int)); struct socket * solookup _P((struct socket *, struct in_addr, u_int, struct in_addr, u_int));
struct socket * socreate _P((void)); struct socket * socreate _P((void));
void sofree _P((struct socket *)); void sofree _P((struct socket *));
...@@ -92,12 +91,8 @@ int sowrite _P((struct socket *)); ...@@ -92,12 +91,8 @@ int sowrite _P((struct socket *));
void sorecvfrom _P((struct socket *)); void sorecvfrom _P((struct socket *));
int sosendto _P((struct socket *, struct mbuf *)); int sosendto _P((struct socket *, struct mbuf *));
struct socket * solisten _P((u_int, u_int32_t, u_int, int)); struct socket * solisten _P((u_int, u_int32_t, u_int, int));
void sorwakeup _P((struct socket *));
void sowwakeup _P((struct socket *));
void soisfconnecting _P((register struct socket *)); void soisfconnecting _P((register struct socket *));
void soisfconnected _P((register struct socket *)); void soisfconnected _P((register struct socket *));
void sofcantrcvmore _P((struct socket *));
void sofcantsendmore _P((struct socket *));
void soisfdisconnected _P((struct socket *)); void soisfdisconnected _P((struct socket *));
void sofwdrain _P((struct socket *)); void sofwdrain _P((struct socket *));
......
...@@ -42,8 +42,6 @@ typedef u_int32_t tcp_seq; ...@@ -42,8 +42,6 @@ typedef u_int32_t tcp_seq;
#define PR_SLOWHZ 2 /* 2 slow timeouts per second (approx) */ #define PR_SLOWHZ 2 /* 2 slow timeouts per second (approx) */
#define PR_FASTHZ 5 /* 5 fast timeouts per second (not important) */ #define PR_FASTHZ 5 /* 5 fast timeouts per second (not important) */
extern int tcp_rcvspace;
extern int tcp_sndspace;
extern struct socket *tcp_last_so; extern struct socket *tcp_last_so;
#define TCP_SNDSPACE 8192 #define TCP_SNDSPACE 8192
...@@ -172,6 +170,6 @@ struct tcphdr { ...@@ -172,6 +170,6 @@ struct tcphdr {
extern tcp_seq tcp_iss; /* tcp initial send seq # */ extern tcp_seq tcp_iss; /* tcp initial send seq # */
extern char *tcpstates[]; extern const char * const tcpstates[];
#endif #endif
...@@ -47,7 +47,7 @@ ...@@ -47,7 +47,7 @@
struct socket tcb; struct socket tcb;
int tcprexmtthresh = 3; #define TCPREXMTTHRESH 3
struct socket *tcp_last_so = &tcb; struct socket *tcp_last_so = &tcb;
tcp_seq tcp_iss; /* tcp initial send seq # */ tcp_seq tcp_iss; /* tcp initial send seq # */
...@@ -112,12 +112,13 @@ tcp_seq tcp_iss; /* tcp initial send seq # */ ...@@ -112,12 +112,13 @@ tcp_seq tcp_iss; /* tcp initial send seq # */
} \ } \
} }
#endif #endif
static void tcp_dooptions(struct tcpcb *tp, u_char *cp, int cnt,
struct tcpiphdr *ti);
static void tcp_xmit_timer(register struct tcpcb *tp, int rtt);
int static int
tcp_reass(tp, ti, m) tcp_reass(register struct tcpcb *tp, register struct tcpiphdr *ti,
register struct tcpcb *tp; struct mbuf *m)
register struct tcpiphdr *ti;
struct mbuf *m;
{ {
register struct tcpiphdr *q; register struct tcpiphdr *q;
struct socket *so = tp->t_socket; struct socket *so = tp->t_socket;
...@@ -402,8 +403,8 @@ findso: ...@@ -402,8 +403,8 @@ findso:
goto dropwithreset; goto dropwithreset;
} }
sbreserve(&so->so_snd, tcp_sndspace); sbreserve(&so->so_snd, TCP_SNDSPACE);
sbreserve(&so->so_rcv, tcp_rcvspace); sbreserve(&so->so_rcv, TCP_RCVSPACE);
/* tcp_last_so = so; */ /* XXX ? */ /* tcp_last_so = so; */ /* XXX ? */
/* tp = sototcpcb(so); */ /* tp = sototcpcb(so); */
...@@ -448,10 +449,10 @@ findso: ...@@ -448,10 +449,10 @@ findso:
* Reset idle time and keep-alive timer. * Reset idle time and keep-alive timer.
*/ */
tp->t_idle = 0; tp->t_idle = 0;
if (so_options) if (SO_OPTIONS)
tp->t_timer[TCPT_KEEP] = tcp_keepintvl; tp->t_timer[TCPT_KEEP] = TCPTV_KEEPINTVL;
else else
tp->t_timer[TCPT_KEEP] = tcp_keepidle; tp->t_timer[TCPT_KEEP] = TCPTV_KEEP_IDLE;
/* /*
* Process options if not in LISTEN state, * Process options if not in LISTEN state,
...@@ -1102,7 +1103,7 @@ trimthenstep6: ...@@ -1102,7 +1103,7 @@ trimthenstep6:
if (tp->t_timer[TCPT_REXMT] == 0 || if (tp->t_timer[TCPT_REXMT] == 0 ||
ti->ti_ack != tp->snd_una) ti->ti_ack != tp->snd_una)
tp->t_dupacks = 0; tp->t_dupacks = 0;
else if (++tp->t_dupacks == tcprexmtthresh) { else if (++tp->t_dupacks == TCPREXMTTHRESH) {
tcp_seq onxt = tp->snd_nxt; tcp_seq onxt = tp->snd_nxt;
u_int win = u_int win =
min(tp->snd_wnd, tp->snd_cwnd) / 2 / min(tp->snd_wnd, tp->snd_cwnd) / 2 /
...@@ -1121,7 +1122,7 @@ trimthenstep6: ...@@ -1121,7 +1122,7 @@ trimthenstep6:
if (SEQ_GT(onxt, tp->snd_nxt)) if (SEQ_GT(onxt, tp->snd_nxt))
tp->snd_nxt = onxt; tp->snd_nxt = onxt;
goto drop; goto drop;
} else if (tp->t_dupacks > tcprexmtthresh) { } else if (tp->t_dupacks > TCPREXMTTHRESH) {
tp->snd_cwnd += tp->t_maxseg; tp->snd_cwnd += tp->t_maxseg;
(void) tcp_output(tp); (void) tcp_output(tp);
goto drop; goto drop;
...@@ -1135,7 +1136,7 @@ trimthenstep6: ...@@ -1135,7 +1136,7 @@ trimthenstep6:
* If the congestion window was inflated to account * If the congestion window was inflated to account
* for the other side's cached packets, retract it. * for the other side's cached packets, retract it.
*/ */
if (tp->t_dupacks > tcprexmtthresh && if (tp->t_dupacks > TCPREXMTTHRESH &&
tp->snd_cwnd > tp->snd_ssthresh) tp->snd_cwnd > tp->snd_ssthresh)
tp->snd_cwnd = tp->snd_ssthresh; tp->snd_cwnd = tp->snd_ssthresh;
tp->t_dupacks = 0; tp->t_dupacks = 0;
...@@ -1227,7 +1228,7 @@ trimthenstep6: ...@@ -1227,7 +1228,7 @@ trimthenstep6:
*/ */
if (so->so_state & SS_FCANTRCVMORE) { if (so->so_state & SS_FCANTRCVMORE) {
soisfdisconnected(so); soisfdisconnected(so);
tp->t_timer[TCPT_2MSL] = tcp_maxidle; tp->t_timer[TCPT_2MSL] = TCP_MAXIDLE;
} }
tp->t_state = TCPS_FIN_WAIT_2; tp->t_state = TCPS_FIN_WAIT_2;
} }
...@@ -1490,12 +1491,8 @@ drop: ...@@ -1490,12 +1491,8 @@ drop:
/* int *ts_present; /* int *ts_present;
* u_int32_t *ts_val, *ts_ecr; * u_int32_t *ts_val, *ts_ecr;
*/ */
void static void
tcp_dooptions(tp, cp, cnt, ti) tcp_dooptions(struct tcpcb *tp, u_char *cp, int cnt, struct tcpiphdr *ti)
struct tcpcb *tp;
u_char *cp;
int cnt;
struct tcpiphdr *ti;
{ {
u_int16_t mss; u_int16_t mss;
int opt, optlen; int opt, optlen;
...@@ -1605,10 +1602,8 @@ tcp_pulloutofband(so, ti, m) ...@@ -1605,10 +1602,8 @@ tcp_pulloutofband(so, ti, m)
* and update averages and current timeout. * and update averages and current timeout.
*/ */
void static void
tcp_xmit_timer(tp, rtt) tcp_xmit_timer(register struct tcpcb *tp, int rtt)
register struct tcpcb *tp;
int rtt;
{ {
register short delta; register short delta;
...@@ -1707,7 +1702,7 @@ tcp_mss(tp, offer) ...@@ -1707,7 +1702,7 @@ tcp_mss(tp, offer)
DEBUG_ARG("tp = %lx", (long)tp); DEBUG_ARG("tp = %lx", (long)tp);
DEBUG_ARG("offer = %d", offer); DEBUG_ARG("offer = %d", offer);
mss = min(if_mtu, if_mru) - sizeof(struct tcpiphdr); mss = min(IF_MTU, IF_MRU) - sizeof(struct tcpiphdr);
if (offer) if (offer)
mss = min(mss, offer); mss = min(mss, offer);
mss = max(mss, 32); mss = max(mss, 32);
...@@ -1716,8 +1711,12 @@ tcp_mss(tp, offer) ...@@ -1716,8 +1711,12 @@ tcp_mss(tp, offer)
tp->snd_cwnd = mss; tp->snd_cwnd = mss;
sbreserve(&so->so_snd, tcp_sndspace+((tcp_sndspace%mss)?(mss-(tcp_sndspace%mss)):0)); sbreserve(&so->so_snd, TCP_SNDSPACE + ((TCP_SNDSPACE % mss) ?
sbreserve(&so->so_rcv, tcp_rcvspace+((tcp_rcvspace%mss)?(mss-(tcp_rcvspace%mss)):0)); (mss - (TCP_SNDSPACE % mss)) :
0));
sbreserve(&so->so_rcv, TCP_RCVSPACE + ((TCP_RCVSPACE % mss) ?
(mss - (TCP_RCVSPACE % mss)) :
0));
DEBUG_MISC((dfd, " returning mss = %d\n", mss)); DEBUG_MISC((dfd, " returning mss = %d\n", mss));
......
...@@ -48,14 +48,14 @@ ...@@ -48,14 +48,14 @@
* Since this is only used in "stats socket", we give meaning * Since this is only used in "stats socket", we give meaning
* names instead of the REAL names * names instead of the REAL names
*/ */
char *tcpstates[] = { const char * const tcpstates[] = {
/* "CLOSED", "LISTEN", "SYN_SENT", "SYN_RCVD", */ /* "CLOSED", "LISTEN", "SYN_SENT", "SYN_RCVD", */
"REDIRECT", "LISTEN", "SYN_SENT", "SYN_RCVD", "REDIRECT", "LISTEN", "SYN_SENT", "SYN_RCVD",
"ESTABLISHED", "CLOSE_WAIT", "FIN_WAIT_1", "CLOSING", "ESTABLISHED", "CLOSE_WAIT", "FIN_WAIT_1", "CLOSING",
"LAST_ACK", "FIN_WAIT_2", "TIME_WAIT", "LAST_ACK", "FIN_WAIT_2", "TIME_WAIT",
}; };
u_char tcp_outflags[TCP_NSTATES] = { static const u_char tcp_outflags[TCP_NSTATES] = {
TH_RST|TH_ACK, 0, TH_SYN, TH_SYN|TH_ACK, TH_RST|TH_ACK, 0, TH_SYN, TH_SYN|TH_ACK,
TH_ACK, TH_ACK, TH_FIN|TH_ACK, TH_FIN|TH_ACK, TH_ACK, TH_ACK, TH_FIN|TH_ACK, TH_FIN|TH_ACK,
TH_FIN|TH_ACK, TH_ACK, TH_ACK, TH_FIN|TH_ACK, TH_ACK, TH_ACK,
...@@ -354,7 +354,7 @@ send: ...@@ -354,7 +354,7 @@ send:
error = 1; error = 1;
goto out; goto out;
} }
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
m->m_len = hdrlen; m->m_len = hdrlen;
/* /*
...@@ -396,7 +396,7 @@ send: ...@@ -396,7 +396,7 @@ send:
error = 1; error = 1;
goto out; goto out;
} }
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
m->m_len = hdrlen; m->m_len = hdrlen;
} }
...@@ -536,7 +536,7 @@ send: ...@@ -536,7 +536,7 @@ send:
((struct ip *)ti)->ip_len = m->m_len; ((struct ip *)ti)->ip_len = m->m_len;
((struct ip *)ti)->ip_ttl = ip_defttl; ((struct ip *)ti)->ip_ttl = IPDEFTTL;
((struct ip *)ti)->ip_tos = so->so_iptos; ((struct ip *)ti)->ip_tos = so->so_iptos;
/* #if BSD >= 43 */ /* #if BSD >= 43 */
......
...@@ -46,11 +46,8 @@ ...@@ -46,11 +46,8 @@
#include <slirp.h> #include <slirp.h>
/* patchable/settable parameters for tcp */ /* patchable/settable parameters for tcp */
int tcp_mssdflt = TCP_MSS; /* Don't do rfc1323 performance enhancements */
int tcp_rttdflt = TCPTV_SRTTDFLT / PR_SLOWHZ; #define TCP_DO_RFC1323 0
int tcp_do_rfc1323 = 0; /* Don't do rfc1323 performance enhancements */
int tcp_rcvspace; /* You may want to change this */
int tcp_sndspace; /* Keep small if you have an error prone link */
/* /*
* Tcp initialization * Tcp initialization
...@@ -60,14 +57,6 @@ tcp_init() ...@@ -60,14 +57,6 @@ tcp_init()
{ {
tcp_iss = 1; /* wrong */ tcp_iss = 1; /* wrong */
tcb.so_next = tcb.so_prev = &tcb; tcb.so_next = tcb.so_prev = &tcb;
/* tcp_rcvspace = our Window we advertise to the remote */
tcp_rcvspace = TCP_RCVSPACE;
tcp_sndspace = TCP_SNDSPACE;
/* Make sure tcp_sndspace is at least 2*MSS */
if (tcp_sndspace < 2*(min(if_mtu, if_mru) - sizeof(struct tcpiphdr)))
tcp_sndspace = 2*(min(if_mtu, if_mru) - sizeof(struct tcpiphdr));
} }
/* /*
...@@ -145,7 +134,7 @@ tcp_respond(tp, ti, m, ack, seq, flags) ...@@ -145,7 +134,7 @@ tcp_respond(tp, ti, m, ack, seq, flags)
#else #else
tlen = 0; tlen = 0;
#endif #endif
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
*mtod(m, struct tcpiphdr *) = *ti; *mtod(m, struct tcpiphdr *) = *ti;
ti = mtod(m, struct tcpiphdr *); ti = mtod(m, struct tcpiphdr *);
flags = TH_ACK; flags = TH_ACK;
...@@ -186,7 +175,7 @@ tcp_respond(tp, ti, m, ack, seq, flags) ...@@ -186,7 +175,7 @@ tcp_respond(tp, ti, m, ack, seq, flags)
if(flags & TH_RST) if(flags & TH_RST)
((struct ip *)ti)->ip_ttl = MAXTTL; ((struct ip *)ti)->ip_ttl = MAXTTL;
else else
((struct ip *)ti)->ip_ttl = ip_defttl; ((struct ip *)ti)->ip_ttl = IPDEFTTL;
(void) ip_output((struct socket *)0, m); (void) ip_output((struct socket *)0, m);
} }
...@@ -208,9 +197,9 @@ tcp_newtcpcb(so) ...@@ -208,9 +197,9 @@ tcp_newtcpcb(so)
memset((char *) tp, 0, sizeof(struct tcpcb)); memset((char *) tp, 0, sizeof(struct tcpcb));
tp->seg_next = tp->seg_prev = (tcpiphdrp_32)tp; tp->seg_next = tp->seg_prev = (tcpiphdrp_32)tp;
tp->t_maxseg = tcp_mssdflt; tp->t_maxseg = TCP_MSS;
tp->t_flags = tcp_do_rfc1323 ? (TF_REQ_SCALE|TF_REQ_TSTMP) : 0; tp->t_flags = TCP_DO_RFC1323 ? (TF_REQ_SCALE|TF_REQ_TSTMP) : 0;
tp->t_socket = so; tp->t_socket = so;
/* /*
...@@ -219,7 +208,7 @@ tcp_newtcpcb(so) ...@@ -219,7 +208,7 @@ tcp_newtcpcb(so)
* reasonable initial retransmit time. * reasonable initial retransmit time.
*/ */
tp->t_srtt = TCPTV_SRTTBASE; tp->t_srtt = TCPTV_SRTTBASE;
tp->t_rttvar = tcp_rttdflt * PR_SLOWHZ << 2; tp->t_rttvar = TCPTV_SRTTDFLT << 2;
tp->t_rttmin = TCPTV_MIN; tp->t_rttmin = TCPTV_MIN;
TCPT_RANGESET(tp->t_rxtcur, TCPT_RANGESET(tp->t_rxtcur,
...@@ -309,6 +298,7 @@ tcp_close(tp) ...@@ -309,6 +298,7 @@ tcp_close(tp)
return ((struct tcpcb *)0); return ((struct tcpcb *)0);
} }
#ifdef notdef
void void
tcp_drain() tcp_drain()
{ {
...@@ -319,9 +309,6 @@ tcp_drain() ...@@ -319,9 +309,6 @@ tcp_drain()
* When a source quench is received, close congestion window * When a source quench is received, close congestion window
* to one segment. We will gradually open it again as we proceed. * to one segment. We will gradually open it again as we proceed.
*/ */
#ifdef notdef
void void
tcp_quench(i, errno) tcp_quench(i, errno)
...@@ -556,7 +543,7 @@ tcp_attach(so) ...@@ -556,7 +543,7 @@ tcp_attach(so)
/* /*
* Set the socket's type of service field * Set the socket's type of service field
*/ */
struct tos_t tcptos[] = { static const struct tos_t tcptos[] = {
{0, 20, IPTOS_THROUGHPUT, 0}, /* ftp data */ {0, 20, IPTOS_THROUGHPUT, 0}, /* ftp data */
{21, 21, IPTOS_LOWDELAY, EMU_FTP}, /* ftp control */ {21, 21, IPTOS_LOWDELAY, EMU_FTP}, /* ftp control */
{0, 23, IPTOS_LOWDELAY, 0}, /* telnet */ {0, 23, IPTOS_LOWDELAY, 0}, /* telnet */
...@@ -572,7 +559,7 @@ struct tos_t tcptos[] = { ...@@ -572,7 +559,7 @@ struct tos_t tcptos[] = {
{0, 0, 0, 0} {0, 0, 0, 0}
}; };
struct emu_t *tcpemu = 0; static struct emu_t *tcpemu = 0;
/* /*
* Return TOS according to the above table * Return TOS according to the above table
...@@ -665,7 +652,7 @@ tcp_emu(so, m) ...@@ -665,7 +652,7 @@ tcp_emu(so, m)
so_rcv->sb_rptr += m->m_len; so_rcv->sb_rptr += m->m_len;
m->m_data[m->m_len] = 0; /* NULL terminate */ m->m_data[m->m_len] = 0; /* NULL terminate */
if (strchr(m->m_data, '\r') || strchr(m->m_data, '\n')) { if (strchr(m->m_data, '\r') || strchr(m->m_data, '\n')) {
if (sscanf(so_rcv->sb_data, "%d%*[ ,]%d", &n1, &n2) == 2) { if (sscanf(so_rcv->sb_data, "%u%*[ ,]%u", &n1, &n2) == 2) {
HTONS(n1); HTONS(n1);
HTONS(n2); HTONS(n2);
/* n2 is the one on our host */ /* n2 is the one on our host */
...@@ -991,7 +978,7 @@ do_prompt: ...@@ -991,7 +978,7 @@ do_prompt:
/* /*
* Need to emulate the PORT command * Need to emulate the PORT command
*/ */
x = sscanf(bptr, "ORT %d,%d,%d,%d,%d,%d\r\n%256[^\177]", x = sscanf(bptr, "ORT %u,%u,%u,%u,%u,%u\r\n%256[^\177]",
&n1, &n2, &n3, &n4, &n5, &n6, buff); &n1, &n2, &n3, &n4, &n5, &n6, buff);
if (x < 6) if (x < 6)
return 1; return 1;
...@@ -1022,7 +1009,7 @@ do_prompt: ...@@ -1022,7 +1009,7 @@ do_prompt:
/* /*
* Need to emulate the PASV response * Need to emulate the PASV response
*/ */
x = sscanf(bptr, "27 Entering Passive Mode (%d,%d,%d,%d,%d,%d)\r\n%256[^\177]", x = sscanf(bptr, "27 Entering Passive Mode (%u,%u,%u,%u,%u,%u)\r\n%256[^\177]",
&n1, &n2, &n3, &n4, &n5, &n6, buff); &n1, &n2, &n3, &n4, &n5, &n6, buff);
if (x < 6) if (x < 6)
return 1; return 1;
......
...@@ -36,17 +36,14 @@ ...@@ -36,17 +36,14 @@
#include <slirp.h> #include <slirp.h>
int tcp_keepidle = TCPTV_KEEP_IDLE;
int tcp_keepintvl = TCPTV_KEEPINTVL;
int tcp_maxidle;
int so_options = DO_KEEPALIVE;
#ifdef LOG_ENABLED #ifdef LOG_ENABLED
struct tcpstat tcpstat; /* tcp statistics */ struct tcpstat tcpstat; /* tcp statistics */
#endif #endif
u_int32_t tcp_now; /* for RFC 1323 timestamps */ u_int32_t tcp_now; /* for RFC 1323 timestamps */
static struct tcpcb *tcp_timers(register struct tcpcb *tp, int timer);
/* /*
* Fast timeout routine for processing delayed acks * Fast timeout routine for processing delayed acks
*/ */
...@@ -84,7 +81,6 @@ tcp_slowtimo() ...@@ -84,7 +81,6 @@ tcp_slowtimo()
DEBUG_CALL("tcp_slowtimo"); DEBUG_CALL("tcp_slowtimo");
tcp_maxidle = TCPTV_KEEPCNT * tcp_keepintvl;
/* /*
* Search through tcb's and update active timers. * Search through tcb's and update active timers.
*/ */
...@@ -130,16 +126,14 @@ tcp_canceltimers(tp) ...@@ -130,16 +126,14 @@ tcp_canceltimers(tp)
tp->t_timer[i] = 0; tp->t_timer[i] = 0;
} }
int tcp_backoff[TCP_MAXRXTSHIFT + 1] = const int tcp_backoff[TCP_MAXRXTSHIFT + 1] =
{ 1, 2, 4, 8, 16, 32, 64, 64, 64, 64, 64, 64, 64 }; { 1, 2, 4, 8, 16, 32, 64, 64, 64, 64, 64, 64, 64 };
/* /*
* TCP timer processing. * TCP timer processing.
*/ */
struct tcpcb * static struct tcpcb *
tcp_timers(tp, timer) tcp_timers(register struct tcpcb *tp, int timer)
register struct tcpcb *tp;
int timer;
{ {
register int rexmt; register int rexmt;
...@@ -155,8 +149,8 @@ tcp_timers(tp, timer) ...@@ -155,8 +149,8 @@ tcp_timers(tp, timer)
*/ */
case TCPT_2MSL: case TCPT_2MSL:
if (tp->t_state != TCPS_TIME_WAIT && if (tp->t_state != TCPS_TIME_WAIT &&
tp->t_idle <= tcp_maxidle) tp->t_idle <= TCP_MAXIDLE)
tp->t_timer[TCPT_2MSL] = tcp_keepintvl; tp->t_timer[TCPT_2MSL] = TCPTV_KEEPINTVL;
else else
tp = tcp_close(tp); tp = tcp_close(tp);
break; break;
...@@ -287,8 +281,8 @@ tcp_timers(tp, timer) ...@@ -287,8 +281,8 @@ tcp_timers(tp, timer)
goto dropit; goto dropit;
/* if (tp->t_socket->so_options & SO_KEEPALIVE && */ /* if (tp->t_socket->so_options & SO_KEEPALIVE && */
if ((so_options) && tp->t_state <= TCPS_CLOSE_WAIT) { if ((SO_OPTIONS) && tp->t_state <= TCPS_CLOSE_WAIT) {
if (tp->t_idle >= tcp_keepidle + tcp_maxidle) if (tp->t_idle >= TCPTV_KEEP_IDLE + TCP_MAXIDLE)
goto dropit; goto dropit;
/* /*
* Send a packet designed to force a response * Send a packet designed to force a response
...@@ -314,9 +308,9 @@ tcp_timers(tp, timer) ...@@ -314,9 +308,9 @@ tcp_timers(tp, timer)
tcp_respond(tp, &tp->t_template, (struct mbuf *)NULL, tcp_respond(tp, &tp->t_template, (struct mbuf *)NULL,
tp->rcv_nxt, tp->snd_una - 1, 0); tp->rcv_nxt, tp->snd_una - 1, 0);
#endif #endif
tp->t_timer[TCPT_KEEP] = tcp_keepintvl; tp->t_timer[TCPT_KEEP] = TCPTV_KEEPINTVL;
} else } else
tp->t_timer[TCPT_KEEP] = tcp_keepidle; tp->t_timer[TCPT_KEEP] = TCPTV_KEEP_IDLE;
break; break;
dropit: dropit:
......
...@@ -126,17 +126,12 @@ char *tcptimers[] = ...@@ -126,17 +126,12 @@ char *tcptimers[] =
(tv) = (tvmax); \ (tv) = (tvmax); \
} }
extern int tcp_keepidle; /* time before keepalive probes begin */ extern const int tcp_backoff[];
extern int tcp_keepintvl; /* time between keepalive probes */
extern int tcp_maxidle; /* time to drop after starting probes */
extern int tcp_ttl; /* time to live for TCP segs */
extern int tcp_backoff[];
struct tcpcb; struct tcpcb;
void tcp_fasttimo _P((void)); void tcp_fasttimo _P((void));
void tcp_slowtimo _P((void)); void tcp_slowtimo _P((void));
void tcp_canceltimers _P((struct tcpcb *)); void tcp_canceltimers _P((struct tcpcb *));
struct tcpcb * tcp_timers _P((register struct tcpcb *, int));
#endif #endif
...@@ -34,7 +34,7 @@ struct tftp_session { ...@@ -34,7 +34,7 @@ struct tftp_session {
int timestamp; int timestamp;
}; };
struct tftp_session tftp_sessions[TFTP_SESSIONS_MAX]; static struct tftp_session tftp_sessions[TFTP_SESSIONS_MAX];
const char *tftp_prefix; const char *tftp_prefix;
...@@ -143,7 +143,7 @@ static int tftp_send_oack(struct tftp_session *spt, ...@@ -143,7 +143,7 @@ static int tftp_send_oack(struct tftp_session *spt,
memset(m->m_data, 0, m->m_size); memset(m->m_data, 0, m->m_size);
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
tp = (void *)m->m_data; tp = (void *)m->m_data;
m->m_data += sizeof(struct udpiphdr); m->m_data += sizeof(struct udpiphdr);
...@@ -183,7 +183,7 @@ static int tftp_send_error(struct tftp_session *spt, ...@@ -183,7 +183,7 @@ static int tftp_send_error(struct tftp_session *spt,
memset(m->m_data, 0, m->m_size); memset(m->m_data, 0, m->m_size);
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
tp = (void *)m->m_data; tp = (void *)m->m_data;
m->m_data += sizeof(struct udpiphdr); m->m_data += sizeof(struct udpiphdr);
...@@ -230,7 +230,7 @@ static int tftp_send_data(struct tftp_session *spt, ...@@ -230,7 +230,7 @@ static int tftp_send_data(struct tftp_session *spt,
memset(m->m_data, 0, m->m_size); memset(m->m_data, 0, m->m_size);
m->m_data += if_maxlinkhdr; m->m_data += IF_MAXLINKHDR;
tp = (void *)m->m_data; tp = (void *)m->m_data;
m->m_data += sizeof(struct udpiphdr); m->m_data += sizeof(struct udpiphdr);
......
...@@ -51,14 +51,17 @@ struct udpstat udpstat; ...@@ -51,14 +51,17 @@ struct udpstat udpstat;
struct socket udb; struct socket udb;
static u_int8_t udp_tos(struct socket *so);
static void udp_emu(struct socket *so, struct mbuf *m);
/* /*
* UDP protocol implementation. * UDP protocol implementation.
* Per RFC 768, August, 1980. * Per RFC 768, August, 1980.
*/ */
#ifndef COMPAT_42 #ifndef COMPAT_42
int udpcksum = 1; #define UDPCKSUM 1
#else #else
int udpcksum = 0; /* XXX */ #define UDPCKSUM 0 /* XXX */
#endif #endif
struct socket *udp_last_so = &udb; struct socket *udp_last_so = &udb;
...@@ -132,7 +135,7 @@ udp_input(m, iphlen) ...@@ -132,7 +135,7 @@ udp_input(m, iphlen)
/* /*
* Checksum extended UDP header and data. * Checksum extended UDP header and data.
*/ */
if (udpcksum && uh->uh_sum) { if (UDPCKSUM && uh->uh_sum) {
((struct ipovly *)ip)->ih_next = 0; ((struct ipovly *)ip)->ih_next = 0;
((struct ipovly *)ip)->ih_prev = 0; ((struct ipovly *)ip)->ih_prev = 0;
((struct ipovly *)ip)->ih_x1 = 0; ((struct ipovly *)ip)->ih_x1 = 0;
...@@ -292,13 +295,13 @@ int udp_output2(struct socket *so, struct mbuf *m, ...@@ -292,13 +295,13 @@ int udp_output2(struct socket *so, struct mbuf *m,
* Stuff checksum and output datagram. * Stuff checksum and output datagram.
*/ */
ui->ui_sum = 0; ui->ui_sum = 0;
if (udpcksum) { if (UDPCKSUM) {
if ((ui->ui_sum = cksum(m, /* sizeof (struct udpiphdr) + */ m->m_len)) == 0) if ((ui->ui_sum = cksum(m, /* sizeof (struct udpiphdr) + */ m->m_len)) == 0)
ui->ui_sum = 0xffff; ui->ui_sum = 0xffff;
} }
((struct ip *)ui)->ip_len = m->m_len; ((struct ip *)ui)->ip_len = m->m_len;
((struct ip *)ui)->ip_ttl = ip_defttl; ((struct ip *)ui)->ip_ttl = IPDEFTTL;
((struct ip *)ui)->ip_tos = iptos; ((struct ip *)ui)->ip_tos = iptos;
STAT(udpstat.udps_opackets++); STAT(udpstat.udps_opackets++);
...@@ -369,7 +372,7 @@ udp_detach(so) ...@@ -369,7 +372,7 @@ udp_detach(so)
sofree(so); sofree(so);
} }
struct tos_t udptos[] = { static const struct tos_t udptos[] = {
{0, 53, IPTOS_LOWDELAY, 0}, /* DNS */ {0, 53, IPTOS_LOWDELAY, 0}, /* DNS */
{517, 517, IPTOS_LOWDELAY, EMU_TALK}, /* talk */ {517, 517, IPTOS_LOWDELAY, EMU_TALK}, /* talk */
{518, 518, IPTOS_LOWDELAY, EMU_NTALK}, /* ntalk */ {518, 518, IPTOS_LOWDELAY, EMU_NTALK}, /* ntalk */
...@@ -377,9 +380,8 @@ struct tos_t udptos[] = { ...@@ -377,9 +380,8 @@ struct tos_t udptos[] = {
{0, 0, 0, 0} {0, 0, 0, 0}
}; };
u_int8_t static u_int8_t
udp_tos(so) udp_tos(struct socket *so)
struct socket *so;
{ {
int i = 0; int i = 0;
...@@ -402,10 +404,8 @@ udp_tos(so) ...@@ -402,10 +404,8 @@ udp_tos(so)
/* /*
* Here, talk/ytalk/ntalk requests must be emulated * Here, talk/ytalk/ntalk requests must be emulated
*/ */
void static void
udp_emu(so, m) udp_emu(struct socket *so, struct mbuf *m)
struct socket *so;
struct mbuf *m;
{ {
struct sockaddr_in addr; struct sockaddr_in addr;
int addrlen = sizeof(addr); int addrlen = sizeof(addr);
......
...@@ -106,8 +106,6 @@ void udp_input _P((register struct mbuf *, int)); ...@@ -106,8 +106,6 @@ void udp_input _P((register struct mbuf *, int));
int udp_output _P((struct socket *, struct mbuf *, struct sockaddr_in *)); int udp_output _P((struct socket *, struct mbuf *, struct sockaddr_in *));
int udp_attach _P((struct socket *)); int udp_attach _P((struct socket *));
void udp_detach _P((struct socket *)); void udp_detach _P((struct socket *));
u_int8_t udp_tos _P((struct socket *));
void udp_emu _P((struct socket *, struct mbuf *));
struct socket * udp_listen _P((u_int, u_int32_t, u_int, int)); struct socket * udp_listen _P((u_int, u_int32_t, u_int, int));
int udp_output2(struct socket *so, struct mbuf *m, int udp_output2(struct socket *so, struct mbuf *m,
struct sockaddr_in *saddr, struct sockaddr_in *daddr, struct sockaddr_in *saddr, struct sockaddr_in *daddr,
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册