Commit 87654cf7 authored by linke li's avatar linke li Committed by Vlastimil Babka

mm/slub: mark racy accesses on slab->slabs

The reads of slab->slabs are racy because it may be changed by
put_cpu_partial concurrently. In slabs_cpu_partial_show() and
show_slab_objects(), slab->slabs is only used for showing information.

Data-racy reads from shared variables that are used only for diagnostic
purposes should typically use data_race(), since it is normally not a
problem if the values are off by a little.

This patch is aimed at reducing the number of benign races reported by
KCSAN in order to focus future debugging effort on harmful races.
Signed-off-by: default avatarlinke li <lilinke99@qq.com>
Reviewed-by: default avatarChengming Zhou <chengming.zhou@linux.dev>
Signed-off-by: default avatarVlastimil Babka <vbabka@suse.cz>
parent ad7c5ebe
...@@ -6036,7 +6036,7 @@ static ssize_t show_slab_objects(struct kmem_cache *s, ...@@ -6036,7 +6036,7 @@ static ssize_t show_slab_objects(struct kmem_cache *s,
else if (flags & SO_OBJECTS) else if (flags & SO_OBJECTS)
WARN_ON_ONCE(1); WARN_ON_ONCE(1);
else else
x = slab->slabs; x = data_race(slab->slabs);
total += x; total += x;
nodes[node] += x; nodes[node] += x;
} }
...@@ -6241,7 +6241,7 @@ static ssize_t slabs_cpu_partial_show(struct kmem_cache *s, char *buf) ...@@ -6241,7 +6241,7 @@ static ssize_t slabs_cpu_partial_show(struct kmem_cache *s, char *buf)
slab = slub_percpu_partial(per_cpu_ptr(s->cpu_slab, cpu)); slab = slub_percpu_partial(per_cpu_ptr(s->cpu_slab, cpu));
if (slab) if (slab)
slabs += slab->slabs; slabs += data_race(slab->slabs);
} }
#endif #endif
...@@ -6255,7 +6255,7 @@ static ssize_t slabs_cpu_partial_show(struct kmem_cache *s, char *buf) ...@@ -6255,7 +6255,7 @@ static ssize_t slabs_cpu_partial_show(struct kmem_cache *s, char *buf)
slab = slub_percpu_partial(per_cpu_ptr(s->cpu_slab, cpu)); slab = slub_percpu_partial(per_cpu_ptr(s->cpu_slab, cpu));
if (slab) { if (slab) {
slabs = READ_ONCE(slab->slabs); slabs = data_race(slab->slabs);
objects = (slabs * oo_objects(s->oo)) / 2; objects = (slabs * oo_objects(s->oo)) / 2;
len += sysfs_emit_at(buf, len, " C%d=%d(%d)", len += sysfs_emit_at(buf, len, " C%d=%d(%d)",
cpu, objects, slabs); cpu, objects, slabs);
......
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