mirror of
https://github.com/adulau/aha.git
synced 2024-12-28 03:36:19 +00:00
nf/dccp: merge errorpaths
Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@helsinki.fi> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
e780f1c33d
commit
79f55f11a0
1 changed files with 9 additions and 7 deletions
|
@ -45,10 +45,8 @@ dccp_find_option(u_int8_t option,
|
||||||
unsigned int optlen = dh->dccph_doff*4 - __dccp_hdr_len(dh);
|
unsigned int optlen = dh->dccph_doff*4 - __dccp_hdr_len(dh);
|
||||||
unsigned int i;
|
unsigned int i;
|
||||||
|
|
||||||
if (dh->dccph_doff * 4 < __dccp_hdr_len(dh)) {
|
if (dh->dccph_doff * 4 < __dccp_hdr_len(dh))
|
||||||
*hotdrop = true;
|
goto invalid;
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!optlen)
|
if (!optlen)
|
||||||
return false;
|
return false;
|
||||||
|
@ -57,9 +55,7 @@ dccp_find_option(u_int8_t option,
|
||||||
op = skb_header_pointer(skb, protoff + optoff, optlen, dccp_optbuf);
|
op = skb_header_pointer(skb, protoff + optoff, optlen, dccp_optbuf);
|
||||||
if (op == NULL) {
|
if (op == NULL) {
|
||||||
/* If we don't have the whole header, drop packet. */
|
/* If we don't have the whole header, drop packet. */
|
||||||
spin_unlock_bh(&dccp_buflock);
|
goto partial;
|
||||||
*hotdrop = true;
|
|
||||||
return false;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for (i = 0; i < optlen; ) {
|
for (i = 0; i < optlen; ) {
|
||||||
|
@ -76,6 +72,12 @@ dccp_find_option(u_int8_t option,
|
||||||
|
|
||||||
spin_unlock_bh(&dccp_buflock);
|
spin_unlock_bh(&dccp_buflock);
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
|
partial:
|
||||||
|
spin_unlock_bh(&dccp_buflock);
|
||||||
|
invalid:
|
||||||
|
*hotdrop = true;
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue