From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757409AbbJHMvu (ORCPT ); Thu, 8 Oct 2015 08:51:50 -0400 Received: from mx1.redhat.com ([209.132.183.28]:52642 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1757054AbbJHMvt (ORCPT ); Thu, 8 Oct 2015 08:51:49 -0400 Date: Thu, 8 Oct 2015 14:51:43 +0200 From: Jiri Olsa To: Namhyung Kim Cc: Arnaldo Carvalho de Melo , Ingo Molnar , Peter Zijlstra , LKML , Frederic Weisbecker , Stephane Eranian , David Ahern , Andi Kleen Subject: Re: [RFC/PATCH 17/38] perf tools: Maintain map groups list in a leader thread Message-ID: <20151008125143.GB14829@krava.landal.opennet> References: <1443763159-29098-1-git-send-email-namhyung@kernel.org> <1443763159-29098-18-git-send-email-namhyung@kernel.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1443763159-29098-18-git-send-email-namhyung@kernel.org> User-Agent: Mutt/1.5.23 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Oct 02, 2015 at 02:18:58PM +0900, Namhyung Kim wrote: SNIP > +static int thread__clone_map_groups(struct thread *thread, > + struct thread *parent); > + > int __thread__set_comm(struct thread *thread, const char *str, u64 timestamp, > bool exec) > { > @@ -182,6 +257,40 @@ int __thread__set_comm(struct thread *thread, const char *str, u64 timestamp, > unwind__flush_access(thread); > } > > + if (exec) { > + struct machine *machine; > + > + BUG_ON(thread->mg == NULL || thread->mg->machine == NULL); > + > + machine = thread->mg->machine; > + > + if (thread->tid != thread->pid_) { > + struct map_groups *old = thread->mg; > + struct thread *leader; > + > + leader = machine__findnew_thread(machine, thread->pid_, > + thread->pid_); > + > + /* now it'll be a new leader */ > + thread->pid_ = thread->tid; > + > + thread->mg = map_groups__new(old->machine); > + if (thread->mg == NULL) > + return -ENOMEM; hum, isn't this leaking thread->mg ? should we call map_groups__put(old) at the end of block? jirka