[<prev] [next>] [<thread-prev] [thread-next>] [day] [month] [year] [list]
Message-ID: <20160122123847.GS6357@twins.programming.kicks-ass.net>
Date: Fri, 22 Jan 2016 13:38:47 +0100
From: Peter Zijlstra <peterz@...radead.org>
To: Alexander Shishkin <alexander.shishkin@...ux.intel.com>
Cc: Ingo Molnar <mingo@...hat.com>, linux-kernel@...r.kernel.org,
vince@...ter.net, eranian@...gle.com,
Arnaldo Carvalho de Melo <acme@...radead.org>,
Jiri Olsa <jolsa@...nel.org>, alexei.starovoitov@...il.com
Subject: Re: [PATCH v2] perf: Synchronously cleanup child events
On Fri, Jan 22, 2016 at 01:35:40PM +0200, Alexander Shishkin wrote:
> Peter Zijlstra <peterz@...radead.org> writes:
>
> > So I think there's a number of problems still :-(
>
> Also, it does indeed race with
> __perf_event_exit_task()/sync_child_event(), but that one I'd fix by
> simply wrapping the sync_child_event()/free_event() in
>
> mutex_lock(&parent_event->child_mutex);
> if (!is_orphan_event(parent_event)) {
> sync_child_event(child_event);
> free_event(child_event);
> }
> mutex_unlock(&parent_event->child_event);
Also, note the comment with _perf_event_disable(), that relies on
sync_child_event() taking event->parent->child_mutex.
Powered by blists - more mailing lists