Re: [PATCH v3 1/2] vsprintf: Add %p[mM]U for uppercase MAC address

From: Konrad Gräfe
Date: Thu May 04 2023 - 09:25:52 EST


On 02.05.23 14:23, Petr Mladek wrote:
On Fri 2023-04-28 08:56:59, Rasmus Villemoes wrote:
On 27/04/2023 13.51, Konrad Gräfe wrote:
The CDC-ECM specification requires an USB gadget to send the host MAC
address as uppercase hex string. This change adds the appropriate
modifier.

Thinking more about it, I'm not sure this is appropriate, not for a
single user like this. vsprintf() should not and cannot satisfy all
possible string formatting requirements for the whole kernel. The %pX
extensions are convenient for use with printk() and friends where one
needs what in other languages would be "string interpolation" (because
then the caller doesn't need to deal with temporary stack buffers and
pass them as %s arguments), but for single items like this, snprintf()
is not necessarily the right tool for the job.

In this case, the caller can just as well call string_upper() on the
result

I tend to agree with Rasmus. string_upper() is a super-easy solution.
One user does not look worth adding all the churn into vsprintf().

Best Regards,
Petr

I do agree as well. That would basically be v1 [1] without the hand-crafted string_upper(). (I didn't know the function.)

Regards,
Konrad

[1]: https://lore.kernel.org/linux-usb/94afd6e0-7300-e8f4-d52e-c21acec04f5b@xxxxxxxxxxx/

Attachment: OpenPGP_signature
Description: OpenPGP digital signature