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:
parent
38fb8d4a38
commit
5a0a4d9df3
@ -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);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user