nfnlmsg_*_parse() does not assign *result on error. So this will
lead to freeing a dangling pointer.
Error found by coverity.
Acked-by: Thomas Graf <tgraf@suug.ch>
Signed-off-by: Thomas Haller <thaller@redhat.com>
int err;
if ((err = nfnlmsg_ct_parse(nlh, &ct)) < 0)
- goto errout;
+ return err;
err = pp->pp_cb((struct nl_object *) ct, pp);
-errout:
nfnl_ct_put(ct);
return err;
}
int err;
if ((err = nfnlmsg_exp_parse(nlh, &exp)) < 0)
- goto errout;
+ return err;
err = pp->pp_cb((struct nl_object *) exp, pp);
-errout:
nfnl_exp_put(exp);
return err;
}
int err;
if ((err = nfnlmsg_log_msg_parse(nlh, &msg)) < 0)
- goto errout;
+ return err;
err = pp->pp_cb((struct nl_object *) msg, pp);
-errout:
nfnl_log_msg_put(msg);
return err;
}
int err;
if ((err = nfnlmsg_queue_msg_parse(nlh, &msg)) < 0)
- goto errout;
+ return err;
err = pp->pp_cb((struct nl_object *) msg, pp);
-errout:
nfnl_queue_msg_put(msg);
return err;
}