From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.4 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH, MAILING_LIST_MULTI,SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=ham autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 19BFBC33CB1 for ; Wed, 15 Jan 2020 10:25:51 +0000 (UTC) Received: from vger.kernel.org (vger.kernel.org [209.132.180.67]) by mail.kernel.org (Postfix) with ESMTP id DF38C2187F for ; Wed, 15 Jan 2020 10:25:50 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=nvidia.com header.i=@nvidia.com header.b="MQURN8Zw" Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1729639AbgAOKZu (ORCPT ); Wed, 15 Jan 2020 05:25:50 -0500 Received: from hqnvemgate24.nvidia.com ([216.228.121.143]:6509 "EHLO hqnvemgate24.nvidia.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729631AbgAOKZu (ORCPT ); Wed, 15 Jan 2020 05:25:50 -0500 Received: from hqpgpgate102.nvidia.com (Not Verified[216.228.121.13]) by hqnvemgate24.nvidia.com (using TLS: TLSv1.2, DES-CBC3-SHA) id ; Wed, 15 Jan 2020 02:24:54 -0800 Received: from hqmail.nvidia.com ([172.20.161.6]) by hqpgpgate102.nvidia.com (PGP Universal service); Wed, 15 Jan 2020 02:25:49 -0800 X-PGP-Universal: processed; by hqpgpgate102.nvidia.com on Wed, 15 Jan 2020 02:25:49 -0800 Received: from [10.21.133.51] (172.20.13.39) by HQMAIL107.nvidia.com (172.20.187.13) with Microsoft SMTP Server (TLS) id 15.0.1473.3; Wed, 15 Jan 2020 10:25:47 +0000 Subject: Re: [PATCH v4 02/14] dmaengine: tegra-apb: Implement synchronization callback From: Jon Hunter To: Dmitry Osipenko , Laxman Dewangan , Vinod Koul , Dan Williams , Thierry Reding , =?UTF-8?B?TWljaGHFgiBNaXJvc8WCYXc=?= CC: , , References: <20200112173006.29863-1-digetx@gmail.com> <20200112173006.29863-3-digetx@gmail.com> <627f996c-1487-1b9a-e953-f5737f3ad32a@gmail.com> <34ec4c18-f082-def6-8544-0d15a109d7f8@nvidia.com> Message-ID: Date: Wed, 15 Jan 2020 10:25:45 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.2.2 MIME-Version: 1.0 In-Reply-To: <34ec4c18-f082-def6-8544-0d15a109d7f8@nvidia.com> X-Originating-IP: [172.20.13.39] X-ClientProxiedBy: HQMAIL107.nvidia.com (172.20.187.13) To HQMAIL107.nvidia.com (172.20.187.13) Content-Type: text/plain; charset="utf-8" Content-Language: en-US Content-Transfer-Encoding: quoted-printable DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=nvidia.com; s=n1; t=1579083894; bh=WDMyn/ZqNy9l1iysLsV2lNTZb/96GII9G+k29s8H9tY=; h=X-PGP-Universal:Subject:From:To:CC:References:Message-ID:Date: User-Agent:MIME-Version:In-Reply-To:X-Originating-IP: X-ClientProxiedBy:Content-Type:Content-Language: Content-Transfer-Encoding; b=MQURN8Zw4jvuLuapdX0bHMWKlRbOsoej7k6+p4drP5m6V+CEidzrouaGDiiHZWlQ4 x9xPnF951BwUjSrWp8Okv9aidiHrG0OXJGab3agHi9rfXfiIba/cg+03h2YjPEUipe mdC8+tHCthzfmetGHXkamozI1tcVD1LapvWEQArL2xWJGkA9N4feBaD8cEvnpuUCJv rcm9w3zMOR+0IjQGQjL/5UCeSA0kNx3LG7fRGX7l6/9eKqc4fZQtj7pfshn+4qZ15K o57qvPFykaEh6MQxv7Jv/go7oEO9o4y/5Ph5YHn+ae80GrloQuV9Ci1Mn63wO87g2h tpdgnRXuznHsA== Sender: dmaengine-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: dmaengine@vger.kernel.org On 15/01/2020 09:18, Jon Hunter wrote: >=20 > On 14/01/2020 21:02, Dmitry Osipenko wrote: >> 14.01.2020 18:15, Jon Hunter =D0=BF=D0=B8=D1=88=D0=B5=D1=82: >>> >>> On 12/01/2020 17:29, Dmitry Osipenko wrote: >>>> The ISR tasklet could be kept scheduled after DMA transfer termination= , >>>> let's add synchronization callback which blocks until tasklet is finis= hed. >>>> >>>> Signed-off-by: Dmitry Osipenko >>>> --- >>>> drivers/dma/tegra20-apb-dma.c | 8 ++++++++ >>>> 1 file changed, 8 insertions(+) >>>> >>>> diff --git a/drivers/dma/tegra20-apb-dma.c b/drivers/dma/tegra20-apb-d= ma.c >>>> index 319f31d27014..664e9c5df3ba 100644 >>>> --- a/drivers/dma/tegra20-apb-dma.c >>>> +++ b/drivers/dma/tegra20-apb-dma.c >>>> @@ -798,6 +798,13 @@ static int tegra_dma_terminate_all(struct dma_cha= n *dc) >>>> return 0; >>>> } >>>> =20 >>>> +static void tegra_dma_synchronize(struct dma_chan *dc) >>>> +{ >>>> + struct tegra_dma_channel *tdc =3D to_tegra_dma_chan(dc); >>>> + >>>> + tasklet_kill(&tdc->tasklet); >>>> +} >>>> + >>> >>> Wouldn't there need to be some clean-up here? If the tasklet is >>> scheduled, seems that there would be some other house-keeping that need= s >>> to be done after killing it. >> >> I'm not seeing anything to clean-up, could you please clarify? >=20 > Clean-up with regard to the descriptors. I was concerned if you will the > tasklet the necessary clean-up of the descriptors is not handled. Ah I see that tasklet_kill, unlike tasklet_kill_immediate, does wait for the tasklet to run if scheduled. OK, then this should be fine. Acked-by: Jon Hunter Cheers Jon --=20 nvpublic