ip6_reass: Move update ip6_frag.drop stats to nullreturn

The ip6_frag.drop counter is updated before all the code paths calling
goto nullreturn, so let's move updating ip6_frag.drop stats to nullreturn.

Signed-off-by: Axel Lin <axel.lin@ingics.com>
This commit is contained in:
Axel Lin 2017-08-01 18:45:39 +08:00 committed by Dirk Ziegelmeier
parent 5d2be3460f
commit 2781d7abd7

View File

@ -303,7 +303,6 @@ ip6_reass(struct pbuf *p)
hdrdiff += IP6_FRAG_HLEN; hdrdiff += IP6_FRAG_HLEN;
if (hdrdiff > len) { if (hdrdiff > len) {
IP6_FRAG_STATS_INC(ip6_frag.proterr); IP6_FRAG_STATS_INC(ip6_frag.proterr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
len = (u16_t)(len - hdrdiff); len = (u16_t)(len - hdrdiff);
@ -311,7 +310,6 @@ ip6_reass(struct pbuf *p)
if (start > (0xFFFF - len)) { if (start > (0xFFFF - len)) {
/* u16_t overflow, cannot handle this */ /* u16_t overflow, cannot handle this */
IP6_FRAG_STATS_INC(ip6_frag.proterr); IP6_FRAG_STATS_INC(ip6_frag.proterr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
@ -349,7 +347,6 @@ ip6_reass(struct pbuf *p)
#endif /* IP_REASS_FREE_OLDEST */ #endif /* IP_REASS_FREE_OLDEST */
{ {
IP6_FRAG_STATS_INC(ip6_frag.memerr); IP6_FRAG_STATS_INC(ip6_frag.memerr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
} }
@ -404,7 +401,6 @@ ip6_reass(struct pbuf *p)
/* @todo: send ICMPv6 time exceeded here? */ /* @todo: send ICMPv6 time exceeded here? */
/* drop this pbuf */ /* drop this pbuf */
IP6_FRAG_STATS_INC(ip6_frag.memerr); IP6_FRAG_STATS_INC(ip6_frag.memerr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
} }
@ -441,14 +437,12 @@ ip6_reass(struct pbuf *p)
if (end > iprh_tmp->start) { if (end > iprh_tmp->start) {
/* fragment overlaps with following, throw away */ /* fragment overlaps with following, throw away */
IP6_FRAG_STATS_INC(ip6_frag.proterr); IP6_FRAG_STATS_INC(ip6_frag.proterr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
if (iprh_prev != NULL) { if (iprh_prev != NULL) {
if (start < iprh_prev->end) { if (start < iprh_prev->end) {
/* fragment overlaps with previous, throw away */ /* fragment overlaps with previous, throw away */
IP6_FRAG_STATS_INC(ip6_frag.proterr); IP6_FRAG_STATS_INC(ip6_frag.proterr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
} }
} }
@ -465,13 +459,11 @@ ip6_reass(struct pbuf *p)
break; break;
} else if (start == iprh_tmp->start) { } else if (start == iprh_tmp->start) {
/* received the same datagram twice: no need to keep the datagram */ /* received the same datagram twice: no need to keep the datagram */
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
#if IP_REASS_CHECK_OVERLAP #if IP_REASS_CHECK_OVERLAP
} else if (start < iprh_tmp->end) { } else if (start < iprh_tmp->end) {
/* overlap: no need to keep the new datagram */ /* overlap: no need to keep the new datagram */
IP6_FRAG_STATS_INC(ip6_frag.proterr); IP6_FRAG_STATS_INC(ip6_frag.proterr);
IP6_FRAG_STATS_INC(ip6_frag.drop);
goto nullreturn; goto nullreturn;
#endif /* IP_REASS_CHECK_OVERLAP */ #endif /* IP_REASS_CHECK_OVERLAP */
} else { } else {
@ -672,6 +664,7 @@ ip6_reass(struct pbuf *p)
return NULL; return NULL;
nullreturn: nullreturn:
IP6_FRAG_STATS_INC(ip6_frag.drop);
pbuf_free(p); pbuf_free(p);
return NULL; return NULL;
} }