On Tue 2020-11-10 15:41:21, Geert Uytterhoeven wrote: > Clarify how to pass the field width for bitmaps, and mention the helper > macros that are available to ease printing cpumask and nodemask. > > Signed-off-by: Geert Uytterhoeven <geert+renesas@xxxxxxxxx> > --- > Documentation/core-api/printk-formats.rst | 4 +++- > 1 file changed, 3 insertions(+), 1 deletion(-) > > diff --git a/Documentation/core-api/printk-formats.rst b/Documentation/core-api/printk-formats.rst > index 6d26c5c6ac485cec..160e710d992f3a36 100644 > --- a/Documentation/core-api/printk-formats.rst > +++ b/Documentation/core-api/printk-formats.rst > @@ -531,7 +531,9 @@ For printing bitmap and its derivatives such as cpumask and nodemask, > %*pb outputs the bitmap with field width as the number of bits and %*pbl > output the bitmap as range list with field width as the number of bits. > > -Passed by reference. > +The field width is passed by value, the bitmap is passed by reference. > +Helper macros cpumask_pr_args() and nodemask_pr_args() are available to ease > +printing cpumask and nodemask. I like it and I would go even further. I have never used these modifiers and was really confused by the entire description. IMHO, it is just an implementation detail that the number of bits is passed via width in struct printf_spec. It is the asterisk '*' that defines that one more argument is needed. And it is up to the documentation to define what the argument is for. The following text shows the idea. I am not a native speaker. I am sure that the working might get improved. <cut> %*pb 0779 %*pbl 0,3-6,8-10 For printing bitmap and its derivatives such as cpumask and nodemask. It takes two arguments, see '*'. The first argument defines the number of bits in the mask. The second argument points to the mask. %*pb outputs the bitmap as a hex number. If the size is bigger than 32-bit then 32-bit values are separated by a comma. %*pbl outputs the bitmap as a range list. The number of bits is passed by value. The mask is passed by reference. Helper macros cpumask_pr_args() and nodemask_pr_args() are available to ease printing cpumask and nodemask. </cut> Best Regards, Petr