Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1757182AbcDMAjU (ORCPT ); Tue, 12 Apr 2016 20:39:20 -0400 Received: from mail-pa0-f52.google.com ([209.85.220.52]:34795 "EHLO mail-pa0-f52.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752311AbcDMAjT (ORCPT ); Tue, 12 Apr 2016 20:39:19 -0400 Date: Tue, 12 Apr 2016 17:39:14 -0700 From: Andrew Vagin To: Cyrill Gorcunov Cc: Andrey Vagin , linux-kernel@vger.kernel.org, Oleg Nesterov , Andrew Morton , Pavel Emelyanov , Roger Luethi , Arnd Bergmann , Arnaldo Carvalho de Melo , David Ahern , Andy Lutomirski , Pavel Odintsov Subject: Re: [PATCH 04/15] task_diag: add a new interface to get information about tasks (v4) Message-ID: <20160413003913.GB18121@gmail.com> References: <1460417755-18201-1-git-send-email-avagin@openvz.org> <1460417755-18201-5-git-send-email-avagin@openvz.org> <20160412070857.GU2000@uranus.lan> MIME-Version: 1.0 Content-Type: text/plain; charset=koi8-r Content-Disposition: inline In-Reply-To: <20160412070857.GU2000@uranus.lan> User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 846 Lines: 33 On Tue, Apr 12, 2016 at 10:08:57AM +0300, Cyrill Gorcunov wrote: > On Mon, Apr 11, 2016 at 04:35:44PM -0700, Andrey Vagin wrote: > ... > > +static int __taskdiag_dumpit(struct task_iter *iter, > > + struct task_diag_cb *cb, struct task_struct **start) > > +{ > > + struct user_namespace *userns = current_user_ns(); > > + struct task_struct *task = *start; > > + int rc; > > + > > + for (; task; task = iter_next(iter)) { > > + if (!ptrace_may_access(task, PTRACE_MODE_READ_FSCREDS)) > > + continue; > > + > > + rc = task_diag_fill(task, cb->resp, &iter->req, > > + cb, iter->ns, userns); > > + if (rc < 0) { > > + if (rc != -EMSGSIZE) > > + return rc; > > + break; task isn't NULL here > > + } > > + } > > + *start = task; > > task = NULL always here? No, it isn't if the loop is interrupted by break. Thanks, Andrew