From: Petr Machata <petrm@nvidia.com>
To: David Ahern <dsahern@gmail.com>
Cc: Petr Machata <me@pmachata.org>, Jiri Pirko <jiri@resnulli.us>,
<netdev@vger.kernel.org>, <stephen@networkplumber.org>,
<daniel.machon@microchip.com>
Subject: Re: [patch iproute2-next v3 3/6] devlink: extend pr_out_nested_handle() to print object
Date: Mon, 30 Oct 2023 12:03:57 +0100 [thread overview]
Message-ID: <871qdc5mcj.fsf@nvidia.com> (raw)
In-Reply-To: <a9b610e6-b0ce-46b6-89ea-faef78c5a4f2@gmail.com>
David Ahern <dsahern@gmail.com> writes:
> On 10/27/23 7:12 AM, Petr Machata wrote:
>> I was wondering whether somehing like this might make sense in the
>> iproute2 library:
>>
>> #define alloca_sprintf(FMT, ...) ({ \
>> int xasprintf_n = snprintf(NULL, 0, (FMT), __VA_ARGS__); \
>> char *xasprintf_buf = alloca(xasprintf_n); \
>> sprintf(xasprintf_buf, (FMT), __VA_ARGS__); \
>> xasprintf_buf; \
>> })
>>
>> void foo() {
>> const char *buf = alloca_sprintf("%x %y %z", etc.);
>> printf(... buf ...);
>> }
>>
>> I'm not really happy with it -- because of alloca vs. array, and because
>> of the double evaluation. But all those SPRINT_BUF's peppered everywhere
>> make me uneasy every time I read or write them.
>
> agreed.
>
>>
>> Or maybe roll something custom asprintf-like that can reuse and/or
>> realloc a passed-in buffer?
>>
>> The sprintf story is pretty bad in iproute2 right now, IMHO.
>
> It is a bit of a mess. If you have a few cycles, want to send an RFC?
> Just pick 1 or 2 to convert to show intent with a new design.
I picked at it a bit over the weekend, but came up with nothing that I
find comfortable proposing. The static buffer approach has some major
advantages: nothing ever fails and nothing ever needs cleanups. This
keeps the client code tidy and compact. Anything dynamic adds points of
failure and cleanups, which in C means more client-side boilerplate.
Anyway, I'll pick at it some more and see I find anything.
next prev parent reply other threads:[~2023-10-30 12:25 UTC|newest]
Thread overview: 16+ messages / expand[flat|nested] mbox.gz Atom feed top
2023-10-24 10:03 [patch iproute2-next v3 0/6] expose devlink instances relationships Jiri Pirko
2023-10-24 10:03 ` [patch iproute2-next v3 1/6] ip/ipnetns: move internals of get_netnsid_from_name() into namespace.c Jiri Pirko
2023-10-26 16:56 ` David Ahern
2023-10-27 8:25 ` Jiri Pirko
2023-10-24 10:03 ` [patch iproute2-next v3 2/6] devlink: do conditional new line print in pr_out_port_handle_end() Jiri Pirko
2023-10-24 10:04 ` [patch iproute2-next v3 3/6] devlink: extend pr_out_nested_handle() to print object Jiri Pirko
2023-10-26 17:03 ` David Ahern
2023-10-27 8:26 ` Jiri Pirko
2023-10-27 13:12 ` Petr Machata
2023-10-27 17:16 ` David Ahern
2023-10-30 11:03 ` Petr Machata [this message]
2023-10-24 10:04 ` [patch iproute2-next v3 4/6] devlink: introduce support for netns id for nested handle Jiri Pirko
2023-10-26 17:08 ` David Ahern
2023-10-27 8:29 ` Jiri Pirko
2023-10-24 10:04 ` [patch iproute2-next v3 5/6] devlink: print nested handle for port function Jiri Pirko
2023-10-24 10:04 ` [patch iproute2-next v3 6/6] devlink: print nested devlink handle for devlink dev Jiri Pirko
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=871qdc5mcj.fsf@nvidia.com \
--to=petrm@nvidia.com \
--cc=daniel.machon@microchip.com \
--cc=dsahern@gmail.com \
--cc=jiri@resnulli.us \
--cc=me@pmachata.org \
--cc=netdev@vger.kernel.org \
--cc=stephen@networkplumber.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 an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.