Received: by 10.192.165.148 with SMTP id m20csp543419imm; Fri, 20 Apr 2018 10:54:36 -0700 (PDT) X-Google-Smtp-Source: AIpwx48eHOrhMuK47fxo17nNS/r4AWdE5DIU3uOS4SpOkJ7acdEFH9DpQo5Pk0nT1GSgyxOB5zpC X-Received: by 2002:a17:902:6ecd:: with SMTP id l13-v6mr11370356pln.113.1524246876639; Fri, 20 Apr 2018 10:54:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1524246876; cv=none; d=google.com; s=arc-20160816; b=vcTPxf39412Uv/JwktWn8i+vqF8o0IMnZerlTjRbVwKkAYJKSpmGg8tVuGWY9Am0Kd h/zkNBrlH+6j2KisslP6m4KuKSFFmyXAZV1XxeYpuh+5iyPUk1mkJ0RTzkU8GQRl0mT5 wlOqF+btBKngMc6y/27ZqliIePjgHl2Jmc61rllk5n6aqEKksauFNRt201C8rnRQubXA G4UKgEN/BweVdcCVGJFrug4vKAvT6O2kk+uzYASwfBbsOxkqfusUqQkD3D1bB2JqgEsa AlfdKu9G6nk9oLlJSzy9uwcBABS1w88OK0qHdO/sHzo5sM84376CpAxwXk85/VTHEnkG K0lQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding:mime-version :references:in-reply-to:message-id:subject:cc:to:from:date :dmarc-filter:arc-authentication-results; bh=qeOayj2m+wo0+52mijKOs707fDId1V0jlZvNRi1FgzI=; b=e4SW7HAAiQDMVdCCcevQ9RUq3/M9YuBWlXSseZ8EK+PaxZo93EYfyh549NMliFzYMe lGV9LR6LYGwJQjWULCJ6t1bqT5QzxU54y9xs1Eoo6KoGGxawYfzKcgRyUKjSMsBPHGY5 S4cQS8voWIr5Mwl2ZNe7Vi3ui5kWxvvKlN+HWlE3PgD0WQ0XP8ODt0GHEIzsyGvTGUhu UxJmrAjdx0vwRpK+r6AChx3ZROWwlpluALLDC2zMkZt9PCRwVziMMTr6aiK+2yybBkwJ gRe7H3uzHCrTssm4ZOnMSVDMn6ZySupIZWGTP8ClpPyC2RdbBKVTeM5vu9YEVJUVRWTv wg/A== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n5si5565740pff.370.2018.04.20.10.53.56; Fri, 20 Apr 2018 10:54:36 -0700 (PDT) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753549AbeDTRvA (ORCPT + 99 others); Fri, 20 Apr 2018 13:51:00 -0400 Received: from mail.kernel.org ([198.145.29.99]:40336 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752778AbeDTRu7 (ORCPT ); Fri, 20 Apr 2018 13:50:59 -0400 Received: from gandalf.local.home (cpe-66-24-56-78.stny.res.rr.com [66.24.56.78]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5069420652; Fri, 20 Apr 2018 17:50:58 +0000 (UTC) DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 5069420652 Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=goodmis.org Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=rostedt@goodmis.org Date: Fri, 20 Apr 2018 13:50:56 -0400 From: Steven Rostedt To: Song Liu Cc: , , Ingo Molnar , Howard McLauchlan , Josef Bacik , Srikar Dronamraju , Miklos Szeredi Subject: Re: [PATCH v3 2/2] tracing: remove igrab() iput() call from uprobes.c Message-ID: <20180420135056.31bff483@gandalf.local.home> In-Reply-To: <20180420165625.129593-2-songliubraving@fb.com> References: <20180420165625.129593-1-songliubraving@fb.com> <20180420165625.129593-2-songliubraving@fb.com> X-Mailer: Claws Mail 3.16.0 (GTK+ 2.24.32; x86_64-pc-linux-gnu) MIME-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, 20 Apr 2018 09:56:25 -0700 Song Liu wrote: > Caller of uprobe_register is required to keep the inode and containing > mount point referenced. I would add a little more background to why this is the case. Also a possible link to the conversation? Link: http://lkml.kernel.org/r/CAELBmZB2XX=qEOLAdvGG4cPx4GEntcSnWQquJLUK1ongRj35cA@mail.gmail.com ? -- Steve > > Cc: Steven Rostedt > Cc: Ingo Molnar > Cc: Howard McLauchlan > Cc: Josef Bacik > Cc: Srikar Dronamraju > Cc: Miklos Szeredi > Signed-off-by: Song Liu > --- > kernel/events/uprobes.c | 6 ++---- > 1 file changed, 2 insertions(+), 4 deletions(-) > > diff --git a/kernel/events/uprobes.c b/kernel/events/uprobes.c > index ce6848e..20486bb 100644 > --- a/kernel/events/uprobes.c > +++ b/kernel/events/uprobes.c > @@ -491,7 +491,6 @@ static struct uprobe *alloc_uprobe(struct inode *inode, loff_t offset) > if (!uprobe) > return NULL; > > - uprobe->inode = igrab(inode); > uprobe->offset = offset; > init_rwsem(&uprobe->register_rwsem); > init_rwsem(&uprobe->consumer_rwsem); > @@ -502,7 +501,6 @@ static struct uprobe *alloc_uprobe(struct inode *inode, loff_t offset) > if (cur_uprobe) { > kfree(uprobe); > uprobe = cur_uprobe; > - iput(inode); > } > > return uprobe; > @@ -701,7 +699,6 @@ static void delete_uprobe(struct uprobe *uprobe) > rb_erase(&uprobe->rb_node, &uprobes_tree); > spin_unlock(&uprobes_treelock); > RB_CLEAR_NODE(&uprobe->rb_node); /* for uprobe_is_active() */ > - iput(uprobe->inode); > put_uprobe(uprobe); > } > > @@ -873,7 +870,8 @@ static void __uprobe_unregister(struct uprobe *uprobe, struct uprobe_consumer *u > * tuple). Creation refcount stops uprobe_unregister from freeing the > * @uprobe even before the register operation is complete. Creation > * refcount is released when the last @uc for the @uprobe > - * unregisters. > + * unregisters. Caller of uprobe_register() is required to keep @inode > + * (and the containing mount) referenced. > * > * Return errno if it cannot successully install probes > * else return 0 (success)