Deleted Added
full compact
tcp_input.c (130398) tcp_input.c (130480)
1/*
2 * Copyright (c) 1982, 1986, 1988, 1990, 1993, 1994, 1995
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 13 unchanged lines hidden (view full) ---

22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 *
29 * @(#)tcp_input.c 8.12 (Berkeley) 5/24/95
1/*
2 * Copyright (c) 1982, 1986, 1988, 1990, 1993, 1994, 1995
3 * The Regents of the University of California. All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * 1. Redistributions of source code must retain the above copyright

--- 13 unchanged lines hidden (view full) ---

22 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
23 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
24 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
25 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
26 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
27 * SUCH DAMAGE.
28 *
29 * @(#)tcp_input.c 8.12 (Berkeley) 5/24/95
30 * $FreeBSD: head/sys/netinet/tcp_input.c 130398 2004-06-13 02:50:07Z rwatson $
30 * $FreeBSD: head/sys/netinet/tcp_input.c 130480 2004-06-14 18:16:22Z rwatson $
31 */
32
33#include "opt_ipfw.h" /* for ipfw_fwd */
34#include "opt_inet.h"
35#include "opt_inet6.h"
36#include "opt_ipsec.h"
37#include "opt_mac.h"
38#include "opt_tcpdebug.h"

--- 311 unchanged lines hidden (view full) ---

350 q = LIST_FIRST(&tp->t_segq);
351 if (!q || q->tqe_th->th_seq != tp->rcv_nxt)
352 return (0);
353 do {
354 tp->rcv_nxt += q->tqe_len;
355 flags = q->tqe_th->th_flags & TH_FIN;
356 nq = LIST_NEXT(q, tqe_q);
357 LIST_REMOVE(q, tqe_q);
31 */
32
33#include "opt_ipfw.h" /* for ipfw_fwd */
34#include "opt_inet.h"
35#include "opt_inet6.h"
36#include "opt_ipsec.h"
37#include "opt_mac.h"
38#include "opt_tcpdebug.h"

--- 311 unchanged lines hidden (view full) ---

350 q = LIST_FIRST(&tp->t_segq);
351 if (!q || q->tqe_th->th_seq != tp->rcv_nxt)
352 return (0);
353 do {
354 tp->rcv_nxt += q->tqe_len;
355 flags = q->tqe_th->th_flags & TH_FIN;
356 nq = LIST_NEXT(q, tqe_q);
357 LIST_REMOVE(q, tqe_q);
358 if (so->so_state & SS_CANTRCVMORE)
358 if (so->so_rcv.sb_state & SBS_CANTRCVMORE)
359 m_freem(q->tqe_m);
360 else
361 sbappendstream(&so->so_rcv, q->tqe_m);
362 uma_zfree(tcp_reass_zone, q);
363 tp->t_segqlen--;
364 tcp_reass_qsize--;
365 q = nq;
366 } while (q && q->tqe_th->th_seq == tp->rcv_nxt);

--- 865 unchanged lines hidden (view full) ---

1232 /*
1233#ifdef TCPDEBUG
1234 if (so->so_options & SO_DEBUG)
1235 tcp_trace(TA_INPUT, ostate, tp,
1236 (void *)tcp_saveipgen, &tcp_savetcp, 0);
1237#endif
1238 * Add data to socket buffer.
1239 */
359 m_freem(q->tqe_m);
360 else
361 sbappendstream(&so->so_rcv, q->tqe_m);
362 uma_zfree(tcp_reass_zone, q);
363 tp->t_segqlen--;
364 tcp_reass_qsize--;
365 q = nq;
366 } while (q && q->tqe_th->th_seq == tp->rcv_nxt);

--- 865 unchanged lines hidden (view full) ---

