From patchwork Mon Dec 9 09:43:25 2019 Content-Type: text/plain; charset="utf-8" MIME-Version: 1.0 Content-Transfer-Encoding: 7bit X-Patchwork-Submitter: Peter Ujfalusi X-Patchwork-Id: 181006 Delivered-To: patch@linaro.org Received: by 2002:a92:3001:0:0:0:0:0 with SMTP id x1csp4117496ile; Mon, 9 Dec 2019 01:43:58 -0800 (PST) X-Google-Smtp-Source: APXvYqz49trKADHN1rZMAdmH87A07VlY6OYxWqdoinBG5zBdudnzKgkkjw7xnVUOhljP6gGVj/wQ X-Received: by 2002:a05:6830:1d7a:: with SMTP id l26mr14298448oti.138.1575884638270; Mon, 09 Dec 2019 01:43:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1575884638; cv=none; d=google.com; s=arc-20160816; b=DjJ4z6Dm+rumKUwYLjMenlVtHWiv0Y7SiNJcMysk3ak1RG+5FtdaPcktlgcCAhGiPq ubKtpida3PdEmSdBUB9xvg/efUBTDLUAvjZmGbAZokvPM8utjz4OWT5L17m7PzNYhBTJ xpfEVuZsFoM+gLF/Z7IsHgGQkjAQtX5bLK3zbuqCn3+ISadaV0mFXKHbSJYLop/STipM dcOczzP1Sx6eUBUS2qNpq27olaNCgC6LZjVwmOmKWecTOB5aY8g7Rbp4u06+yesFtQVw 8IwvhRWhtJp7OMnxheJFr218R9dDELUu/H+aLlS17uV93HToQuMy9abvWsHL/vZ4pGED viuA== 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:date:subject:cc:to:from :dkim-signature; bh=1ejU+vd2T9/FB/A9l3rJiiNfVEy7pyhWG9mzxXGvrc8=; b=aX2esnEO0s0lqkWJIR5igYJ3aUuOET85/thRAKP5xiCZKyfYlmFIqkwqW0Vbqm1EEv Z4YApu1M4O4eUxaNOIkJyu3HX3DgLutEf7/zwN0Dk1qOIsw7xLBLaPNy+hXPcsYSb9tC iAhpFItmFxTNPpBmL5P7CBrqVmPAqxRo0bFC+Zh6eV8jikAfSqpKqBeCVQ7Kk3sq4229 wE5OBGx18joXs/kzaRojzTf3lcqH1aBFul8JB0Vim7c06NS3FgUoGOCLhy7UVsFeSrK5 ZjtPLKhwxyIq0WZrjVqp1X83F2PDAY77uWrRfZ6yGcqRS5/9urxH+EkA0L9CAlxCdtYG 2Org== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=t2MRX1bD; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q26si11566144oij.38.2019.12.09.01.43.58; Mon, 09 Dec 2019 01:43:58 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@ti.com header.s=ti-com-17Q1 header.b=t2MRX1bD; spf=pass (google.com: best guess record for domain of devicetree-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=devicetree-owner@vger.kernel.org; dmarc=pass (p=QUARANTINE sp=NONE dis=NONE) header.from=ti.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727506AbfLIJn5 (ORCPT + 8 others); Mon, 9 Dec 2019 04:43:57 -0500 Received: from fllv0015.ext.ti.com ([198.47.19.141]:57546 "EHLO fllv0015.ext.ti.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727682AbfLIJn5 (ORCPT ); Mon, 9 Dec 2019 04:43:57 -0500 Received: from fllv0035.itg.ti.com ([10.64.41.0]) by fllv0015.ext.ti.com (8.15.2/8.15.2) with ESMTP id xB99hnEh108537; Mon, 9 Dec 2019 03:43:49 -0600 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=ti.com; s=ti-com-17Q1; t=1575884629; bh=1ejU+vd2T9/FB/A9l3rJiiNfVEy7pyhWG9mzxXGvrc8=; h=From:To:CC:Subject:Date:In-Reply-To:References; b=t2MRX1bDhbmbg6nQZg6aKzoT6ERle44QR8OAMv57meO94t17L82jlT4de1YQXBHi/ gyMJ5C3jX8F6+R6m5GZwh3S6Nj/GfUbumde8kfY8aumE57kBwV7xt1M4CsNnOtMj8I l7jLXwCum9rap3Mbp+0CMFz7qVHXpH75ClVRvWYQ= Received: from DFLE103.ent.ti.com (dfle103.ent.ti.com [10.64.6.24]) by fllv0035.itg.ti.com (8.15.2/8.15.2) with ESMTP id xB99hnPC032005; Mon, 9 Dec 2019 03:43:49 -0600 Received: from DFLE109.ent.ti.com (10.64.6.30) by DFLE103.ent.ti.com (10.64.6.24) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3; Mon, 9 Dec 2019 03:43:49 -0600 Received: from fllv0040.itg.ti.com (10.64.41.20) by DFLE109.ent.ti.com (10.64.6.30) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1847.3 via Frontend Transport; Mon, 9 Dec 2019 03:43:49 -0600 Received: from feketebors.ti.com (ileax41-snat.itg.ti.com [10.172.224.153]) by fllv0040.itg.ti.com (8.15.2/8.15.2) with ESMTP id xB99hOWm080263; Mon, 9 Dec 2019 03:43:45 -0600 From: Peter Ujfalusi To: , , , CC: , , , , , , , , , , Subject: [PATCH v7 05/12] dmaengine: Add support for reporting DMA cached data amount Date: Mon, 9 Dec 2019 11:43:25 +0200 Message-ID: <20191209094332.4047-6-peter.ujfalusi@ti.com> X-Mailer: git-send-email 2.24.0 In-Reply-To: <20191209094332.4047-1-peter.ujfalusi@ti.com> References: <20191209094332.4047-1-peter.ujfalusi@ti.com> MIME-Version: 1.0 X-EXCLAIMER-MD-CONFIG: e1e8a2fd-e40a-4ac6-ac9b-f7e9cc9ee180 Sender: devicetree-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: devicetree@vger.kernel.org A DMA hardware can have big cache or FIFO and the amount of data sitting in the DMA fabric can be an interest for the clients. For example in audio we want to know the delay in the data flow and in case the DMA have significantly large FIFO/cache, it can affect the latenc/delay Signed-off-by: Peter Ujfalusi Reviewed-by: Tero Kristo --- drivers/dma/dmaengine.h | 8 ++++++++ include/linux/dmaengine.h | 2 ++ 2 files changed, 10 insertions(+) -- Peter Texas Instruments Finland Oy, Porkkalankatu 22, 00180 Helsinki. Y-tunnus/Business ID: 0615521-4. Kotipaikka/Domicile: Helsinki diff --git a/drivers/dma/dmaengine.h b/drivers/dma/dmaengine.h index 501c0b063f85..b0b97475707a 100644 --- a/drivers/dma/dmaengine.h +++ b/drivers/dma/dmaengine.h @@ -77,6 +77,7 @@ static inline enum dma_status dma_cookie_status(struct dma_chan *chan, state->last = complete; state->used = used; state->residue = 0; + state->in_flight_bytes = 0; } return dma_async_is_complete(cookie, complete, used); } @@ -87,6 +88,13 @@ static inline void dma_set_residue(struct dma_tx_state *state, u32 residue) state->residue = residue; } +static inline void dma_set_in_flight_bytes(struct dma_tx_state *state, + u32 in_flight_bytes) +{ + if (state) + state->in_flight_bytes = in_flight_bytes; +} + struct dmaengine_desc_callback { dma_async_tx_callback callback; dma_async_tx_callback_result callback_result; diff --git a/include/linux/dmaengine.h b/include/linux/dmaengine.h index 0e8b426bbde9..c4c5219030a6 100644 --- a/include/linux/dmaengine.h +++ b/include/linux/dmaengine.h @@ -682,11 +682,13 @@ static inline struct dma_async_tx_descriptor *txd_next(struct dma_async_tx_descr * @residue: the remaining number of bytes left to transmit * on the selected transfer for states DMA_IN_PROGRESS and * DMA_PAUSED if this is implemented in the driver, else 0 + * @in_flight_bytes: amount of data in bytes cached by the DMA. */ struct dma_tx_state { dma_cookie_t last; dma_cookie_t used; u32 residue; + u32 in_flight_bytes; }; /**