Received: by 2002:a25:1506:0:0:0:0:0 with SMTP id 6csp1587665ybv; Thu, 6 Feb 2020 06:33:01 -0800 (PST) X-Google-Smtp-Source: APXvYqz0UbdJiNr3ZbfvWFAR3MqpLEetlrSM2NFAYZyTnN/ae1qjcH+6w4fbKpxJz1aL6XTXrE9/ X-Received: by 2002:a9d:7a47:: with SMTP id z7mr31328264otm.179.1580999581682; Thu, 06 Feb 2020 06:33:01 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1580999581; cv=none; d=google.com; s=arc-20160816; b=ablNkkqGS/+XCFCqWTJZzndB+EquUWK0FX+Ihc8+e6ssMswnO3VRJ9JiAnpczStSAD qadQ8M6z/LAcsVKxf2yukNb4gAoz2/fsQdUFDJz5pvzRLa2a47vEKjoIe2Pd8ZPSSe0c YYYQHv5tNCAaizA1I8ssmEl1PiuiZd8t0Hgj3pw2f5rRTB8+e08JZM8eB4iePvuuY7Wn dDWPzbgKy5mxPJETzr7Q44TlVMdYYN/iW2/1sPmn3UdQrIFtFMvkcRej8faLpKhUDcH1 1gt9sH5zuNlVVV7tIE40SIKTA241whbQ/3JuAhosfydFk3D/5Y7OCK7fujKJZN2U0MmM CQtQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:dkim-signature; bh=LYnTX+vuEch8amcqPtgj6i6sblayjdqUwjD1WqwgRUg=; b=BgTiCVb8BcJdKITmFGk4LOUc54ZwMsOahto41gpBvfFnanzf2E45ID/fag3jrvAEQk VkuxIeSpGPzkF72TiI7H9PoqzXvX7Lllp3G0i0U9rqmrNIOmmNaFIXDEgQ5wiRxkMO99 RNwSuvgVv2rZWMC26J4XWRXhPLQvEzUeBwbXTEkAQPGJQNolpI3rAeDhpri8qmHDLd7x fe9d44SMm8Vv7PK/zTx4YglRAv2I6hPeSGCtiNQF3OVeCL2rftZlpY3AlRN+ws7QS2Vj yK3skCs6am8f2pCMpYj34wwKtwM0So6v761ceqhDt+eXZfByyGfGi+EN8nPH9vx77DLx T1Yw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=rFYHzyK4; 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=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y19si1837981oto.102.2020.02.06.06.32.47; Thu, 06 Feb 2020 06:33:01 -0800 (PST) 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=@gmail.com header.s=20161025 header.b=rFYHzyK4; 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=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727963AbgBFObv (ORCPT + 99 others); Thu, 6 Feb 2020 09:31:51 -0500 Received: from mail-lj1-f195.google.com ([209.85.208.195]:36108 "EHLO mail-lj1-f195.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727901AbgBFObv (ORCPT ); Thu, 6 Feb 2020 09:31:51 -0500 Received: by mail-lj1-f195.google.com with SMTP id r19so6351370ljg.3; Thu, 06 Feb 2020 06:31:49 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=subject:to:cc:references:from:message-id:date:user-agent :mime-version:in-reply-to:content-language:content-transfer-encoding; bh=LYnTX+vuEch8amcqPtgj6i6sblayjdqUwjD1WqwgRUg=; b=rFYHzyK4k2vQwvpbA9XpYXNVtyOqH1iRZ9VK74Eks3rEQiCjU9VB/E4tSXleaK/7DS yCtEtGuaZDiimEeXKokqEWuXypgbIypXpSEayNNIttVD4bEhOXwQPBPpwpHuLTmArg/G t60NRj2zbSZXPEZaVMe2059b6Puih6HAUYQdl2ZYJQvXv83b2ZpiSa95NUc7okZdX9yR 2jv6HUimzPCKRw0aIbgXPBQnX2mIjfz8MUbLiwBCiEIG7D+VopxpeA4Fj/0vxBkNpc1J +a6VPej9BPWH5T+D9H9InZWWrGRrIpKEX9CZg3hz4sZ73e6C7MZCbK4oIdw8R3XEdokl Q1hw== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:subject:to:cc:references:from:message-id:date :user-agent:mime-version:in-reply-to:content-language :content-transfer-encoding; bh=LYnTX+vuEch8amcqPtgj6i6sblayjdqUwjD1WqwgRUg=; b=uPvLS5zNwEwVmvGfRtrKwHBpuvDV+tT0wqHW9w/FklBZrxM79O9PisWAGJO4EiNDRW xFym7WTxgDy+l/eaugolgennPRe4PAfPOl0aXXq20ngi8I11MYzdZ1ECqhN1ePX+rRDR IxVjpKwbnm4oV2/Lmd04IBJDcePrppTYbwzhsjjGDL0g3ztwC1C8DGR741kuOyB3zgy/ jCdlkCNV9GfCZGKlVk77XeBPpz4aJDzpOt8LzrI5novqJq7SjSsYy/92xu80jgCVsclh aVqsWssgb+mbzdHAAy9udfvF7Y54ohOxoJEwE5UVdM7xVFv+9Nc534HKOzO/rx8nzhTc VoBg== X-Gm-Message-State: APjAAAXj6xK5ohaqm1MZA381mwp7VoRj0Kb5I3dAfY8Lum7CQRMMOcoe ye/GrTwiIeMlGAip/j6lRFMwoJZv X-Received: by 2002:a2e:914d:: with SMTP id q13mr2240218ljg.198.1580999508762; Thu, 06 Feb 2020 06:31:48 -0800 (PST) Received: from [192.168.2.145] (79-139-233-37.dynamic.spd-mgts.ru. [79.139.233.37]) by smtp.googlemail.com with ESMTPSA id s15sm1477022ljs.58.2020.02.06.06.31.47 (version=TLS1_3 cipher=TLS_AES_128_GCM_SHA256 bits=128/128); Thu, 06 Feb 2020 06:31:48 -0800 (PST) Subject: Re: [PATCH v7 14/19] dmaengine: tegra-apb: Keep clock enabled only during of DMA transfer To: Jon Hunter , Laxman Dewangan , Vinod Koul , Dan Williams , Thierry Reding , =?UTF-8?B?TWljaGHFgiBNaXJvc8WCYXc=?= Cc: dmaengine@vger.kernel.org, linux-tegra@vger.kernel.org, linux-kernel@vger.kernel.org References: <20200202222854.18409-1-digetx@gmail.com> <20200202222854.18409-15-digetx@gmail.com> From: Dmitry Osipenko Message-ID: <3133d4e3-7623-9342-f26c-5de8b4e6b8c6@gmail.com> Date: Thu, 6 Feb 2020 17:31:45 +0300 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org 06.02.2020 16:50, Jon Hunter пишет: > > On 02/02/2020 22:28, Dmitry Osipenko wrote: >> It's a bit impractical to enable hardware's clock at the time of DMA >> channel's allocation because most of DMA client drivers allocate DMA >> channel at the time of the driver's probing, and thus, DMA clock is kept >> always-enabled in practice, defeating the whole purpose of runtime PM. >> >> Signed-off-by: Dmitry Osipenko >> --- >> drivers/dma/tegra20-apb-dma.c | 35 ++++++++++++++++++++++++----------- >> 1 file changed, 24 insertions(+), 11 deletions(-) > What about something like ...... > @@ -581,6 +582,7 @@ static bool handle_continuous_head_request(struct tegra_dma_channel *tdc, > hsgreq = list_first_entry(&tdc->pending_sg_req, typeof(*hsgreq), node); > if (!hsgreq->configured) { > tegra_dma_stop(tdc); > + pm_runtime_put(tdc->tdma->dev); > dev_err(tdc2dev(tdc), "Error in DMA transfer, aborting DMA\n"); > tegra_dma_abort_all(tdc); > return false; Yes, that it's what you suggested to do in the reply to v6. Alright, I'll drop v7 patch #13 and add the put to this patch #14.