Received: by 2002:a05:6a10:f3d0:0:0:0:0 with SMTP id a16csp849307pxv; Thu, 1 Jul 2021 10:36:14 -0700 (PDT) X-Google-Smtp-Source: ABdhPJyqEjsYJSuvrbOY038whsyMeUBux3Ak3RPrsNJObOZYBOZbV1VjryyQU7k9D6/Q9Hv2Y6z0 X-Received: by 2002:a17:907:1c84:: with SMTP id nb4mr1087615ejc.125.1625160974586; Thu, 01 Jul 2021 10:36:14 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1625160974; cv=none; d=google.com; s=arc-20160816; b=iXpt8BEjJMlAV9NmHpb26nWBKXMwsEs9DGQmv7i4Xk8z4U5TqL3o6NJxuh0FSoCPXE qP60HVzv2yWC72FUBx+Ka+iDr6D0vuGgegmx78zrYeaCSLYCBduljaA2gtEaDm0y9kfM ijob94ijrXLx+HbZ0gqOnMF0YPkswpuMQ0lC/5WL1CoUGBsX3ycKq1IW7Wz+fGQW476S Xh4M+ECUr2f+AccGlLtE9lnD9bmBbY0Fz+k40el8Nliic37zGK7NhbXk6PnoB0xv1RSe nynIAdPOY8RFZ48/UuIo5KQ3N9lQ/mJxE1lVxXqeh2pc462jSqxaLsCx5mnExsTBX8To NnbA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:in-reply-to:content-disposition:mime-version :references:message-id:subject:cc:to:from:date:dkim-signature; bh=BbJUiUUe8T9b2PK6TM2EJq7HBKzquI9DW1+aUliaiPo=; b=tLyXbhGTsZ6Eqe1Y8LbxpfxPxo5yC6p7BuO4CWiD0mDzitJJR+aVVqULi83y3fIXFJ JBPcI7+RcYFkdixUb5IxzuxOdioZXbvty3v5lCMxVTtBOCdpyc03jqSymOyfrpUDLYp8 D9fN3+tDgr7L5CIgWWgETgLjfNJdXfVTO6XZdso+HhaYKLTKpi5yc2J3LvsboBQ51PS/ 9rmrxoQiudiInpVMbHpLfLVpN0/WhJLYklrcB/B4k5/RCV0rQh9oIUCrT8Ge3ohiI0YN wnniQL87YRVXJ4PDLXj2ejPASufDjCF1RUHOp/4fF1sGd42F2E56+KdYRD8444lf+jQL VePg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=CVBp7Sxk; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id cw1si304483edb.82.2021.07.01.10.35.50; Thu, 01 Jul 2021 10:36:14 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@google.com header.s=20161025 header.b=CVBp7Sxk; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=REJECT sp=REJECT dis=NONE) header.from=google.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S230139AbhGARei (ORCPT + 99 others); Thu, 1 Jul 2021 13:34:38 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:46204 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229978AbhGAReg (ORCPT ); Thu, 1 Jul 2021 13:34:36 -0400 Received: from mail-pl1-x632.google.com (mail-pl1-x632.google.com [IPv6:2607:f8b0:4864:20::632]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 331A8C061764 for ; Thu, 1 Jul 2021 10:32:05 -0700 (PDT) Received: by mail-pl1-x632.google.com with SMTP id u19so4058872plc.3 for ; Thu, 01 Jul 2021 10:32:05 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=20161025; h=date:from:to:cc:subject:message-id:references:mime-version :content-disposition:in-reply-to; bh=BbJUiUUe8T9b2PK6TM2EJq7HBKzquI9DW1+aUliaiPo=; b=CVBp7SxkahiNSc/6amQlsQrupBIvPGzMuT+qFHMb8J+fEgPmJ+jSNCObUz3UPwYwDh 96U0UYYZnKH2aWE3M+lvXivMBhfaVSK+gjY5ur0I4ocShvUctW+KnLGvoFzWfrQslIk6 qhd/uIEmUd5jSNYfWvz65ylCrTmu0PcSVOlxbZrg1xHtLdgXfIko/5vmpmtm3li2QbnP Y0moswHricRpt+NVr5AWm0QclZ+uXuMmIJKEWZ9wiXx/T/+XpZgl7Z/SMudxcLfqBcNP TTnrGYRIDdk4Nea4OFwd9s1bwBi4xFDWbYXNUIWUbl0VP7GQ9CetjiSW63t0JNc8CgD3 wD7Q== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:date:from:to:cc:subject:message-id:references :mime-version:content-disposition:in-reply-to; bh=BbJUiUUe8T9b2PK6TM2EJq7HBKzquI9DW1+aUliaiPo=; b=t456SsPw+PAB4GXGO89GskpYMm+zGFPcJo9fzp0MA3XHA4Q5LM07/kIJaFnzLlV/Bl nT34FuIwXfNt/Y3gpvnD0YRV2V72I1G15CuETlZ0HleCm7XZsZHQ3zhBqNyDP/O0sdGU h13ECI9xw3swrGkMhNpE9Gk6/iQtaCJefkkdRYVUV5cYaRV2blrlsqgzxzVVpyEOBXBc /xuBEAIWHS8cXz19PSo8yNKDmJR/faCCm6DhEUxpb2df9SwVkCw18x4G7nbDrkqqc351 wR1xzHeWHV56TRRnGjheC4CX4b//7W3s3JteSnV/FXxGKmsxQtzM/6KII/ZPqI5BHvK+ ykKw== X-Gm-Message-State: AOAM531yidQ2SMixaUgc5R9isEBNF1JLtAJN0sGj4Rx8F3n5lwTEdBqA 87oAqiUmHMkBaLnFRPrQFcIMGA== X-Received: by 2002:a17:902:8503:b029:127:8abc:191c with SMTP id bj3-20020a1709028503b02901278abc191cmr845772plb.21.1625160724477; Thu, 01 Jul 2021 10:32:04 -0700 (PDT) Received: from google.com ([2620:15c:280:201:558a:406a:d453:dbe5]) by smtp.gmail.com with ESMTPSA id y13sm444667pgp.16.2021.07.01.10.32.03 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Thu, 01 Jul 2021 10:32:04 -0700 (PDT) Date: Thu, 1 Jul 2021 10:31:59 -0700 From: Paul Burton To: Joel Fernandes Cc: linux-kernel@vger.kernel.org, Steven Rostedt , Ingo Molnar , stable@vger.kernel.org Subject: Re: [PATCH 1/2] tracing: Simplify & fix saved_tgids logic Message-ID: References: <20210630003406.4013668-1-paulburton@google.com> MIME-Version: 1.0 Content-Type: text/plain; charset=utf-8 Content-Disposition: inline In-Reply-To: Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Joel, On Wed, Jun 30, 2021 at 06:29:55PM -0400, Joel Fernandes wrote: > On Tue, Jun 29, 2021 at 8:34 PM Paul Burton wrote: > > > > The tgid_map array records a mapping from pid to tgid, where the index > > of an entry within the array is the pid & the value stored at that index > > is the tgid. > > > > The saved_tgids_next() function iterates over pointers into the tgid_map > > array & dereferences the pointers which results in the tgid, but then it > > passes that dereferenced value to trace_find_tgid() which treats it as a > > pid & does a further lookup within the tgid_map array. It seems likely > > that the intent here was to skip over entries in tgid_map for which the > > recorded tgid is zero, but instead we end up skipping over entries for > > which the thread group leader hasn't yet had its own tgid recorded in > > tgid_map. > > > > A minimal fix would be to remove the call to trace_find_tgid, turning: > > > > if (trace_find_tgid(*ptr)) > > > > into: > > > > if (*ptr) > > > > ..but it seems like this logic can be much simpler if we simply let > > seq_read() iterate over the whole tgid_map array & filter out empty > > entries by returning SEQ_SKIP from saved_tgids_show(). Here we take that > > approach, removing the incorrect logic here entirely. > > Looks reasonable except for one nit: > > > Signed-off-by: Paul Burton > > Fixes: d914ba37d714 ("tracing: Add support for recording tgid of tasks") > > Cc: Steven Rostedt > > Cc: Ingo Molnar > > Cc: Joel Fernandes > > Cc: > > --- > > kernel/trace/trace.c | 38 +++++++++++++------------------------- > > 1 file changed, 13 insertions(+), 25 deletions(-) > > > > diff --git a/kernel/trace/trace.c b/kernel/trace/trace.c > > index d23a09d3eb37b..9570667310bcc 100644 > > --- a/kernel/trace/trace.c > > +++ b/kernel/trace/trace.c > > @@ -5608,37 +5608,20 @@ static const struct file_operations tracing_readme_fops = { > > > > static void *saved_tgids_next(struct seq_file *m, void *v, loff_t *pos) > > { > > - int *ptr = v; > > + int pid = ++(*pos); > > > > - if (*pos || m->count) > > - ptr++; > > - > > - (*pos)++; > > - > > - for (; ptr <= &tgid_map[PID_MAX_DEFAULT]; ptr++) { > > - if (trace_find_tgid(*ptr)) > > - return ptr; > > It would be great if you can add back the check for !tgid_map to both > next() and show() as well, for added robustness (since the old code > previously did it). That condition cannot happen, because both next() & show() are called to iterate through the content of the seq_file & by definition their v argument is non-NULL (else seq_file would have finished iterating already). That argument came from either start() or an earlier call to next(), which would only have returned a non-NULL pointer into tgid_map if tgid_map is non-NULL. I've added comments to this effect in v2, though the second patch in v2 does wind up effectively adding back the check in next() anyway in order to reuse some code. I was tempted to just add the redundant checks anyway (pick your battles and all) but for show() in particular it wound up making things seem non-sensical to me ("display the value describing this non-NULL pointer into tgid_map only if tgid_map is not NULL?"). Thanks, Paul > With that change: > Reviewed-by: Joel Fernandes (Google) > > thanks, > > -Joel > > > > - } > > + if (pid > PID_MAX_DEFAULT) > > + return NULL; > > > > - return NULL; > > + return &tgid_map[pid]; > > } > > > > static void *saved_tgids_start(struct seq_file *m, loff_t *pos) > > { > > - void *v; > > - loff_t l = 0; > > - > > - if (!tgid_map) > > + if (!tgid_map || *pos > PID_MAX_DEFAULT) > > return NULL; > > > > - v = &tgid_map[0]; > > - while (l <= *pos) { > > - v = saved_tgids_next(m, v, &l); > > - if (!v) > > - return NULL; > > - } > > - > > - return v; > > + return &tgid_map[*pos]; > > } > > > > static void saved_tgids_stop(struct seq_file *m, void *v) > > @@ -5647,9 +5630,14 @@ static void saved_tgids_stop(struct seq_file *m, void *v) > > > > static int saved_tgids_show(struct seq_file *m, void *v) > > { > > - int pid = (int *)v - tgid_map; > > + int *entry = (int *)v; > > + int pid = entry - tgid_map; > > + int tgid = *entry; > > + > > + if (tgid == 0) > > + return SEQ_SKIP; > > > > - seq_printf(m, "%d %d\n", pid, trace_find_tgid(pid)); > > + seq_printf(m, "%d %d\n", pid, tgid); > > return 0; > > } > > > > > > base-commit: 62fb9874f5da54fdb243003b386128037319b219 > > -- > > 2.32.0.93.g670b81a890-goog > >