netfilter-devel.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: Pablo Neira Ayuso <pablo@netfilter.org>
To: Eric Leblond <eric@regit.org>
Cc: netfilter-devel@vger.kernel.org, Florian Westphal <fw@strlen.de>
Subject: Re: [PATCH nft v2 00/18] introducing libnftables
Date: Tue, 22 Aug 2017 19:30:14 +0200	[thread overview]
Message-ID: <20170822173014.GA18045@salvia> (raw)
In-Reply-To: <1503351765.9868.15.camel@regit.org>

On Mon, Aug 21, 2017 at 11:42:45PM +0200, Eric Leblond wrote:
[...]
> I see possible issues. Let's take for instance latest work by Florian
> on tcpmss. It is add new call to printf so this would be something to
> rework. And experience in redoing the work I already done for this
> patchset is that it can be really painful.

That's why I'm asking you please send incremental preparation patches
that we can quickly upstream, so everyone keeps flying fast... we
reduce chances of clashes/time wasted in rebases...

Or at least, if you're getting very upset with me :), then just help us
identify what needs to be fixed, as you did with the max_errors thing -
a major problem in my opinion, because it cripples multi-error
reporting...

Regarding API, my conclusion is:

* Let's get rid of the nft_init()/nft_deinit() functions and place
  this code in the nft context structure.

* Split scanner + parser + evaluation from netlink IO. Of course, you
  can provide a composite function that does it all as we agreed, for
  people that just want to save the fork()+exec().

You also mentioned a problem/open issue with sets that I still don't
understand.

There's also monitor mode that we need to integrate, or at least,
agree on how this is exposed.

There's a few more globals we can remove:

nftables$ git grep "^static.*;"
src/cli.c:static struct parser_state *state;
src/cli.c:static struct nft_ctx *cli_nft;
src/cli.c:static struct mnl_socket *cli_nf_sock;
src/cli.c:static void *scanner;
src/cli.c:static char histfile[PATH_MAX];
src/cli.c:static char *multiline;
src/cli.c:static bool eof;
src/ct.c:static struct symbol_table *ct_label_tbl;
src/datatype.c:static struct symbol_table *mark_tbl;
src/evaluate.c:static struct output_ctx octx_debug_dummy;
src/evaluate.c:static int expr_evaluate(struct eval_ctx *ctx, struct expr **expr);
src/iface.c:static LIST_HEAD(iface_list);
src/iface.c:static bool iface_cache_init;
src/main.c:static struct nft_ctx nft;
src/mergesort.c:static int expr_msort_cmp(const struct expr *e1, const struct expr *e2);
src/meta.c:static struct symbol_table *realm_tbl;
src/meta.c:static struct symbol_table *devgroup_tbl;
src/mini-gmp.c:static void * (*gmp_allocate_func) (size_t) = gmp_default_alloc;
src/mini-gmp.c:static void * (*gmp_reallocate_func) (void *, size_t, size_t) = gmp_default_realloc;
src/mini-gmp.c:static void (*gmp_free_func) (void *, size_t) = gmp_default_free;
src/mnl.c:static uint16_t nft_genid;
src/mnl.c:static int nlbuffsiz;
src/netlink_delinearize.c:static void expr_postprocess(struct rule_pp_ctx *ctx, struct expr **exprp);
src/rt.c:static struct symbol_table *realm_tbl;
src/rule.c:static uint32_t set_id;
src/scanner.l:static void scanner_pop_buffer(yyscan_t scanner);
src/segtree.c:static struct output_ctx debug_octx = {};

Library would also exit in case of OOM, probably we can change that so
the client deals with this errors. But this could be done later on, OK.

Anything else? :-)

  reply	other threads:[~2017-08-22 17:30 UTC|newest]

Thread overview: 56+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2017-08-19 15:24 [PATCH nft v2 00/18] introducing libnftables Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 01/18] mnl: fix error handling in mnl_batch_talk Eric Leblond
2017-08-21  8:10   ` Pablo Neira Ayuso
2017-08-21 19:01     ` Eric Leblond
2017-08-24 15:13       ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 02/18] erec: add function to free list Eric Leblond
2017-08-21  8:12   ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 03/18] libnftables: introduce library Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 04/18] libnftables: add context new and free Eric Leblond
2017-08-21  8:17   ` Pablo Neira Ayuso
2017-08-24 15:30   ` Pablo Neira Ayuso
2017-08-25 11:22     ` Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 05/18] libnftables: add nft_run_command_from_buffer Eric Leblond
2017-08-21  8:23   ` Pablo Neira Ayuso
2017-08-21  8:45     ` Pablo Neira Ayuso
2017-08-21  9:06       ` Eric Leblond
2017-08-21  9:44         ` Pablo Neira Ayuso
2017-08-21 19:21           ` Eric Leblond
2017-08-22 12:37             ` Pablo Neira Ayuso
2017-08-25 11:16               ` Eric Leblond
2017-08-24 15:49   ` Pablo Neira Ayuso
2017-08-25 11:26     ` Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 06/18] libnftables: add nft_run_command_from_filename Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 07/18] libnftables: put nft_run in library Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 08/18] libnftables: add missing variables to library Eric Leblond
2017-08-21  8:27   ` Pablo Neira Ayuso
2017-08-21 19:04     ` Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 09/18] libnftables: add NFT_EXIT_* " Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 10/18] libnftables: add a nft_cache to nft_ctx Eric Leblond
2017-08-21  8:32   ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 11/18] libnftables: move iface_cache_release to deinit Eric Leblond
2017-08-21  8:33   ` Pablo Neira Ayuso
2017-08-24 15:55   ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 12/18] libnftables: get rid of printf Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 13/18] libnftables: add nft_context_set_print Eric Leblond
2017-08-25  9:59   ` Pablo Neira Ayuso
2017-08-25 11:49     ` Eric Leblond
2017-08-30 10:46       ` Pablo Neira Ayuso
2017-08-31 10:09         ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 14/18] libnftables: transaction support Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 15/18] libnftables: set max_errors to 1 in library Eric Leblond
2017-08-21  8:37   ` Pablo Neira Ayuso
2017-08-21 19:12     ` Eric Leblond
2017-08-22 15:04       ` Phil Sutter
2017-08-24 16:02       ` Pablo Neira Ayuso
2017-08-25 11:37         ` Eric Leblond
2017-08-28 15:18           ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 16/18] libnftables: add error handling Eric Leblond
2017-08-19 15:24 ` [PATH nft v2 17/18] libnftables: suppress unused global variables Eric Leblond
2017-08-21  8:40   ` Pablo Neira Ayuso
2017-08-19 15:24 ` [PATH nft v2 18/18] libnftables: doxygen documentation Eric Leblond
2017-08-21  8:55 ` [PATCH nft v2 00/18] introducing libnftables Pablo Neira Ayuso
2017-08-21 21:42   ` Eric Leblond
2017-08-22 17:30     ` Pablo Neira Ayuso [this message]
2017-08-30 10:31 ` Phil Sutter
2017-08-31 10:19   ` Pablo Neira Ayuso

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=20170822173014.GA18045@salvia \
    --to=pablo@netfilter.org \
    --cc=eric@regit.org \
    --cc=fw@strlen.de \
    --cc=netfilter-devel@vger.kernel.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).