From: Joe Perches <joe@perches.com>
To: Kent Overstreet <koverstreet@google.com>
Cc: Tejun Heo <tejun@google.com>,
linux-bcache@vger.kernel.org, linux-kernel@vger.kernel.org,
dm-devel@redhat.com, agk@redhat.com
Subject: Re: [PATCH] Add human-readable units modifier to vsnprintf()
Date: Tue, 22 May 2012 22:42:40 -0700 [thread overview]
Message-ID: <1337751760.13111.47.camel@joe2Laptop> (raw)
In-Reply-To: <20120523052236.GA14312@dhcp-172-18-216-138.mtv.corp.google.com>
On Wed, 2012-05-23 at 01:22 -0400, Kent Overstreet wrote:
> On Tue, May 22, 2012 at 10:10:48PM -0700, Joe Perches wrote:
> > On Wed, 2012-05-23 at 00:50 -0400, Kent Overstreet wrote:
> > > diff --git a/lib/vsprintf.c b/lib/vsprintf.c
> > []
> > > @@ -1002,6 +1023,7 @@ int format_decode(const char *fmt, struct printf_spec *spec)
> > > case ' ': spec->flags |= SPACE; break;
> > > case '#': spec->flags |= SPECIAL; break;
> > > case '0': spec->flags |= ZEROPAD; break;
> > > + case 'h': spec->flags |= HUNITS; break;
> > > default: found = false;
> > > }
> > >
> >
> > I think that doesn't work well because
> > gcc __attribute__((format(printf, x, y)))
> > verification fails.
>
> Yeah, I already ran into that. I was looking through the gcc docs to see
> if there was a way to add modifiers (how is it done for the other kernel
> specific format strings?) but I haven't found anything yet
It's done via %p extensions.
gcc doesn't care as long as the %p argument is a pointer.
> > It's also possible
> > to confuse it with printf's own 'h' /
> > integer precision use.
>
> Well, that's annoying. Any suggestions?
I gave you one already.
Use a new lib/vsprintf.c %p pointer extension like
"%pD" or "%pH" and use a pointer to the type as the
argument.
It's how it's done for an ipv4 address.
For instance:
be32 address = cpu_to_be32(0xc0a80101);
printk("%pI4" &address);
emits "192.168.1.1"
next prev parent reply other threads:[~2012-05-23 5:42 UTC|newest]
Thread overview: 87+ messages / expand[flat|nested] mbox.gz Atom feed top
2012-05-10 3:07 [Bcache v13 00/16] Kent Overstreet
2012-05-10 3:08 ` [Bcache v13 01/16] Only clone bio vecs that are in use Kent Overstreet
2012-05-10 21:35 ` [dm-devel] " Vivek Goyal
2012-05-10 21:42 ` Kent Overstreet
2012-05-11 13:29 ` Jeff Moyer
2012-05-11 20:29 ` Kent Overstreet
2012-05-15 16:19 ` Tejun Heo
2012-05-10 3:08 ` [Bcache v13 02/16] Bio pool freeing Kent Overstreet
2012-05-10 21:32 ` [dm-devel] " Vivek Goyal
2012-05-10 21:39 ` Kent Overstreet
2012-05-10 21:52 ` Vivek Goyal
2012-05-10 21:53 ` Kent Overstreet
2012-05-15 16:24 ` Tejun Heo
2012-05-15 16:25 ` Tejun Heo
2012-05-10 3:08 ` [Bcache v13 03/16] Revert "rw_semaphore: remove up/down_read_non_owner" Kent Overstreet
2012-05-15 16:37 ` Tejun Heo
2012-05-15 16:38 ` Tejun Heo
2012-05-10 3:09 ` [Bcache v13 04/16] Fix ratelimit macro to compile in c99 mode Kent Overstreet
2012-05-15 16:43 ` Tejun Heo
2012-05-10 3:09 ` [Bcache v13 05/16] Export get_random_int() Kent Overstreet
2012-05-15 16:44 ` Tejun Heo
2012-05-10 3:09 ` [Bcache v13 06/16] Export blk_fill_rwbs() Kent Overstreet
2012-05-10 3:09 ` [Bcache v13 07/16] Closures Kent Overstreet
2012-05-15 22:41 ` Tejun Heo
2012-05-18 6:29 ` Kent Overstreet
2012-05-18 10:02 ` Alan Cox
2012-05-21 19:40 ` Kent Overstreet
2012-05-10 3:10 ` [Bcache v13 08/16] bcache: Documentation, and changes to generic code Kent Overstreet
2012-05-10 3:10 ` [Bcache v13 09/16] Bcache: generic utility code Kent Overstreet
2012-05-10 19:35 ` Dan Williams
2012-05-10 21:42 ` Kent Overstreet
2012-05-22 21:17 ` Tejun Heo
2012-05-23 3:12 ` Kent Overstreet
2012-05-23 3:36 ` Joe Perches
2012-05-23 4:50 ` [PATCH] Add human-readable units modifier to vsnprintf() Kent Overstreet
2012-05-23 5:10 ` Joe Perches
2012-05-23 5:22 ` Kent Overstreet
2012-05-23 5:42 ` Joe Perches [this message]
2012-05-23 6:04 ` Kent Overstreet
2012-05-23 6:12 ` Joe Perches
2012-05-23 5:08 ` [Bcache v13 09/16] Bcache: generic utility code Tejun Heo
2012-05-23 5:54 ` Kent Overstreet
2012-05-23 16:51 ` Tejun Heo
2012-05-23 15:15 ` [dm-devel] " Vivek Goyal
2012-05-23 15:33 ` Kent Overstreet
2012-05-22 21:19 ` Tejun Heo
2012-05-10 3:10 ` [Bcache v13 10/16] bcache: Superblock/initialization/sysfs code Kent Overstreet
2012-05-10 3:10 ` [Bcache v13 11/16] bcache: Core btree code Kent Overstreet
2012-05-22 22:12 ` Tejun Heo
2012-05-23 3:45 ` Kent Overstreet
2012-05-23 5:20 ` Tejun Heo
2012-05-23 5:34 ` Kent Overstreet
2012-05-23 17:24 ` Tejun Heo
2012-05-22 22:40 ` Tejun Heo
2012-05-30 7:47 ` Tejun Heo
2012-05-31 1:09 ` Kent Overstreet
2012-05-10 3:11 ` [Bcache v13 12/16] bcache: Bset code (lookups within a btree node) Kent Overstreet
2012-05-22 22:39 ` Tejun Heo
2012-05-23 4:21 ` Kent Overstreet
2012-05-23 17:55 ` Tejun Heo
2012-05-23 20:49 ` Tejun Heo
2012-05-24 18:11 ` Tejun Heo
2012-05-10 3:11 ` [Bcache v13 13/16] bcache: Journalling Kent Overstreet
2012-05-10 3:11 ` [Bcache v13 14/16] bcache: Request, io and allocation code Kent Overstreet
2012-05-22 22:42 ` Tejun Heo
2012-05-23 1:44 ` Kent Overstreet
2012-05-23 4:24 ` Kent Overstreet
2012-05-22 22:44 ` Tejun Heo
2012-05-30 7:23 ` Tejun Heo
2012-05-31 0:52 ` Kent Overstreet
2012-05-31 2:43 ` Tejun Heo
2012-05-31 5:13 ` Kent Overstreet
2012-05-31 6:45 ` Tejun Heo
2012-06-01 2:37 ` Tejun Heo
2012-05-31 2:45 ` Tejun Heo
2012-05-30 7:32 ` Tejun Heo
2012-05-10 3:11 ` [Bcache v13 15/16] bcache: Writeback Kent Overstreet
2012-05-10 3:11 ` [Bcache v13 16/16] bcache: Debug and tracing code Kent Overstreet
2012-05-10 13:54 ` [dm-devel] [Bcache v13 00/16] Vivek Goyal
2012-05-10 15:03 ` Vivek Goyal
2012-05-10 15:34 ` Kent Overstreet
2012-05-10 18:34 ` Dan Williams
[not found] ` <1188908028.170.1336674698865.JavaMail.mail@webmail09>
2012-05-10 18:49 ` [Bcache v13 11/16] bcache: Core btree code Joe Perches
2012-05-10 21:48 ` Kent Overstreet
2012-05-18 10:06 ` [Bcache v13 00/16] Arnd Bergmann
2012-05-30 8:29 ` Tejun Heo
2012-05-30 8:54 ` Zhi Yong Wu
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=1337751760.13111.47.camel@joe2Laptop \
--to=joe@perches.com \
--cc=agk@redhat.com \
--cc=dm-devel@redhat.com \
--cc=koverstreet@google.com \
--cc=linux-bcache@vger.kernel.org \
--cc=linux-kernel@vger.kernel.org \
--cc=tejun@google.com \
/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 a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).