From 137b3f2c46fefd84745c9edc8da31065a8d4f17a Mon Sep 17 00:00:00 2001 From: "Thordur I. Bjornsson" Date: Mon, 10 Sep 2007 23:05:40 +0000 Subject: Remove the ipq locking, it isn't strictly needed right now and is actually wrong in some cases, since we can enter functions without taking the lock because the return value of ipq_lock() isn't checked properly. However, this needs to be revisited when we start calling ip_drain() from the pool code when we are running out of memory, but this isn't done currently. OK art@, henning@ --- sys/netinet/ip_input.c | 45 +-------------------------------------------- 1 file changed, 1 insertion(+), 44 deletions(-) (limited to 'sys') diff --git a/sys/netinet/ip_input.c b/sys/netinet/ip_input.c index 8297a269bdc..22cc242fa8c 100644 --- a/sys/netinet/ip_input.c +++ b/sys/netinet/ip_input.c @@ -1,4 +1,4 @@ -/* $OpenBSD: ip_input.c,v 1.152 2007/09/01 18:49:28 henning Exp $ */ +/* $OpenBSD: ip_input.c,v 1.153 2007/09/10 23:05:39 thib Exp $ */ /* $NetBSD: ip_input.c,v 1.30 1996/03/16 23:53:58 christos Exp $ */ /* @@ -133,42 +133,10 @@ int ipqmaxlen = IFQ_MAXLEN; struct in_ifaddrhead in_ifaddr; struct ifqueue ipintrq; -int ipq_locked; -static __inline int ipq_lock_try(void); -static __inline void ipq_unlock(void); - struct pool ipqent_pool; struct ipstat ipstat; -static __inline int -ipq_lock_try() -{ - int s; - - /* Use splvm() due to mbuf allocation. */ - s = splvm(); - if (ipq_locked) { - splx(s); - return (0); - } - ipq_locked = 1; - splx(s); - return (1); -} - -#define ipq_lock() ipq_lock_try() - -static __inline void -ipq_unlock() -{ - int s; - - s = splvm(); - ipq_locked = 0; - splx(s); -} - char * inet_ntoa(ina) struct in_addr ina; @@ -549,7 +517,6 @@ ours: * Look for queue of fragments * of this datagram. */ - ipq_lock(); LIST_FOREACH(fp, &ipq, ipq_q) if (ip->ip_id == fp->ipq_id && ip->ip_src.s_addr == fp->ipq_src.s_addr && @@ -574,7 +541,6 @@ found: if (ntohs(ip->ip_len) == 0 || (ntohs(ip->ip_len) & 0x7) != 0) { ipstat.ips_badfrags++; - ipq_unlock(); goto bad; } } @@ -590,14 +556,12 @@ found: if (ip_frags + 1 > ip_maxqueue) { ip_flush(); ipstat.ips_rcvmemdrop++; - ipq_unlock(); goto bad; } ipqe = pool_get(&ipqent_pool, PR_NOWAIT); if (ipqe == NULL) { ipstat.ips_rcvmemdrop++; - ipq_unlock(); goto bad; } ip_frags++; @@ -606,7 +570,6 @@ found: ipqe->ipqe_ip = ip; m = ip_reass(ipqe, fp); if (m == 0) { - ipq_unlock(); return; } ipstat.ips_reassembled++; @@ -616,7 +579,6 @@ found: } else if (fp) ip_freef(fp); - ipq_unlock(); } #ifdef IPSEC @@ -953,7 +915,6 @@ ip_slowtimo() struct ipq *fp, *nfp; int s = splsoftnet(); - ipq_lock(); for (fp = LIST_FIRST(&ipq); fp != LIST_END(&ipq); fp = nfp) { nfp = LIST_NEXT(fp, ipq_q); if (--fp->ipq_ttl == 0) { @@ -961,7 +922,6 @@ ip_slowtimo() ip_freef(fp); } } - ipq_unlock(); if (ipforward_rt.ro_rt) { RTFREE(ipforward_rt.ro_rt); ipforward_rt.ro_rt = 0; @@ -976,13 +936,10 @@ void ip_drain() { - if (ipq_lock_try() == 0) - return; while (!LIST_EMPTY(&ipq)) { ipstat.ips_fragdropped++; ip_freef(LIST_FIRST(&ipq)); } - ipq_unlock(); } /* -- cgit v1.2.3