Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp4270163imm; Mon, 18 Jun 2018 12:00:00 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJTcOEqv3E5B0kpQuv9SB+mpy22dKXvJLGjZ1waeKHLBejwgv0YAFEo+IJbbaajdpxwzOBn X-Received: by 2002:a62:fd0b:: with SMTP id p11-v6mr14819139pfh.52.1529348400766; Mon, 18 Jun 2018 12:00:00 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529348400; cv=none; d=google.com; s=arc-20160816; b=JoE4IafcfOIvuDkTM09j7ViyfdgfXsu3OUjz5CrPkUaO0y0T/08tR1Cm2yOZWwAg7U mkbDKZBCrA6fwjlxZOLLwdSZu0usThqgc1uc+yJk4d4XkpRQtHghCUsFDedSDwa/kFhQ lan15pl0t3ejFY8EN/4uxSgycRd+jbX4dUfjy+f/xPbQ/uSBF4avZc13HXqccDzPR1v1 czPFqhAiLeBh3C6TfFBt7BueRm5PdFVLUJEH+SrGlIupPQnteo97H6gpZlqVy1GiT2td x7oKqk4t1PpbbYyTGdCBzyLzqKdfq9z6DtGzVDDSKFgHkKgPteVGbanf34Y8M0uDpGbb ridA== 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 :arc-authentication-results; bh=pUJ5j9gKrhDfrGO4lSDLi3tqM9Ri6xS5aXzQZbcRwwc=; b=Zdkn6Ll7KBRjUp6HR1OefPZYgbzmotB4c1SuMKbpBXrXZn6AHemmTK8zfYDPNabVGc XtYiMRKQv+KdST5xuFmXprau8AiGiV0hjqiCEghRUB1wVZ4d7tlqREXbUq5+Y6HQPUYV i2HQuJ5AJrIhFl1Ggb0B/wuuuUUmjG8d6JTwy3vj5ShmylpBbZ3b1NZbJnBB0zEo2TsM dcWhLW+ikWVt/K8B8r4c7JhVJgY8nvpi62zS2BO5wNETPT9oqS/3c1SlZSKihqYXdGzD 9fqUjE+CxyJP8kjeIWaKS0/UVf1wZ4H46WmmzTlm7iYomqOuwye7jCvt8CgjYFadMZyw LJOg== 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 d10-v6si12878468pgf.515.2018.06.18.11.59.47; Mon, 18 Jun 2018 12:00:00 -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 S936150AbeFRS66 (ORCPT + 99 others); Mon, 18 Jun 2018 14:58:58 -0400 Received: from mail.kernel.org ([198.145.29.99]:57228 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935828AbeFRS65 (ORCPT ); Mon, 18 Jun 2018 14:58:57 -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 F0B3620693; Mon, 18 Jun 2018 18:58:55 +0000 (UTC) Date: Mon, 18 Jun 2018 14:58:54 -0400 From: Steven Rostedt To: "Matwey V. Kornilov" Cc: hverkuil@xs4all.nl, mchehab@kernel.org, mingo@redhat.com, isely@pobox.com, bhumirks@gmail.com, colin.king@canonical.com, linux-media@vger.kernel.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH 1/2] Add TRACE_EVENTs in pwc_isoc_handler() Message-ID: <20180618145854.2092c6e0@gandalf.local.home> In-Reply-To: <20180617143625.32133-1-matwey@sai.msu.ru> References: <20180617143625.32133-1-matwey@sai.msu.ru> 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 Sun, 17 Jun 2018 17:36:24 +0300 "Matwey V. Kornilov" wrote: I would prefer a change log here that would explain why these tracepoints are being added. > Signed-off-by: Matwey V. Kornilov > --- > drivers/media/usb/pwc/pwc-if.c | 7 +++++++ > include/trace/events/pwc.h | 45 ++++++++++++++++++++++++++++++++++++++++++ > 2 files changed, 52 insertions(+) > create mode 100644 include/trace/events/pwc.h > > diff --git a/drivers/media/usb/pwc/pwc-if.c b/drivers/media/usb/pwc/pwc-if.c > index 54b036d39c5b..5775d1f60668 100644 > --- a/drivers/media/usb/pwc/pwc-if.c > +++ b/drivers/media/usb/pwc/pwc-if.c > @@ -57,6 +57,9 @@ > - Pham Thanh Nam: webcam snapshot button as an event input device > */ > > +#define CREATE_TRACE_POINTS > +#include > + > #include > #include > #include > @@ -260,6 +263,8 @@ static void pwc_isoc_handler(struct urb *urb) > int i, fst, flen; > unsigned char *iso_buf = NULL; > > + trace_pwc_handler_enter(urb); > + > if (urb->status == -ENOENT || urb->status == -ECONNRESET || > urb->status == -ESHUTDOWN) { > PWC_DEBUG_OPEN("URB (%p) unlinked %ssynchronously.\n", Looks like if this is hit, we will return from the function without calling trace_pwc_handler_exit(). > @@ -347,6 +352,8 @@ static void pwc_isoc_handler(struct urb *urb) > pdev->vlast_packet_size = flen; > } > > + trace_pwc_handler_exit(urb); > + > handler_end: Why not add the tracepoint after handler_end. In fact, why not add some exit status to the trace event? I would think that would be useful as well. > i = usb_submit_urb(urb, GFP_ATOMIC); > if (i != 0) > diff --git a/include/trace/events/pwc.h b/include/trace/events/pwc.h > new file mode 100644 > index 000000000000..b13d2118bb7a > --- /dev/null > +++ b/include/trace/events/pwc.h > @@ -0,0 +1,45 @@ > +/* SPDX-License-Identifier: GPL-2.0 */ > +#if !defined(_TRACE_PWC_H) || defined(TRACE_HEADER_MULTI_READ) > +#define _TRACE_PWC_H > + > +#include > +#include > + > +#undef TRACE_SYSTEM > +#define TRACE_SYSTEM pwc > + > +TRACE_EVENT(pwc_handler_enter, > + TP_PROTO(struct urb *urb), > + TP_ARGS(urb), > + TP_STRUCT__entry( > + __field(struct urb*, urb) > + __field(int, urb__status) > + __field(u32, urb__actual_length) > + ), > + TP_fast_assign( > + __entry->urb = urb; > + __entry->urb__status = urb->status; > + __entry->urb__actual_length = urb->actual_length; Is there any other data that may be interesting to record here? -- Steve > + ), > + TP_printk("urb=%p (status=%d actual_length=%u)", > + __entry->urb, > + __entry->urb__status, > + __entry->urb__actual_length) > +); > + > +TRACE_EVENT(pwc_handler_exit, > + TP_PROTO(struct urb *urb), > + TP_ARGS(urb), > + TP_STRUCT__entry( > + __field(struct urb*, urb) > + ), > + TP_fast_assign( > + __entry->urb = urb; > + ), > + TP_printk("urb=%p", __entry->urb) > +); > + > +#endif /* _TRACE_PWC_H */ > + > +/* This part must be outside protection */ > +#include