From: Pablo Neira Ayuso Date: Thu, 23 Oct 2014 11:30:36 +0000 (+0200) Subject: iptables-compat: fix empty chains after first invocation of iptables-compat -L X-Git-Tag: v1.6.0~64 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=a4e78370af8498e2de65fcb8aafed39a4482966c;p=thirdparty%2Fiptables.git iptables-compat: fix empty chains after first invocation of iptables-compat -L # iptables-compat -L # iptables-compat -L Chain INPUT (policy ACCEPT) target prot opt source destination Chain FORWARD (policy ACCEPT) target prot opt source destination Chain OUTPUT (policy ACCEPT) target prot opt source destination Note that the second (and follow up) invocations after the first one display the chains. Signed-off-by: Pablo Neira Ayuso --- diff --git a/iptables/nft.c b/iptables/nft.c index 52c89b94..5492a8fd 100644 --- a/iptables/nft.c +++ b/iptables/nft.c @@ -1937,8 +1937,14 @@ int nft_rule_list(struct nft_handle *h, const char *chain, const char *table, bool found = false; /* If built-in chains don't exist for this table, create them */ - if (nft_xtables_config_load(h, XTABLES_CONFIG_DEFAULT, 0) < 0) + if (nft_xtables_config_load(h, XTABLES_CONFIG_DEFAULT, 0) < 0) { nft_xt_builtin_init(h, table); + /* Force table and chain creation, otherwise first iptables -L + * lists no table/chains. + */ + if (!list_empty(&h->obj_list)) + nft_commit(h); + } ops = nft_family_ops_lookup(h->family);