PERFORCE change 126121 for review
Kip Macy
kmacy at FreeBSD.org
Wed Sep 5 20:42:42 PDT 2007
http://perforce.freebsd.org/chv.cgi?CH=126121
Change 126121 by kmacy at kmacy:storage:toestack on 2007/09/06 03:42:13
direct operations to TOE usrreqs if TOE is enabled on a tcpcb
Affected files ...
.. //depot/projects/toestack/sys/conf/files#2 edit
.. //depot/projects/toestack/sys/netinet/tcp_ofld.c#1 add
.. //depot/projects/toestack/sys/netinet/tcp_ofld.h#1 add
.. //depot/projects/toestack/sys/netinet/tcp_subr.c#2 edit
.. //depot/projects/toestack/sys/netinet/tcp_usrreq.c#2 edit
.. //depot/projects/toestack/sys/netinet/tcp_var.h#2 edit
Differences ...
==== //depot/projects/toestack/sys/conf/files#2 (text+ko) ====
@@ -1887,6 +1887,7 @@
netinet/tcp_timer.c optional inet
netinet/tcp_timewait.c optional inet
netinet/tcp_usrreq.c optional inet
+netinet/tcp_ofld.c optional inet
netinet/udp_usrreq.c optional inet
netinet/libalias/alias.c optional libalias | netgraph_nat
netinet/libalias/alias_db.c optional libalias | netgraph_nat
==== //depot/projects/toestack/sys/netinet/tcp_subr.c#2 (text+ko) ====
@@ -83,6 +83,7 @@
#include <netinet/tcp_timer.h>
#include <netinet/tcp_var.h>
#include <netinet/tcp_syncache.h>
+#include <netinet/tcp_ofld.h>
#ifdef INET6
#include <netinet6/tcp6_var.h>
#endif
@@ -646,7 +647,7 @@
if (TCPS_HAVERCVDSYN(tp->t_state)) {
tp->t_state = TCPS_CLOSED;
- (void) tcp_output(tp);
+ (void) tcp_gen_abort(tp);
tcpstat.tcps_drops++;
} else
tcpstat.tcps_conndrops++;
@@ -1560,7 +1561,7 @@
tp->snd_recover = tp->snd_max;
if (tp->t_flags & TF_SACK_PERMIT)
EXIT_FASTRECOVERY(tp);
- tcp_output(tp);
+ tcp_gen_send(tp);
return (inp);
}
==== //depot/projects/toestack/sys/netinet/tcp_usrreq.c#2 (text+ko) ====
@@ -83,6 +83,7 @@
#ifdef TCPDEBUG
#include <netinet/tcp_debug.h>
#endif
+#include <netinet/tcp_ofld.h>
/*
* TCP protocol interface to socket abstraction.
@@ -383,6 +384,7 @@
if (error == 0) {
tp->t_state = TCPS_LISTEN;
solisten_proto(so, backlog);
+ tcp_gen_listen(tp);
}
SOCK_UNLOCK(so);
@@ -474,7 +476,7 @@
TCPDEBUG1();
if ((error = tcp_connect(tp, nam, td)) != 0)
goto out;
- error = tcp_output(tp);
+ error = tcp_gen_connect(tp, nam);
out:
TCPDEBUG2(PRU_CONNECT);
INP_UNLOCK(inp);
@@ -526,7 +528,7 @@
inp->inp_vflag &= ~INP_IPV6;
if ((error = tcp_connect(tp, (struct sockaddr *)&sin, td)) != 0)
goto out;
- error = tcp_output(tp);
+ error = tcp_gen_connect(tp, nam);
goto out;
}
inp->inp_vflag &= ~INP_IPV4;
@@ -534,7 +536,7 @@
inp->inp_inc.inc_isipv6 = 1;
if ((error = tcp6_connect(tp, nam, td)) != 0)
goto out;
- error = tcp_output(tp);
+ error = tcp_gen_connect(tp, nam);
out:
TCPDEBUG2(PRU_CONNECT);
@@ -701,7 +703,7 @@
TCPDEBUG1();
socantsendmore(so);
tcp_usrclosed(tp);
- error = tcp_output(tp);
+ error = tcp_gen_disconnect(tp);
out:
TCPDEBUG2(PRU_SHUTDOWN);
@@ -731,7 +733,7 @@
}
tp = intotcpcb(inp);
TCPDEBUG1();
- tcp_output(tp);
+ tcp_gen_rcvd(tp);
out:
TCPDEBUG2(PRU_RCVD);
@@ -836,7 +838,7 @@
if (tp != NULL) {
if (flags & PRUS_MORETOCOME)
tp->t_flags |= TF_MORETOCOME;
- error = tcp_output(tp);
+ error = tcp_gen_send(tp);
if (flags & PRUS_MORETOCOME)
tp->t_flags &= ~TF_MORETOCOME;
}
@@ -887,7 +889,7 @@
}
tp->snd_up = tp->snd_una + so->so_snd.sb_cc;
tp->t_flags |= TF_FORCEDATA;
- error = tcp_output(tp);
+ error = tcp_gen_send(tp);
tp->t_flags &= ~TF_FORCEDATA;
}
out:
@@ -1488,7 +1490,7 @@
sbflush(&so->so_rcv);
tcp_usrclosed(tp);
if (!(inp->inp_vflag & INP_DROPPED))
- tcp_output(tp);
+ tcp_gen_disconnect(tp);
}
}
==== //depot/projects/toestack/sys/netinet/tcp_var.h#2 (text+ko) ====
@@ -123,6 +123,7 @@
#define TF_SIGNATURE 0x400000 /* require MD5 digests (RFC2385) */
#define TF_FORCEDATA 0x800000 /* force out a byte */
#define TF_TSO 0x1000000 /* TSO enabled on this connection */
+#define TF_TOE 0x2000000 /* TOE enabled on this connection */
tcp_seq snd_una; /* send unacknowledged */
tcp_seq snd_max; /* highest sequence number sent;
@@ -206,6 +207,8 @@
int t_rttlow; /* smallest observerved RTT */
u_int32_t rfbuf_ts; /* recv buffer autoscaling timestamp */
int rfbuf_cnt; /* recv buffer autoscaling byte count */
+ struct toe_usrreqs *t_tu; /* offload operations vector */
+ void *t_toe_priv;
};
#define IN_FASTRECOVERY(tp) (tp->t_flags & TF_FASTRECOVERY)
More information about the p4-projects
mailing list