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

kcsan: Support reporting scoped read-write access type

Support generating the string representation of scoped read-write
accesses for completeness. They will become required in planned changes.
Signed-off-by: default avatarMarco Elver <elver@google.com>
Signed-off-by: default avatarPaul E. McKenney <paulmck@kernel.org>
parent 6c65eb75
...@@ -210,10 +210,12 @@ static bool report_matches(const struct expect_report *r) ...@@ -210,10 +210,12 @@ static bool report_matches(const struct expect_report *r)
"read-write" : "read-write" :
"write") : "write") :
"read"); "read");
const bool is_atomic = (ty & KCSAN_ACCESS_ATOMIC);
const bool is_scoped = (ty & KCSAN_ACCESS_SCOPED);
const char *const access_type_aux = const char *const access_type_aux =
(ty & KCSAN_ACCESS_ATOMIC) ? (is_atomic && is_scoped) ? " (marked, scoped)"
" (marked)" : : (is_atomic ? " (marked)"
((ty & KCSAN_ACCESS_SCOPED) ? " (scoped)" : ""); : (is_scoped ? " (scoped)" : ""));
if (i == 1) { if (i == 1) {
/* Access 2 */ /* Access 2 */
......
...@@ -247,6 +247,10 @@ static const char *get_access_type(int type) ...@@ -247,6 +247,10 @@ static const char *get_access_type(int type)
return "write (scoped)"; return "write (scoped)";
case KCSAN_ACCESS_SCOPED | KCSAN_ACCESS_WRITE | KCSAN_ACCESS_ATOMIC: case KCSAN_ACCESS_SCOPED | KCSAN_ACCESS_WRITE | KCSAN_ACCESS_ATOMIC:
return "write (marked, scoped)"; return "write (marked, scoped)";
case KCSAN_ACCESS_SCOPED | KCSAN_ACCESS_COMPOUND | KCSAN_ACCESS_WRITE:
return "read-write (scoped)";
case KCSAN_ACCESS_SCOPED | KCSAN_ACCESS_COMPOUND | KCSAN_ACCESS_WRITE | KCSAN_ACCESS_ATOMIC:
return "read-write (marked, scoped)";
default: default:
BUG(); BUG();
} }
......
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