From patchwork Wed Nov 11 01:14:45 2020 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Dmitry Osipenko X-Patchwork-Id: 11896051 X-Patchwork-Delegate: cw00.choi@samsung.com Return-Path: Received: from mail.kernel.org (pdx-korg-mail-1.web.codeaurora.org [172.30.200.123]) by pdx-korg-patchwork-2.web.codeaurora.org (Postfix) with ESMTP id F24FB921 for ; Wed, 11 Nov 2020 01:17:28 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by mail.kernel.org (Postfix) with ESMTP id CF2B0221F7 for ; Wed, 11 Nov 2020 01:17:28 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=gmail.com header.i=@gmail.com header.b="Ntx7ZeFj" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1733012AbgKKBRR (ORCPT ); Tue, 10 Nov 2020 20:17:17 -0500 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:48784 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1732586AbgKKBPg (ORCPT ); Tue, 10 Nov 2020 20:15:36 -0500 Received: from mail-wr1-x444.google.com (mail-wr1-x444.google.com [IPv6:2a00:1450:4864:20::444]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 16C1AC0613D1; Tue, 10 Nov 2020 17:15:36 -0800 (PST) Received: by mail-wr1-x444.google.com with SMTP id s8so708276wrw.10; Tue, 10 Nov 2020 17:15:36 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=from:to:cc:subject:date:message-id:in-reply-to:references :mime-version:content-transfer-encoding; bh=1e/VYWgZxHoyycezlGx0+zNMTf+Ar1q2pDE3AU+q2B4=; b=Ntx7ZeFjnTLoZ7J8oLjNcCFDoPBW4C5PNkct/9BX0yPgUHnj1t705oKvKLsOLkqYzW CK67X5JEuIk+DIDAlUjSfCVfq8mtpGNXEfe7hK2tLBD8kBwCRr86GMPqxlQBoVX6/Wat UekFb/FL5BFeVLuEE5QylQmc27TAjgFF8roBBGCVnMEQIA+CVv5IfJq9AVaT+BQaUZYT Gd9cN+/jJGxf5QB7BHEfps/Q4Je+7yzw0U0dzjE3C2v/IpUDpcFOdBCekq+97nl2kdf1 J4cv2MOo4FLbMlPfNX2FF+ywKahFTCkBtEgDATLeOb28PBj9npnNj2qno6RmvCyHH02i zp5w== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references:mime-version:content-transfer-encoding; bh=1e/VYWgZxHoyycezlGx0+zNMTf+Ar1q2pDE3AU+q2B4=; b=UpX3keQ7hicyeIpU7pNm2OKD/LEv+owCtF0u2ZC6Uk4JnPPZqXCUt9w0c6fEfDJRfQ W1tIor1YIMs4tEpuE1R9z8j/6r10t0WA4VKNZizLIzdDqYuQCpt3Mg9h8hMunbD26CHV zKXU2OvsO8DgE4yJ2CAij/adgDhciU1vwU3n/1MupR/TSsSeSwPkYmvaki40eA+emq5A JIkQqT53DVJnKnvtqz7t4p+8Pg35O723byNGGghd+Zi/awMkWQ577PKDquuOPjEg2aVb QmFQtwFFbtw0r85NvKEP8OOF36LYK5dNvYWaoSIgMMKkcjWMQ2RiPKdKfqdOkyK05BEq nJkA== X-Gm-Message-State: AOAM533ppdTAKJ9Q0sAIoGxNJ1sv4uj7NvA7qOI1vfrSXL7hEU+rCrQA 8NRE9Lu2SjlfN/9JErY1Vqk= X-Google-Smtp-Source: ABdhPJxglGCpULnac1YqVQcpXTbXrBkV/6sfAkYeybyeZ3ivKOQLtr9xoJP1u4dyX3xlS8RoO4Uq1g== X-Received: by 2002:adf:f4c9:: with SMTP id h9mr25752756wrp.332.1605057334852; Tue, 10 Nov 2020 17:15:34 -0800 (PST) Received: from localhost.localdomain (109-252-193-159.dynamic.spd-mgts.ru. [109.252.193.159]) by smtp.gmail.com with ESMTPSA id g131sm564329wma.35.2020.11.10.17.15.33 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Tue, 10 Nov 2020 17:15:34 -0800 (PST) From: Dmitry Osipenko To: Thierry Reding , Jonathan Hunter , Georgi Djakov , Rob Herring , Michael Turquette , Stephen Boyd , Peter De Schrijver , MyungJoo Ham , Kyungmin Park , Chanwoo Choi , Mikko Perttunen , Viresh Kumar , Peter Geis , Nicolas Chauvet , Krzysztof Kozlowski Cc: linux-tegra@vger.kernel.org, linux-pm@vger.kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org Subject: [PATCH v8 15/26] drm/tegra: dc: Extend debug stats with total number of events Date: Wed, 11 Nov 2020 04:14:45 +0300 Message-Id: <20201111011456.7875-16-digetx@gmail.com> X-Mailer: git-send-email 2.29.2 In-Reply-To: <20201111011456.7875-1-digetx@gmail.com> References: <20201111011456.7875-1-digetx@gmail.com> MIME-Version: 1.0 Precedence: bulk List-ID: X-Mailing-List: linux-pm@vger.kernel.org It's useful to know the total number of underflow events and currently the debug stats are getting reset each time CRTC is being disabled. Let's account the overall number of events that doesn't get a reset. Tested-by: Peter Geis Tested-by: Nicolas Chauvet Signed-off-by: Dmitry Osipenko --- drivers/gpu/drm/tegra/dc.c | 10 ++++++++++ drivers/gpu/drm/tegra/dc.h | 5 +++++ 2 files changed, 15 insertions(+) diff --git a/drivers/gpu/drm/tegra/dc.c b/drivers/gpu/drm/tegra/dc.c index 14168f792977..fd7c8828652d 100644 --- a/drivers/gpu/drm/tegra/dc.c +++ b/drivers/gpu/drm/tegra/dc.c @@ -1539,6 +1539,11 @@ static int tegra_dc_show_stats(struct seq_file *s, void *data) seq_printf(s, "underflow: %lu\n", dc->stats.underflow); seq_printf(s, "overflow: %lu\n", dc->stats.overflow); + seq_printf(s, "frames total: %lu\n", dc->stats.frames_total); + seq_printf(s, "vblank total: %lu\n", dc->stats.vblank_total); + seq_printf(s, "underflow total: %lu\n", dc->stats.underflow_total); + seq_printf(s, "overflow total: %lu\n", dc->stats.overflow_total); + return 0; } @@ -2308,6 +2313,7 @@ static irqreturn_t tegra_dc_irq(int irq, void *data) /* dev_dbg(dc->dev, "%s(): frame end\n", __func__); */ + dc->stats.frames_total++; dc->stats.frames++; } @@ -2316,6 +2322,7 @@ static irqreturn_t tegra_dc_irq(int irq, void *data) dev_dbg(dc->dev, "%s(): vertical blank\n", __func__); */ drm_crtc_handle_vblank(&dc->base); + dc->stats.vblank_total++; dc->stats.vblank++; } @@ -2323,6 +2330,7 @@ static irqreturn_t tegra_dc_irq(int irq, void *data) /* dev_dbg(dc->dev, "%s(): underflow\n", __func__); */ + dc->stats.underflow_total++; dc->stats.underflow++; } @@ -2330,11 +2338,13 @@ static irqreturn_t tegra_dc_irq(int irq, void *data) /* dev_dbg(dc->dev, "%s(): overflow\n", __func__); */ + dc->stats.overflow_total++; dc->stats.overflow++; } if (status & HEAD_UF_INT) { dev_dbg_ratelimited(dc->dev, "%s(): head underflow\n", __func__); + dc->stats.underflow_total++; dc->stats.underflow++; } diff --git a/drivers/gpu/drm/tegra/dc.h b/drivers/gpu/drm/tegra/dc.h index 0d7bdf66a1ec..ba4ed35139fb 100644 --- a/drivers/gpu/drm/tegra/dc.h +++ b/drivers/gpu/drm/tegra/dc.h @@ -48,6 +48,11 @@ struct tegra_dc_stats { unsigned long vblank; unsigned long underflow; unsigned long overflow; + + unsigned long frames_total; + unsigned long vblank_total; + unsigned long underflow_total; + unsigned long overflow_total; }; struct tegra_windowgroup_soc {