From e4118bb67dee6b4064d196cbe6e1c83cb7d1d586 Mon Sep 17 00:00:00 2001 From: dzwdz Date: Wed, 19 Oct 2022 15:17:36 +0200 Subject: shared/printf: implement %p --- src/shared/printf.c | 28 +++++++++++++++++++--------- 1 file changed, 19 insertions(+), 9 deletions(-) (limited to 'src/shared') diff --git a/src/shared/printf.c b/src/shared/printf.c index a9cd355..5134048 100644 --- a/src/shared/printf.c +++ b/src/shared/printf.c @@ -2,6 +2,7 @@ #include #include #include +#include enum lenmod { LM_int, @@ -82,6 +83,18 @@ static void output_uint(struct out_state *os, struct mods *m, unsigned long long output(os, buf + pos, len); } +static void output_uint16(struct out_state *os, struct mods *m, unsigned long long n) { + size_t len = 1; + while (n >> (len * 4) && (len * 4) < (sizeof(n) * 8)) + len++; + padnum(os, m, len, '\0'); + while (len-- > 0) { + char h = '0' + ((n >> (len * 4)) & 0xf); + if (h > '9') h += 'a' - '9' - 1; + output_c(os, h, 1); + } +} + int __printf_internal(const char *fmt, va_list argp, void (*back)(void*, const char*, size_t), void *backarg) @@ -176,19 +189,16 @@ int __printf_internal(const char *fmt, va_list argp, output(&os, s, len); break; + case 'p': + output(&os, "0x", 2); + output_uint16(&os, &m, (uintptr_t)va_arg(argp, void*)); + break; + case 'x': if (lm == LM_int) n = va_arg(argp, unsigned int); else if (lm == LM_long) n = va_arg(argp, unsigned long); else if (lm == LM_longlong) n = va_arg(argp, unsigned long long); - len = 1; - while (n >> (len * 4) && (len * 4) < (sizeof(n) * 8)) - len++; - padnum(&os, &m, len, '\0'); - while (len-- > 0) { - char h = '0' + ((n >> (len * 4)) & 0xf); - if (h > '9') h += 'a' - '9' - 1; - output_c(&os, h, 1); - } + output_uint16(&os, &m, n); break; case 'u': -- cgit v1.2.3