revert tcp_sack.c rev.1.15 because it's unnecessary.

all callers of these functions are at splsoftnet already:
	tcp_sack_option
		tcp_input ok

	tcp_del_sackholes
		tcp_input ok

	tcp_free_sackholes
		tcp_close ok
		tcp_timer_rexmt ok
		tcp_timer_2msl ok
This commit is contained in:
yamt 2006-10-07 19:56:14 +00:00
parent 38fb8d4a38
commit 5a0a4d9df3

View File

@ -1,4 +1,4 @@
/* $NetBSD: tcp_sack.c,v 1.17 2006/10/07 19:26:45 yamt Exp $ */ /* $NetBSD: tcp_sack.c,v 1.18 2006/10/07 19:56:14 yamt Exp $ */
/* /*
* Copyright (c) 2005 The NetBSD Foundation, Inc. * Copyright (c) 2005 The NetBSD Foundation, Inc.
@ -109,7 +109,7 @@
*/ */
#include <sys/cdefs.h> #include <sys/cdefs.h>
__KERNEL_RCSID(0, "$NetBSD: tcp_sack.c,v 1.17 2006/10/07 19:26:45 yamt Exp $"); __KERNEL_RCSID(0, "$NetBSD: tcp_sack.c,v 1.18 2006/10/07 19:56:14 yamt Exp $");
#include "opt_inet.h" #include "opt_inet.h"
#include "opt_ipsec.h" #include "opt_ipsec.h"
@ -190,7 +190,7 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
struct sackhole *cur = NULL; struct sackhole *cur = NULL;
struct sackhole *tmp = NULL; struct sackhole *tmp = NULL;
u_int32_t *lp = (u_int32_t *) (cp + 2); u_int32_t *lp = (u_int32_t *) (cp + 2);
int i, j, num_sack_blks, s; int i, j, num_sack_blks;
tcp_seq left, right, acked; tcp_seq left, right, acked;
/* /*
@ -246,9 +246,6 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
t_sack_block[j].right = right; t_sack_block[j].right = right;
} }
/* XXX: Investigate making this a bit more fine-grained. */
s = splsoftnet();
/* Update the scoreboard. */ /* Update the scoreboard. */
cur = TAILQ_FIRST(&tp->snd_holes); cur = TAILQ_FIRST(&tp->snd_holes);
for (i = 0; i < num_sack_blks; i++) { for (i = 0; i < num_sack_blks; i++) {
@ -263,14 +260,12 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
if (TAILQ_EMPTY(&tp->snd_holes)) { if (TAILQ_EMPTY(&tp->snd_holes)) {
/* First hole. */ /* First hole. */
if (tcp_sack_globalholes >= tcp_sack_globalmaxholes) { if (tcp_sack_globalholes >= tcp_sack_globalmaxholes) {
splx(s);
return; return;
} }
cur = (struct sackhole *) cur = (struct sackhole *)
pool_get(&sackhole_pool, PR_NOWAIT); pool_get(&sackhole_pool, PR_NOWAIT);
if (cur == NULL) { if (cur == NULL) {
/* ENOBUFS, bail out*/ /* ENOBUFS, bail out*/
splx(s);
return; return;
} }
cur->start = th->th_ack; cur->start = th->th_ack;
@ -333,14 +328,12 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
tcp_sack_globalmaxholes || tcp_sack_globalmaxholes ||
tp->snd_numholes >= tp->snd_numholes >=
tcp_sack_tp_maxholes) { tcp_sack_tp_maxholes) {
splx(s);
return; return;
} }
tmp = (struct sackhole *) tmp = (struct sackhole *)
pool_get(&sackhole_pool, PR_NOWAIT); pool_get(&sackhole_pool, PR_NOWAIT);
if (tmp == NULL) { if (tmp == NULL) {
/* ENOBUFS, bail out. */ /* ENOBUFS, bail out. */
splx(s);
return; return;
} }
tmp->start = sack->right; tmp->start = sack->right;
@ -366,7 +359,6 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
tcp_sack_globalmaxholes || tcp_sack_globalmaxholes ||
tp->snd_numholes >= tp->snd_numholes >=
tcp_sack_tp_maxholes) { tcp_sack_tp_maxholes) {
splx(s);
return; return;
} }
tmp = (struct sackhole *) tmp = (struct sackhole *)
@ -385,8 +377,6 @@ tcp_sack_option(struct tcpcb *tp, struct tcphdr *th, u_char *cp, int optlen)
tp->rcv_lastsack = sack->right; tp->rcv_lastsack = sack->right;
} }
} }
splx(s);
} }
void void
@ -397,9 +387,6 @@ tcp_del_sackholes(struct tcpcb *tp, struct tcphdr *th)
th->th_ack : tp->snd_una; th->th_ack : tp->snd_una;
struct sackhole *cur = TAILQ_FIRST(&tp->snd_holes); struct sackhole *cur = TAILQ_FIRST(&tp->snd_holes);
struct sackhole *tmp; struct sackhole *tmp;
int s;
s = splsoftnet();
while (cur) { while (cur) {
if (SEQ_LEQ(cur->end, lastack)) { if (SEQ_LEQ(cur->end, lastack)) {
@ -417,17 +404,12 @@ tcp_del_sackholes(struct tcpcb *tp, struct tcphdr *th)
} else } else
break; break;
} }
splx(s);
} }
void void
tcp_free_sackholes(struct tcpcb *tp) tcp_free_sackholes(struct tcpcb *tp)
{ {
struct sackhole *sack; struct sackhole *sack;
int s;
s = splsoftnet();
/* Free up the SACK hole list. */ /* Free up the SACK hole list. */
while (!TAILQ_EMPTY(&tp->snd_holes)) { while (!TAILQ_EMPTY(&tp->snd_holes)) {
@ -438,8 +420,6 @@ tcp_free_sackholes(struct tcpcb *tp)
} }
tp->snd_numholes = 0; tp->snd_numholes = 0;
splx(s);
} }
/* /*