[PATCH] tiny-printf: Add support for upper case hex values

Marek Vasut marex at denx.de
Thu Mar 20 15:14:03 CET 2025


On 3/20/25 3:00 PM, Quentin Schulz wrote:
> Hi Marek,
> 
> On 3/20/25 12:49 PM, Marek Vasut wrote:
>> On 3/20/25 11:23 AM, Christoph Niedermaier wrote:
>>> If tiny printf is used with 0x%08X (upper case X) the output is
>>> always 0x00000000. It could be confusing if upper case instead
>>> of lower case is used intentionally or accidentally because the
>>> actual value is not output. To avoid this confusion, tiny printf
>>> is extended to support also the formatting with %X.
>>>
>>> Signed-off-by: Christoph Niedermaier <cniedermaier at dh-electronics.com>
>> TINY_PRINTF is meant to be tiny, i.e. not consume a lot of space, at 
>> the expense of functionality. This is meant to be used in size 
>> constrained environments, like the SPL. If you need full vsprintf() 
>> formatting support, disable TINY_PRINTF in your config and use the 
>> regular vsprintf() implementation.
> 
> The issue is that disabling TINY_PRINTF may not be possible (size 
> constraints) and some code is compiled for different stages and people 
> typically don't check whether the format used in printf is valid with 
> tiny_printf. I've had this issue already in the past, I vaguely recall 
> "complaining" about it on IRC.
> 
> Maybe there's something we can do to verify that the code is working how 
> we expect it to work, regardless of tiny_printf/full printf selection? 
> checkpatch or a compile-time check for the formats maybe?
> 
> But yeah, essentially the whole thing is... if we continue like this, 
> we'll just end up getting closer and closer to the full printf which is 
> not something we want :)
Shall we maybe patch tiny printf to print '?' on unsupported formatting 
characters, or outright complain that users should fix their code ?

For the %x/%X thing, we could technically fall back from %X to %x , 
which would do the printing with minimum footprint increase, albeit 
slightly malformed:

diff --git a/lib/tiny-printf.c b/lib/tiny-printf.c
index 0503c17341f..48db7b1f78f 100644
--- a/lib/tiny-printf.c
+++ b/lib/tiny-printf.c
@@ -284,6 +284,7 @@ static int _vprintf(struct printf_info *info, const 
char *fmt, va_list va)
                                 islong = true;
                                 /* no break */
                         case 'x':
+                       case 'X':
                                 if (islong) {
                                         num = va_arg(va, unsigned long);
                                         div = 1UL << (sizeof(long) * 8 
- 4);



More information about the U-Boot mailing list