Received: by 2002:ac0:a581:0:0:0:0:0 with SMTP id m1-v6csp767564imm; Fri, 22 Jun 2018 05:06:11 -0700 (PDT) X-Google-Smtp-Source: ADUXVKJvQXQXvPjSuMTKHFoasWLtaSinkKsyTPAcrsoioudKaWMM1u269zK2nLWGU1s04afUkgsT X-Received: by 2002:a63:6e07:: with SMTP id j7-v6mr1185460pgc.251.1529669171393; Fri, 22 Jun 2018 05:06:11 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1529669171; cv=none; d=google.com; s=arc-20160816; b=WlhVv9DAnAMsPlCujvEFMN6lCyDdgn9w4dgZB5iQ54B0czjPCwG68QyjZh3UtAQZwc qFhmxSA7D6esm6imOEXTkFA2IEofulDM2Uut2AGHKZBzAuKaGE3KrbUxM+cQE6k7mU13 CIhJ+TRkSTAn6UnsLv+rucNBqHlZslwHjl1RWKY80xkQQ21AWe3rFOA0TD53wHyiMlQS lBjmiY7eKYvBZjq7GBxJpskJPDevenO6FOrzdYIfrcQPtcjkfrJ5ZM0Fl4TjRe374hld NHfeBrl/YwKgQypuo9B2LKwK3bqehx7bg7Hp3ir6yBVk9aD9V5cRfWkXlX9i+Hma9PBx Ih3w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from:dkim-signature:arc-authentication-results; bh=pwyO2hqgjXvQ1ArP/eHWgSkTsTtLlQ59Bespivq+iLM=; b=1EP0mSwBjK5LlXkd6yoYhYcA/B/7MxzdaTOiHdan7nGKcqVzoVqzcjNg5EVGeHewTF VLKoO99Y81HAbV2YuucrA8yFW8UMy06dSHV+38QwB274hV6Iyj8hSX0pAdiDL0MVNF9l 2jPDu8UZ53664ysmAYCdll8rUHjkwz70TPjSTdESH74FWWPPm1ZtAob8k6RuYa8ID25r Svj6/o45DohWBzgvocwxqfNv8XQ3+4zhu0HrASxdnmVsWbaIsS7V6Yg5YsPaKk3/VecC r9g1mxoZMrlm8178mFbkstkOSo2puBolbg74LgIK+fsqBnQ4fSBz5S40TrF5S09+SepH hllg== ARC-Authentication-Results: i=1; mx.google.com; dkim=fail header.i=@gmail.com header.s=20161025 header.b=H6kr7Z73; 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 f77-v6si7694306pff.267.2018.06.22.05.05.47; Fri, 22 Jun 2018 05:06:11 -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; dkim=fail header.i=@gmail.com header.s=20161025 header.b=H6kr7Z73; 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 S933139AbeFVMEm (ORCPT + 99 others); Fri, 22 Jun 2018 08:04:42 -0400 Received: from mail-lf0-f66.google.com ([209.85.215.66]:39596 "EHLO mail-lf0-f66.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751005AbeFVMEh (ORCPT ); Fri, 22 Jun 2018 08:04:37 -0400 Received: by mail-lf0-f66.google.com with SMTP id t2-v6so8611483lfd.6; Fri, 22 Jun 2018 05:04:36 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=sender:from:to:cc:subject:date:message-id:in-reply-to:references; bh=pwyO2hqgjXvQ1ArP/eHWgSkTsTtLlQ59Bespivq+iLM=; b=H6kr7Z73KTS+UyP79d4OCoY2nVaYNKs4XdQ3Xp7GjmfAVqwOKRY2F9IwGONOg9PtF/ 31ihxd4Wsb3dJ9UqXYvnG3KQi1de4DwXPmBzWBnlPaEjdfQmos5VvVGtVk35xT1gHTlH tFvddAcben14xxkRSFeOQdF17R5VT5qRGZV9jGLNp4uzKv+tvu0PuTXBlLqHTLzcvV4z zb+/LG/QkU7KT/t343uscvRNsLy1BS1jLFPksn2uWDmyh65EihntdScFZVgr0byiD4YN HghIyTn90qmQI1PhWLp/S+rQNSQHvP6MwbxnFLkGYI4SS/p2xk20sNy0bXxm4kLipEjr O/Kw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:sender:from:to:cc:subject:date:message-id :in-reply-to:references; bh=pwyO2hqgjXvQ1ArP/eHWgSkTsTtLlQ59Bespivq+iLM=; b=r5R/N/IF/1P4eGp1ZSsRcQP8AeKIr0oQsv8MvM3TfUm1qkGk/MRTQFQ+BPn/DZ6k3D bkvobRVnqj7ADQSU7o1GZFx4b/jBhqdS3inNP9IwElkNrR3i7klZzqNelkxclHRIGTuG RQEj6MFOrl1NUEhcBgvv2wY/yEoveQXyVDCjBhPfmTNL+FC7XI5rZLXdn9wF6kIWPrqX gvqQEtZqC9SAqLstTYkzSZGw3Zbghfd+9fU/QMWp+1ZSn1bcunXkXCiRJL+qCTpd09LR ZdmCh77gThwB/lQSmUO1kuzTBGsm88xnJJT1RS4guEGkQFqQxmAN12lyvC+U49EvGx6k sthw== X-Gm-Message-State: APt69E0PgV2acgjwEv6JqTHJQPc3W8YIPgLNXfOh61UVKIKWaVioknbq ohe7V0ImvaNlAHfwmCLdMqk= X-Received: by 2002:a2e:9789:: with SMTP id y9-v6mr1150046lji.52.1529669075589; Fri, 22 Jun 2018 05:04:35 -0700 (PDT) Received: from alpha.sai.msu.ru ([93.180.21.1]) by smtp.gmail.com with ESMTPSA id a77-v6sm1433663lfb.37.2018.06.22.05.04.34 (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Fri, 22 Jun 2018 05:04:34 -0700 (PDT) From: "Matwey V. Kornilov" To: hverkuil@xs4all.nl, mchehab@kernel.org Cc: "Matwey V. Kornilov" , rostedt@goodmis.org, mingo@redhat.com, isely@pobox.com, bhumirks@gmail.com, colin.king@canonical.com, linux-media@vger.kernel.org, linux-kernel@vger.kernel.org, ezequiel@collabora.com, laurent.pinchart@ideasonboard.com Subject: [PATCH v2 1/2] media: usb: pwc: Introduce TRACE_EVENTs for pwc_isoc_handler() Date: Fri, 22 Jun 2018 15:04:18 +0300 Message-Id: <20180622120419.7675-2-matwey@sai.msu.ru> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20180622120419.7675-1-matwey@sai.msu.ru> References: <20180622120419.7675-1-matwey@sai.msu.ru> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org There were reports that PWC-based webcams don't work at some embedded ARM platforms. [1] Isochronous transfer handler seems to work too long leading to the issues in MUSB USB host subsystem. Also note, that urb->giveback() handlers are still called with disabled interrupts. In order to be able to measure performance of PWC driver, traces are introduced in URB handler section. [1] https://www.spinics.net/lists/linux-usb/msg165735.html Signed-off-by: Matwey V. Kornilov --- drivers/media/usb/pwc/pwc-if.c | 7 +++++ include/trace/events/pwc.h | 64 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 71 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..72d2897a4b9f 100644 --- a/drivers/media/usb/pwc/pwc-if.c +++ b/drivers/media/usb/pwc/pwc-if.c @@ -76,6 +76,9 @@ #include "pwc-dec23.h" #include "pwc-dec1.h" +#define CREATE_TRACE_POINTS +#include + /* Function prototypes and driver templates */ /* hotplug device table support */ @@ -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, pdev); + if (urb->status == -ENOENT || urb->status == -ECONNRESET || urb->status == -ESHUTDOWN) { PWC_DEBUG_OPEN("URB (%p) unlinked %ssynchronously.\n", @@ -348,6 +353,8 @@ static void pwc_isoc_handler(struct urb *urb) } handler_end: + trace_pwc_handler_exit(urb, pdev); + i = usb_submit_urb(urb, GFP_ATOMIC); if (i != 0) PWC_ERROR("Error (%d) re-submitting urb in pwc_isoc_handler.\n", i); diff --git a/include/trace/events/pwc.h b/include/trace/events/pwc.h new file mode 100644 index 000000000000..d5bcb1314d0e --- /dev/null +++ b/include/trace/events/pwc.h @@ -0,0 +1,64 @@ +/* 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, struct pwc_device *pdev), + TP_ARGS(urb, pdev), + TP_STRUCT__entry( + __field(struct urb*, urb) + __field(int, urb__status) + __field(u32, urb__actual_length) + __field(char*, devpath) + __field(struct pwc_frame_buf*, fbuf) + __field(int, fbuf__filled) + ), + TP_fast_assign( + __entry->urb = urb; + __entry->urb__status = urb->status; + __entry->urb__actual_length = urb->actual_length; + __entry->devpath = pdev->udev->devpath; + __entry->fbuf = pdev->fill_buf; + __entry->fbuf__filled = pdev->fill_buf->filled; + ), + TP_printk("devpath=%s (fbuf=%p filled=%d) urb=%p (status=%d actual_length=%u)", + __entry->devpath, + __entry->fbuf, + __entry->fbuf__filled, + __entry->urb, + __entry->urb__status, + __entry->urb__actual_length) +); + +TRACE_EVENT(pwc_handler_exit, + TP_PROTO(struct urb *urb, struct pwc_device* pdev), + TP_ARGS(urb, pdev), + TP_STRUCT__entry( + __field(struct urb*, urb) + __field(char*, devpath) + __field(struct pwc_frame_buf*, fbuf) + __field(int, fbuf__filled) + ), + TP_fast_assign( + __entry->urb = urb; + __entry->devpath = pdev->udev->devpath; + __entry->fbuf = pdev->fill_buf; + __entry->fbuf__filled = pdev->fill_buf->filled; + ), + TP_printk("devpath=%s (fbuf=%p filled=%d) urb=%p", + __entry->devpath, + __entry->fbuf, + __entry->fbuf__filled, + __entry->urb) +); + +#endif /* _TRACE_PWC_H */ + +/* This part must be outside protection */ +#include -- 2.16.4