diff options
author | Rich Fought <rmf.aero@gmail.com> | 2013-01-29 23:10:01 (GMT) |
---|---|---|
committer | Rich Fought <rmf.aero@gmail.com> | 2013-01-29 23:10:01 (GMT) |
commit | 4f088d38aecd86f5377287f8a0ad8534fe441ad9 (patch) | |
tree | 9ee8208d163139f30591d2879f2958196d4b44c3 /lib/netfilter/exp.c | |
parent | 6cc5fdc0e915c76d43055bf58e1e133f6ad2f1c8 (diff) | |
download | libnl-4f088d38aecd86f5377287f8a0ad8534fe441ad9.zip libnl-4f088d38aecd86f5377287f8a0ad8534fe441ad9.tar.gz libnl-4f088d38aecd86f5377287f8a0ad8534fe441ad9.tar.bz2 |
netfilter: correct error in construction of NAT tuple
Diffstat (limited to 'lib/netfilter/exp.c')
-rw-r--r-- | lib/netfilter/exp.c | 8 |
1 files changed, 6 insertions, 2 deletions
diff --git a/lib/netfilter/exp.c b/lib/netfilter/exp.c index a348f99..86ed8d1 100644 --- a/lib/netfilter/exp.c +++ b/lib/netfilter/exp.c @@ -351,7 +351,11 @@ static int nfnl_exp_build_tuple(struct nl_msg *msg, const struct nfnl_exp *exp, int type = exp_get_tuple_attr(cta); - tuple = nla_nest_start(msg, cta); + if (cta == CTA_EXPECT_NAT) + tuple = nla_nest_start(msg, CTA_EXPECT_NAT_TUPLE); + else + tuple = nla_nest_start(msg, cta); + if (!tuple) goto nla_put_failure; @@ -420,7 +424,7 @@ static int nfnl_exp_build_nat(struct nl_msg *msg, const struct nfnl_exp *exp) nfnl_exp_get_nat_dir(exp)); } - if ((err = nfnl_exp_build_tuple(msg, exp, CTA_EXPECT_NAT_TUPLE)) < 0) + if ((err = nfnl_exp_build_tuple(msg, exp, CTA_EXPECT_NAT)) < 0) goto nla_put_failure; nla_nest_end(msg, nat); |