summaryrefslogtreecommitdiff
path: root/tools/include/nolibc
diff options
context:
space:
mode:
authorWilly Tarreau <w@1wt.eu>2022-03-21 20:33:09 +0300
committerPaul E. McKenney <paulmck@kernel.org>2022-04-21 03:05:45 +0300
commitbd845a193aae4b99da5215fcfff0e9014b9f7b96 (patch)
tree9114824f9ec71631f18e8a1292cd02f41b774041 /tools/include/nolibc
parent077d0a392446981cde2e8dd23090140bdd9fb728 (diff)
downloadlinux-bd845a193aae4b99da5215fcfff0e9014b9f7b96.tar.xz
tools/nolibc/stdio: add support for '%p' to vfprintf()
%p remains quite useful in test code, and the code path can easily be merged with the existing "%x" thus only adds ~50 bytes, thus let's add it. Signed-off-by: Willy Tarreau <w@1wt.eu> Signed-off-by: Paul E. McKenney <paulmck@kernel.org>
Diffstat (limited to 'tools/include/nolibc')
-rw-r--r--tools/include/nolibc/stdio.h30
1 files changed, 19 insertions, 11 deletions
diff --git a/tools/include/nolibc/stdio.h b/tools/include/nolibc/stdio.h
index 559ebe052a75..15dedf8d0902 100644
--- a/tools/include/nolibc/stdio.h
+++ b/tools/include/nolibc/stdio.h
@@ -163,7 +163,7 @@ char *fgets(char *s, int size, FILE *stream)
/* minimal vfprintf(). It supports the following formats:
- * - %[l*]{d,u,c,x}
+ * - %[l*]{d,u,c,x,p}
* - %s
* - unknown modifiers are ignored.
*/
@@ -184,8 +184,12 @@ int vfprintf(FILE *stream, const char *fmt, va_list args)
if (escape) {
/* we're in an escape sequence, ofs == 1 */
escape = 0;
- if (c == 'c' || c == 'd' || c == 'u' || c == 'x') {
- if (lpref) {
+ if (c == 'c' || c == 'd' || c == 'u' || c == 'x' || c == 'p') {
+ char *out = tmpbuf;
+
+ if (c == 'p')
+ v = va_arg(args, unsigned long);
+ else if (lpref) {
if (lpref > 1)
v = va_arg(args, unsigned long long);
else
@@ -202,18 +206,22 @@ int vfprintf(FILE *stream, const char *fmt, va_list args)
}
switch (c) {
+ case 'c':
+ out[0] = v;
+ out[1] = 0;
+ break;
case 'd':
- i64toa_r(v, tmpbuf);
+ i64toa_r(v, out);
break;
case 'u':
- u64toa_r(v, tmpbuf);
- break;
- case 'x':
- u64toh_r(v, tmpbuf);
+ u64toa_r(v, out);
break;
- default: /* 'c' */
- tmpbuf[0] = v;
- tmpbuf[1] = 0;
+ case 'p':
+ *(out++) = '0';
+ *(out++) = 'x';
+ /* fall through */
+ default: /* 'x' and 'p' above */
+ u64toh_r(v, out);
break;
}
outstr = tmpbuf;