Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/netinet6 Reduce the number of return points of frag6_input
details: https://anonhg.NetBSD.org/src/rev/99e7070ecb37
branches: trunk
changeset: 348808:99e7070ecb37
user: ozaki-r <ozaki-r%NetBSD.org@localhost>
date: Wed Nov 09 03:49:38 2016 +0000
description:
Reduce the number of return points of frag6_input
No functional change.
diffstat:
sys/netinet6/frag6.c | 17 +++++++++--------
1 files changed, 9 insertions(+), 8 deletions(-)
diffs (77 lines):
diff -r 73aa1129e4cf -r 99e7070ecb37 sys/netinet6/frag6.c
--- a/sys/netinet6/frag6.c Wed Nov 09 03:33:30 2016 +0000
+++ b/sys/netinet6/frag6.c Wed Nov 09 03:49:38 2016 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: frag6.c,v 1.56 2014/09/05 05:33:06 matt Exp $ */
+/* $NetBSD: frag6.c,v 1.57 2016/11/09 03:49:38 ozaki-r Exp $ */
/* $KAME: frag6.c,v 1.40 2002/05/27 21:40:31 itojun Exp $ */
/*
@@ -31,7 +31,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: frag6.c,v 1.56 2014/09/05 05:33:06 matt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: frag6.c,v 1.57 2016/11/09 03:49:38 ozaki-r Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -148,7 +148,7 @@
if (ip6->ip6_plen == 0) {
icmp6_error(m, ICMP6_PARAM_PROB, ICMP6_PARAMPROB_HEADER, offset);
in6_ifstat_inc(dstifp, ifs6_reass_fail);
- return IPPROTO_DONE;
+ goto done;
}
/*
@@ -162,7 +162,7 @@
icmp6_error(m, ICMP6_PARAM_PROB, ICMP6_PARAMPROB_HEADER,
offsetof(struct ip6_hdr, ip6_plen));
in6_ifstat_inc(dstifp, ifs6_reass_fail);
- return IPPROTO_DONE;
+ goto done;
}
IP6_STATINC(IP6_STAT_FRAGMENTS);
@@ -267,14 +267,14 @@
icmp6_error(m, ICMP6_PARAM_PROB, ICMP6_PARAMPROB_HEADER,
offset - sizeof(struct ip6_frag) +
offsetof(struct ip6_frag, ip6f_offlg));
- return IPPROTO_DONE;
+ goto done;
}
} else if (fragoff + frgpartlen > IPV6_MAXPACKET) {
mutex_exit(&frag6_lock);
icmp6_error(m, ICMP6_PARAM_PROB, ICMP6_PARAMPROB_HEADER,
offset - sizeof(struct ip6_frag) +
offsetof(struct ip6_frag, ip6f_offlg));
- return IPPROTO_DONE;
+ goto done;
}
/*
* If it's the first fragment, do the above check for each
@@ -382,13 +382,13 @@
af6 = af6->ip6af_down) {
if (af6->ip6af_off != next) {
mutex_exit(&frag6_lock);
- return IPPROTO_DONE;
+ goto done;
}
next += af6->ip6af_frglen;
}
if (af6->ip6af_up->ip6af_mff) {
mutex_exit(&frag6_lock);
- return IPPROTO_DONE;
+ goto done;
}
/*
@@ -479,6 +479,7 @@
in6_ifstat_inc(dstifp, ifs6_reass_fail);
IP6_STATINC(IP6_STAT_FRAGDROPPED);
m_freem(m);
+ done:
return IPPROTO_DONE;
}
Home |
Main Index |
Thread Index |
Old Index