Received: by 2002:ac0:a582:0:0:0:0:0 with SMTP id m2-v6csp414634imm; Tue, 9 Oct 2018 21:05:37 -0700 (PDT) X-Google-Smtp-Source: ACcGV62CfONyhZoPtuFoA/DQUTRS4+LBjmv9KPZMnVGmfd1vbt+t6hANXaokJfZT4VjmAxKdRKN1 X-Received: by 2002:a17:902:bf0c:: with SMTP id bi12-v6mr31178372plb.118.1539144337670; Tue, 09 Oct 2018 21:05:37 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1539144337; cv=none; d=google.com; s=arc-20160816; b=OU/x7MrDilVBgEFhFwh9+JTaD1g7aD4JU6gaYuub+PbuDKQkNlGbnvfXkri1Nx8Q6z rWe5RmP5NEuouaB9YCrk6gdgsnkNIQG479BO94M1BxhjodextYhhc0DdEmKWSPX7yXPA nkLcfrHlsDDRJHcEWmMXMvd8Q3BUo0de/b1b61aeJ7hO8/BmlxdYz0mMxc0n/xI27MXa eGB8/7OEzveaP4Xr5r64zqjIlRuZe3ZfBaV/ldnpcahvQvJ0lBFPoQ0ciFL+3twz713d DVpyb7HjesijW5O2yxn1Qv0EWG/P3PoFiPcBEWyLRX87iWuQoY0kc2qru1lUgWaqT/U1 2/6A== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:user-agent:in-reply-to :content-disposition:mime-version:references:message-id:subject:cc :to:from:date:dkim-signature; bh=foD4Nb0MDOoew5t+a40wnVMX+K8c3yO/8BPvR7ygBLE=; b=dswGkXB5CZ6w/09+5b4BuE4Z3oc6u/1fkhYdkmWOlFPnxvEqd0EWkJs1aYfGVUQL9Z DTNs+ElZKNdGOv+P6sbtMEi71p0HvapI8FkRCzrJb220syhISL9M3XZGlWCIsGnUeIpW RpVwmtdngUnT6qVvX8CRHCHPwOBoJR64Dj2h1mtct8R9chOMhEqpaYu3QKIBnTvv7sss 02ZFn+oAUUEXRtl/vP6un/UGuBumwJ93+3604tpus/curwnYpcZFGFviNluDSZtm+PpK KxpcwZMWdVgCduJt7biNX5nH4rAujTIzx1db+6uhqOyfvb83N/6OyqFfO85VI2YLWL9O I4CQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b="Dt1FhK/9"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id q5-v6si20373099pgp.332.2018.10.09.21.05.22; Tue, 09 Oct 2018 21:05:37 -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=pass header.i=@kernel.org header.s=default header.b="Dt1FhK/9"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=kernel.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727218AbeJJLYD (ORCPT + 99 others); Wed, 10 Oct 2018 07:24:03 -0400 Received: from mail.kernel.org ([198.145.29.99]:46352 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1726515AbeJJLYC (ORCPT ); Wed, 10 Oct 2018 07:24:02 -0400 Received: from localhost (unknown [171.76.86.221]) (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 80CEC2077C; Wed, 10 Oct 2018 04:03:51 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1539144232; bh=EZH88J4QcH2ZTkA62iIrr2kBDAqlqKe4D5n4vfbWVUI=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=Dt1FhK/9OELUjgU8Zf7P2Fvyv6XjJvXLQaC5UgU3fH2LuPM7SUz8/4qKOs6zNUBj9 Zl6/iuKPVTdb62xYebasKKSKW950Q6dWThqi6FKAMjZpqGZrnTZQTfjvmWGJxBgm24 mP3QaZmJ5gSE7OicZtBdttw7NhYXuD6suiHTnlN4= Date: Wed, 10 Oct 2018 09:33:43 +0530 From: Vinod To: Pierre Yves MORDRET Cc: Rob Herring , Mark Rutland , Alexandre Torgue , Maxime Coquelin , Dan Williams , devicetree@vger.kernel.org, dmaengine@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org Subject: Re: [PATCH v3 4/7] dmaengine: stm32-dma: Add DMA/MDMA chaining support Message-ID: <20181010040343.GO2372@vkoul-mobl> References: <1538139715-24406-1-git-send-email-pierre-yves.mordret@st.com> <1538139715-24406-5-git-send-email-pierre-yves.mordret@st.com> <20181007160030.GB2372@vkoul-mobl> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.9.2 (2017-12-15) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 09-10-18, 10:40, Pierre Yves MORDRET wrote: > > > On 10/07/2018 06:00 PM, Vinod wrote: > > On 28-09-18, 15:01, Pierre-Yves MORDRET wrote: > >> This patch adds support of DMA/MDMA chaining support. > >> It introduces an intermediate transfer between peripherals and STM32 DMA. > >> This intermediate transfer is triggered by SW for single M2D transfer and > >> by STM32 DMA IP for all other modes (sg, cyclic) and direction (D2M). > >> > >> A generic SRAM allocator is used for this intermediate buffer > >> Each DMA channel will be able to define its SRAM needs to achieve chaining > >> feature : (2 ^ order) * PAGE_SIZE. > >> For cyclic, SRAM buffer is derived from period length (rounded on > >> PAGE_SIZE). > > > > So IIUC, you chain two dma txns together and transfer data via an SRAM? > > Correct. one DMA is DMAv2 (stm32-dma) and the other is MDMA(stm32-mdma). > Intermediate transfer is between device and memory. > This intermediate transfer is using SDRAM. Ah so you use dma calls to setup mdma xtfers? I dont think that is a good idea. How do you know you should use mdma for subsequent transfer? > >> drivers/dma/stm32-dma.c | 879 ++++++++++++++++++++++++++++++++++++++++++------ > > > > that is a lot of change for a driver, consider splitting it up > > logically in smaller changes... > > > > This feature is rather monolithic. Difficult to split up. > All the code is required at once. It can be enabled at last but split up logically. Intrusive changes to a driver make it hard to review.. -- ~Vinod