aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/machine.c
diff options
context:
space:
mode:
authorElena Reshetova <elena.reshetova@intel.com>2017-02-21 10:35:02 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2017-03-03 17:07:16 -0500
commite34f5b11cd51fbe723e481c1db03a77260be6f4c (patch)
tree7ff4889208d4221312fd12a756603ed6bd9d35d3 /tools/perf/util/machine.c
parent25a3720cf45779900246ec17e238fbb674ce4e67 (diff)
perf thread: convert thread.refcnt from atomic_t to refcount_t
The refcount_t type and corresponding API should be used instead of atomic_t when the variable is used as a reference counter. This allows to avoid accidental refcounter overflows that might lead to use-after-free situations. Signed-off-by: Elena Reshetova <elena.reshetova@intel.com> Signed-off-by: David Windsor <dwindsor@gmail.com> Signed-off-by: Hans Liljestrand <ishkamiel@gmail.com> Signed-off-by: Kees Kook <keescook@chromium.org> Tested-by: Arnaldo Carvalho de Melo <acme@redhat.com> Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com> Cc: Andrew Morton <akpm@linux-foundation.org> Cc: David Windsor <dwindsor@gmail.com> Cc: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: Hans Liljestrand <ishkamiel@gmail.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Kees Kook <keescook@chromium.org> Cc: Mark Rutland <mark.rutland@arm.com> Cc: Matija Glavinic Pecotic <matija.glavinic-pecotic.ext@nokia.com> Cc: Peter Zijlstra <peterz@infradead.org> Cc: alsa-devel@alsa-project.org Link: http://lkml.kernel.org/r/1487691303-31858-9-git-send-email-elena.reshetova@intel.com [ Did missing conversion in __machine__remove_thread() ] Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/machine.c')
-rw-r--r--tools/perf/util/machine.c2
1 files changed, 1 insertions, 1 deletions
diff --git a/tools/perf/util/machine.c b/tools/perf/util/machine.c
index 71c9720d4973..b9974fe41bc1 100644
--- a/tools/perf/util/machine.c
+++ b/tools/perf/util/machine.c
@@ -1439,7 +1439,7 @@ static void __machine__remove_thread(struct machine *machine, struct thread *th,
1439 if (machine->last_match == th) 1439 if (machine->last_match == th)
1440 machine->last_match = NULL; 1440 machine->last_match = NULL;
1441 1441
1442 BUG_ON(atomic_read(&th->refcnt) == 0); 1442 BUG_ON(refcount_read(&th->refcnt) == 0);
1443 if (lock) 1443 if (lock)
1444 pthread_rwlock_wrlock(&machine->threads_lock); 1444 pthread_rwlock_wrlock(&machine->threads_lock);
1445 rb_erase_init(&th->rb_node, &machine->threads); 1445 rb_erase_init(&th->rb_node, &machine->threads);