sparse_error() sets max_warnings = 0 to silence subsequent sparse_warning()s or info()s; however, this also silences the info() after that sparse_error() and subsequent sparse_errors() which still get shown. bad_expr_type runs into this problem: it reports an error with sparse_error() and then provides further information with info(), which the user never sees. Make info() continue to print as long as the immediately preceeding warning or error does. Thanks to Adam DiCarlo <adam.dicarlo@xxxxxxxxx> for reporting the problem. Signed-off-by: Josh Triplett <josh@xxxxxxxxxxxxxxx> Cc: Adam DiCarlo <adam.dicarlo@xxxxxxxxx> --- lib.c | 13 ++++++++++--- 1 files changed, 10 insertions(+), 3 deletions(-) diff --git a/lib.c b/lib.c index feb755a..05ed848 100644 --- a/lib.c +++ b/lib.c @@ -94,12 +94,13 @@ static void do_warn(const char *type, st } static int max_warnings = 100; +static int show_info = 1; void info(struct position pos, const char * fmt, ...) { va_list args; - if (!max_warnings) + if (!show_info) return; va_start(args, fmt); do_warn("", pos, fmt, args); @@ -110,11 +111,15 @@ void warning(struct position pos, const { va_list args; - if (!max_warnings) + if (!max_warnings) { + show_info = 0; return; + } - if (!--max_warnings) + if (!--max_warnings) { + show_info = 0; fmt = "too many warnings"; + } va_start(args, fmt); do_warn("warning: ", pos, fmt, args); @@ -126,10 +131,12 @@ void sparse_error(struct position pos, c static int errors = 0; va_list args; die_if_error = 1; + show_info = 1; /* Shut up warnings after an error */ max_warnings = 0; if (errors > 100) { static int once = 0; + show_info = 0; if (once) return; fmt = "too many errors"; - To unsubscribe from this list: send the line "unsubscribe linux-sparse" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html