Hi David, On Wed, Dec 17, 2014 at 01:29:08PM -0700, David Ahern wrote: > Adds helper for following kernel formats: > %pi4 print an IPv4 address with leading zeros > %pI4 print an IPv4 address without leading zeros > %pi6 print an IPv6 address without colons > %pI6 print an IPv6 address with colons > %pI6c print an IPv6 address with colons > %pISpc print an IP address from a sockaddr > > Allows these formats to be used in tracepoints. > > Quite a bit of this is adapted from code in lib/vsprintf.c. > > Signed-off-by: David Ahern <dsah...@gmail.com> > Cc: Namhyung Kim <namhy...@kernel.org> > Cc: Jiri Olsa <jo...@kernel.org> > Cc: Steven Rostedt <rost...@goodmis.org> > ---
[SNIP] > +static int print_ip_arg(struct trace_seq *s, const char *ptr, > + void *data, int size, struct event_format *event, > + struct print_arg *arg) > +{ > + char i = *(ptr + 1); /* 'i' or 'I' */ It'd be better if we do it like below.. char i = *ptr++; Why not passing ptr + 1 to print_ip_arg()? > + char ver; > + int rc = 0; > + > + ptr++; > + rc++; > + > + ver = *(ptr + 1); Ditto. > + ptr++; > + rc++; > + > + switch (ver) { > + case '4': > + rc += print_ipv4_arg(s, ptr, i, data, size, event, arg); > + break; > + case '6': > + rc += print_ipv6_arg(s, ptr, i, data, size, event, arg); > + break; > + case 'S': > + rc += print_ipsa_arg(s, ptr, i, data, size, event, arg); > + break; > + default: > + return 0; > + } > + > + return rc; > +} > + > static int is_printable_array(char *p, unsigned int len) > { > unsigned int i; > @@ -4337,6 +4644,15 @@ static void pretty_print(struct trace_seq *s, void > *data, int size, struct event > ptr++; > arg = arg->next; > break; > + } else if (*(ptr+1) == 'I' || *(ptr+1) == 'i') { > + int n; > + > + n = print_ip_arg(s, ptr, data, size, > event, arg); Here.. Thanks, Namhyung > + if (n > 0) { > + ptr += n; > + arg = arg->next; > + break; > + } > } > > /* fall through */ > -- > 1.9.3 (Apple Git-50) > > -- > To unsubscribe from this list: send the line "unsubscribe linux-kernel" in > the body of a message to majord...@vger.kernel.org > More majordomo info at http://vger.kernel.org/majordomo-info.html > Please read the FAQ at http://www.tux.org/lkml/ -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majord...@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/