diff options
author | Pablo Neira Ayuso <pablo@netfilter.org> | 2008-08-07 14:53:29 +0200 |
---|---|---|
committer | Pablo Neira Ayuso <pablo@netfilter.org> | 2008-08-07 14:53:29 +0200 |
commit | 8a78dda3e6676286f09f5c78cca60a8178186930 (patch) | |
tree | 8b00a9b242e137c1233579bbe500ae123fd65191 /src/netlink.c | |
parent | 6cb33c62c8007593d8a85aa202fa173043877135 (diff) | |
download | conntrack-tools-8a78dda3e6676286f09f5c78cca60a8178186930.tar.gz conntrack-tools-8a78dda3e6676286f09f5c78cca60a8178186930.zip |
cache iterators: commit master entries before related ones
Commit master entries before related ones to avoid ENOENT errors.
Signed-off-by: Pablo Neira Ayuso <pablo@netfilter.org>
Diffstat (limited to 'src/netlink.c')
-rw-r--r-- | src/netlink.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/src/netlink.c b/src/netlink.c index 0d9b7db..e9b1cfd 100644 --- a/src/netlink.c +++ b/src/netlink.c @@ -337,6 +337,18 @@ int nl_update_conntrack(struct nf_conntrack *ct) nfct_set_attr_u32(ct, ATTR_STATUS, status); } + /* we hit error if we try to update the master conntrack */ + if (ct_is_related(ct)) { + nfct_attr_unset(ct, ATTR_MASTER_L3PROTO); + nfct_attr_unset(ct, ATTR_MASTER_L4PROTO); + nfct_attr_unset(ct, ATTR_MASTER_IPV4_SRC); + nfct_attr_unset(ct, ATTR_MASTER_IPV4_DST); + nfct_attr_unset(ct, ATTR_MASTER_IPV6_SRC); + nfct_attr_unset(ct, ATTR_MASTER_IPV6_DST); + nfct_attr_unset(ct, ATTR_MASTER_PORT_SRC); + nfct_attr_unset(ct, ATTR_MASTER_PORT_DST); + } + return nl_create_conntrack(ct); } |