1232 /*
1233#ifdef TCPDEBUG
1234 if (so->so_options & SO_DEBUG)
1235 tcp_trace(TA_INPUT, ostate, tp,
1236 (void *)tcp_saveipgen, &tcp_savetcp, 0);
1237#endif
1238 * Add data to socket buffer.
1239 */
1240 if (so->so_state & SS_CANTRCVMORE) {
1240 if (so->so_rcv.sb_state & SBS_CANTRCVMORE) {
1241 m_freem(m);
1242 } else {
1243 m_adj(m, drop_hdrlen); /* delayed header drop */
1244 sbappendstream(&so->so_rcv, m);
1245 }
1246 sorwakeup(so);
1247 if (DELAY_ACK(tp)) {
1248 tp->t_flags |= TF_DELACK;

--- 889 unchanged lines hidden (view full) ---

2138 * Starting the timer is contrary to the
2139 * specification, but if we don't get a FIN
2140 * we'll hang forever.
2141 */
2142 /* XXXjl
2143 * we should release the tp also, and use a
2144 * compressed state.
2145 */
1241 m_freem(m);
1242 } else {
1243 m_adj(m, drop_hdrlen); /* delayed header drop */
1244 sbappendstream(&so->so_rcv, m);
1245 }
1246 sorwakeup(so);
1247 if (DELAY_ACK(tp)) {
1248 tp->t_flags |= TF_DELACK;

--- 889 unchanged lines hidden (view full) ---

2138 * Starting the timer is contrary to the
2139 * specification, but if we don't get a FIN
2140 * we'll hang forever.
2141 */
2142 /* XXXjl
2143 * we should release the tp also, and use a
2144 * compressed state.
2145 */
2146 if (so->so_state & SS_CANTRCVMORE) {
2146 if (so->so_rcv.sb_state & SBS_CANTRCVMORE) {
2147 soisdisconnected(so);
2148 callout_reset(tp->tt_2msl, tcp_maxidle,
2149 tcp_timer_2msl, tp);
2150 }
2151 tp->t_state = TCPS_FIN_WAIT_2;
2152 }
2153 break;
2154

--- 90 unchanged lines hidden (view full) ---

2245 * of data past the urgent section as the original
2246 * spec states (in one of two places).
2247 */
2248 if (SEQ_GT(th->th_seq+th->th_urp, tp->rcv_up)) {
2249 tp->rcv_up = th->th_seq + th->th_urp;
2250 so->so_oobmark = so->so_rcv.sb_cc +
2251 (tp->rcv_up - tp->rcv_nxt) - 1;
2252 if (so->so_oobmark == 0)
2147 soisdisconnected(so);
2148 callout_reset(tp->tt_2msl, tcp_maxidle,
2149 tcp_timer_2msl, tp);
2150 }
2151 tp->t_state = TCPS_FIN_WAIT_2;
2152 }
2153 break;
2154

--- 90 unchanged lines hidden (view full) ---

2245 * of data past the urgent section as the original
2246 * spec states (in one of two places).
2247 */
2248 if (SEQ_GT(th->th_seq+th->th_urp, tp->rcv_up)) {
2249 tp->rcv_up = th->th_seq + th->th_urp;
2250 so->so_oobmark = so->so_rcv.sb_cc +
2251 (tp->rcv_up - tp->rcv_nxt) - 1;
2252 if (so->so_oobmark == 0)
2253 so->so_state |= SS_RCVATMARK;
2253 so->so_rcv.sb_state |= SBS_RCVATMARK;
2254 sohasoutofband(so);
2255 tp->t_oobflags &= ~(TCPOOB_HAVEDATA | TCPOOB_HADDATA);
2256 }
2257 /*
2258 * Remove out of band data so doesn't get presented to user.
2259 * This can happen independent of advancing the URG pointer,
2260 * but if two URG's are pending at once, some out-of-band
2261 * data may creep in... ick.

--- 44 unchanged lines hidden (view full) ---

2306 tp->t_flags |= TF_DELACK;
2307 else
2308 tp->t_flags |= TF_ACKNOW;
2309 tp->rcv_nxt += tlen;
2310 thflags = th->th_flags & TH_FIN;
2311 tcpstat.tcps_rcvpack++;
2312 tcpstat.tcps_rcvbyte += tlen;
2313 ND6_HINT(tp);
2254 sohasoutofband(so);
2255 tp->t_oobflags &= ~(TCPOOB_HAVEDATA | TCPOOB_HADDATA);
2256 }
2257 /*
2258 * Remove out of band data so doesn't get presented to user.
2259 * This can happen independent of advancing the URG pointer,
2260 * but if two URG's are pending at once, some out-of-band
2261 * data may creep in... ick.

--- 44 unchanged lines hidden (view full) ---

2306 tp->t_flags |= TF_DELACK;
2307 else
2308 tp->t_flags |= TF_ACKNOW;
2309 tp->rcv_nxt += tlen;
2310 thflags = th->th_flags & TH_FIN;
2311 tcpstat.tcps_rcvpack++;
2312 tcpstat.tcps_rcvbyte += tlen;
2313 ND6_HINT(tp);
2314 if (so->so_state & SS_CANTRCVMORE)
2314 if (so->so_rcv.sb_state & SBS_CANTRCVMORE)
2315 m_freem(m);
2316 else
2317 sbappendstream(&so->so_rcv, m);
2318 sorwakeup(so);
2319 } else {
2320 thflags = tcp_reass(tp, th, &tlen, m);
2321 tp->t_flags |= TF_ACKNOW;
2322 }

--- 920 unchanged lines hidden ---
2315 m_freem(m);
2316 else
2317 sbappendstream(&so->so_rcv, m);
2318 sorwakeup(so);
2319 } else {
2320 thflags = tcp_reass(tp, th, &tlen, m);
2321 tp->t_flags |= TF_ACKNOW;
2322 }

--- 920 unchanged lines hidden ---