On Tue, 2013-10-29 at 21:33 +0800, Du, Changbin wrote: > This patch add wildcard '*'(matches zero or more characters) and '?' > (matches one character) support when qurying debug flags.
Hi again. Some trivial notes and a possible logic error: > diff --git a/lib/dynamic_debug.c b/lib/dynamic_debug.c [] > @@ -127,6 +127,43 @@ static void vpr_info_dq(const struct ddebug_query > *query, const char *msg) > query->first_lineno, query->last_lineno); > } > > +/* check if the string matches given pattern which includes wildcards */ > +static bool match_pattern(const char *pattern, const char *string) > +{ > + const char *s = string, > + *p = pattern; This sort of alignment is pretty unusual. Most kernel uses just repeat the type like: const char *s = string; const char *p = pattern; > + bool star = 0; bool star = false; > + > + while (*s) { > + switch (*p) { > + case '?': > + ++s, ++p; > + break; > + case '*': > + star = true; > + string = s; > + if (!*++p) > + return true; > + pattern = p;; repeated ; Running your patches through checkpatch should find this sort of defect. > + break; > + default: > + if (*s != *p) { > + if (!star) > + return false; > + string++; > + s = string; > + p = pattern; > + break; > + } > + ++s, ++p; Maybe nicer with an if/else, I think you're still missing a reset of "star = false;" and I also think it's better to use a break here too. if (*s == *p) { s++; p++; star = false; } else { if (!star) return false; string++; s = string; p = pattern; } break; -- 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/