|
@@ -228,10 +228,10 @@ icmp_error(struct net *net, struct nf_conn *tmpl,
|
|
static int icmp_tuple_to_nlattr(struct sk_buff *skb,
|
|
static int icmp_tuple_to_nlattr(struct sk_buff *skb,
|
|
const struct nf_conntrack_tuple *t)
|
|
const struct nf_conntrack_tuple *t)
|
|
{
|
|
{
|
|
- NLA_PUT_BE16(skb, CTA_PROTO_ICMP_ID, t->src.u.icmp.id);
|
|
|
|
- NLA_PUT_U8(skb, CTA_PROTO_ICMP_TYPE, t->dst.u.icmp.type);
|
|
|
|
- NLA_PUT_U8(skb, CTA_PROTO_ICMP_CODE, t->dst.u.icmp.code);
|
|
|
|
-
|
|
|
|
|
|
+ if (nla_put_be16(skb, CTA_PROTO_ICMP_ID, t->src.u.icmp.id) ||
|
|
|
|
+ nla_put_u8(skb, CTA_PROTO_ICMP_TYPE, t->dst.u.icmp.type) ||
|
|
|
|
+ nla_put_u8(skb, CTA_PROTO_ICMP_CODE, t->dst.u.icmp.code))
|
|
|
|
+ goto nla_put_failure;
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
nla_put_failure:
|
|
nla_put_failure:
|
|
@@ -293,8 +293,8 @@ icmp_timeout_obj_to_nlattr(struct sk_buff *skb, const void *data)
|
|
{
|
|
{
|
|
const unsigned int *timeout = data;
|
|
const unsigned int *timeout = data;
|
|
|
|
|
|
- NLA_PUT_BE32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ));
|
|
|
|
-
|
|
|
|
|
|
+ if (nla_put_be32(skb, CTA_TIMEOUT_ICMP_TIMEOUT, htonl(*timeout / HZ)))
|
|
|
|
+ goto nla_put_failure;
|
|
return 0;
|
|
return 0;
|
|
|
|
|
|
nla_put_failure:
|
|
nla_put_failure:
|