Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933846AbcLIRSJ (ORCPT ); Fri, 9 Dec 2016 12:18:09 -0500 Received: from mga07.intel.com ([134.134.136.100]:4061 "EHLO mga07.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933531AbcLIRSG (ORCPT ); Fri, 9 Dec 2016 12:18:06 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.33,324,1477983600"; d="scan'208";a="796207674" Date: Fri, 9 Dec 2016 22:47:27 +0530 From: Vinod Koul To: Sebastian Frias Cc: =?iso-8859-1?Q?M=E5ns_Rullg=E5rd?= , Mason , Russell King , dmaengine@vger.kernel.org, Linus Walleij , Dan Williams , LKML , Linux ARM , Jon Mason , Mark Brown , Lars-Peter Clausen , Lee Jones , Laurent Pinchart , Arnd Bergmann , Maxime Ripard , Dave Jiang , Peter Ujfalusi , Bartlomiej Zolnierkiewicz , Thibaud Cornic Subject: Re: Tearing down DMA transfer setup after DMA client has finished Message-ID: <20161209171727.GK6408@localhost> References: <5846B237.8060409@free.fr> <20161207164341.GX6408@localhost> <20161208103921.GC6408@localhost> <91b0d10c-1bc2-c3e1-4088-f4ad9adcd6c0@free.fr> <20161208163755.GH6408@localhost> <20161209065955.GJ6408@localhost> <6ce1ea97-1d68-2203-c7b4-73315e801655@laposte.net> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <6ce1ea97-1d68-2203-c7b4-73315e801655@laposte.net> User-Agent: Mutt/1.5.21 (2010-09-15) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 1695 Lines: 43 On Fri, Dec 09, 2016 at 11:25:57AM +0100, Sebastian Frias wrote: > > What concrete solution do you propose? I have already proposed two solutions. A) Request a channel only when you need it. Obviously we can't do virtual channels with this (though we should still use virt-channels framework). The sbox setup and teardown can be done as part of channel request and freeup. PL08x already does this. Downside is that we can only have as many consumers at a time as channels. I have not heard any technical reason for not doing this apart from drivers grab the channel at probe, which is incorrect and needs to be fixed irrespective of the problem at hand. This is my preferred option. B) Create a custom driver specific API. This API for example: sbox_setup(bool enable, ...) can be called by client to explicitly setup and clear up the sbox setting. This way we can have transactions muxed. I have not heard any arguments on why we shouldn't do this except Russell's comment that A) solves this. > Alternatively, one can think of the current issue (i.e.: the fact that the IRQ > arrives "too soon") in a different way. > Instead of thinking the IRQ indicates "transfer complete", it is indicating "ready > to accept another command", which in practice (and with proper API support) can > translate into efficient queuing of DMA operations. That IMO is a better understanding of this issue. But based on discussion, I think the issue is that submitting next transaction cannot be done until sbox is setup (as a consequence torn down for previous). Tear down can be down only when client knows that transfer is done, from dma controller data has been pushed and in-flight. -- ~Vinod