Commit f770ed10 authored by Marco Elver's avatar Marco Elver Committed by Paul E. McKenney

kcsan: Fix function matching in report

Pass string length as returned by scnprintf() to strnstr(), since
strnstr() searches exactly len bytes in haystack, even if it contains a
NUL-terminator before haystack+len.
Signed-off-by: default avatarMarco Elver <elver@google.com>
Signed-off-by: default avatarPaul E. McKenney <paulmck@kernel.org>
parent d071e913
...@@ -192,11 +192,11 @@ skip_report(enum kcsan_value_change value_change, unsigned long top_frame) ...@@ -192,11 +192,11 @@ skip_report(enum kcsan_value_change value_change, unsigned long top_frame)
* maintainers. * maintainers.
*/ */
char buf[64]; char buf[64];
int len = scnprintf(buf, sizeof(buf), "%ps", (void *)top_frame);
snprintf(buf, sizeof(buf), "%ps", (void *)top_frame); if (!strnstr(buf, "rcu_", len) &&
if (!strnstr(buf, "rcu_", sizeof(buf)) && !strnstr(buf, "_rcu", len) &&
!strnstr(buf, "_rcu", sizeof(buf)) && !strnstr(buf, "_srcu", len))
!strnstr(buf, "_srcu", sizeof(buf)))
return true; return true;
} }
...@@ -262,15 +262,15 @@ static const char *get_thread_desc(int task_id) ...@@ -262,15 +262,15 @@ static const char *get_thread_desc(int task_id)
static int get_stack_skipnr(const unsigned long stack_entries[], int num_entries) static int get_stack_skipnr(const unsigned long stack_entries[], int num_entries)
{ {
char buf[64]; char buf[64];
int len;
int skip = 0; int skip = 0;
for (; skip < num_entries; ++skip) { for (; skip < num_entries; ++skip) {
snprintf(buf, sizeof(buf), "%ps", (void *)stack_entries[skip]); len = scnprintf(buf, sizeof(buf), "%ps", (void *)stack_entries[skip]);
if (!strnstr(buf, "csan_", sizeof(buf)) && if (!strnstr(buf, "csan_", len) &&
!strnstr(buf, "tsan_", sizeof(buf)) && !strnstr(buf, "tsan_", len) &&
!strnstr(buf, "_once_size", sizeof(buf))) { !strnstr(buf, "_once_size", len))
break; break;
}
} }
return skip; return skip;
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment