Received: by 2002:ac0:950e:0:0:0:0:0 with SMTP id f14csp402176imc; Sat, 16 Mar 2019 04:24:50 -0700 (PDT) X-Google-Smtp-Source: APXvYqydKXRCOC2ZWEuEYZPLSO7AMd7w5UFQB8luDug40LnoyJQN6wDk+wbNqCeca8qYUU/YBS7K X-Received: by 2002:a62:f201:: with SMTP id m1mr8965012pfh.97.1552735490116; Sat, 16 Mar 2019 04:24:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1552735490; cv=none; d=google.com; s=arc-20160816; b=HXbxyXKksjbUK+H7eGNVXOcImRA8EvEGEjoPLeoC6PaKpCtDUtG20ry1Fw4iC9eNLO P9rfp2EE+bf3XDDXbLba4FX5cYNHJgmmbVlbZbCvZUsRNta+qVF14aCbRiBYPgxiDgu7 Pqu5nD3OZ36KmEB0K0xyUgAoXaO0HvC3Ygt5YMhA4XIuUBH4Xu+epwfxqmvaJZhwPuwt hI5tweKMjLnVkqKyvFRxmbhGrgGc6XPEqVMWxVUHhCtCw34xsHS3AUoCtddJvUjLo8f4 9uwxyC2OiGkdDZGMnbYHh3Njneyj+vmb0vqcEmqGI9vHiGH7V8tAznQbCR+bHkpjcCFw XAMw== 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; bh=GcBusZByMyXsPZw+EnJrPebffZawpSZGRIdqc446LG4=; b=psy7Qs+ZU/YqL/PM3QxomMgM8pkBgNfAUWgQWCMDOQDg7V3uDbaue6r6ZsmaYrqoJK eYiD7bPUGOiNDQ8Jq4eyvioqGLDTOqhdRa1fO0Ak7HuO+ziIdABIMAlkGlFD849WYz3T /3JP5svFfCW35YEPw8tc8nlLdKc+xZVQdJ6ZH5Eq9J8qc0YdWFhP9zPIEmFD/zNEyHPe pcdoSRVXilbArHBJ7h7c/R4lfa8tvQshzYyBxdAazVq0p0r5VHAbgxhtS3DROoUnZq2y ODT/rrQc9WDTIPZ1d+wHtyz+W3FpPxkgDieh3qS4uqKea6sWL1qGTPUqTCX16USstuTq 3Z8g== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id j26si4326059pfe.175.2019.03.16.04.24.33; Sat, 16 Mar 2019 04:24:50 -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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726801AbfCPLXz (ORCPT + 99 others); Sat, 16 Mar 2019 07:23:55 -0400 Received: from mailoutvs63.siol.net ([185.57.226.254]:54362 "EHLO mail.siol.net" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1726620AbfCPLXz (ORCPT ); Sat, 16 Mar 2019 07:23:55 -0400 Received: from localhost (localhost [127.0.0.1]) by mail.siol.net (Postfix) with ESMTP id A996F520F70; Sat, 16 Mar 2019 12:23:51 +0100 (CET) X-Virus-Scanned: amavisd-new at psrvmta09.zcs-production.pri Received: from mail.siol.net ([127.0.0.1]) by localhost (psrvmta09.zcs-production.pri [127.0.0.1]) (amavisd-new, port 10032) with ESMTP id 6SAXB4rc4Ekg; Sat, 16 Mar 2019 12:23:51 +0100 (CET) Received: from mail.siol.net (localhost [127.0.0.1]) by mail.siol.net (Postfix) with ESMTPS id 229AB520FB1; Sat, 16 Mar 2019 12:23:51 +0100 (CET) Received: from jernej-laptop.localnet (89-212-178-211.dynamic.t-2.net [89.212.178.211]) (Authenticated sender: jernej.skrabec@siol.net) by mail.siol.net (Postfix) with ESMTPA id A9911520F70; Sat, 16 Mar 2019 12:23:49 +0100 (CET) From: Jernej =?utf-8?B?xaBrcmFiZWM=?= To: Vinod Koul Cc: maxime.ripard@bootlin.com, wens@csie.org, robh+dt@kernel.org, mark.rutland@arm.com, dan.j.williams@intel.com, dmaengine@vger.kernel.org, devicetree@vger.kernel.org, linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, linux-sunxi@googlegroups.com Subject: Re: [PATCH 2/6] dmaengine: sun6i: Add a quirk for additional mbus clock Date: Sat, 16 Mar 2019 12:23:47 +0100 Message-ID: <2451376.qVWA8nfu3q@jernej-laptop> In-Reply-To: <20190316110753.GH5348@vkoul-mobl> References: <20190307165829.9086-1-jernej.skrabec@siol.net> <20190307165829.9086-3-jernej.skrabec@siol.net> <20190316110753.GH5348@vkoul-mobl> MIME-Version: 1.0 Content-Transfer-Encoding: 7Bit Content-Type: text/plain; charset="us-ascii" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi! Dne sobota, 16. marec 2019 ob 12:07:53 CET je Vinod Koul napisal(a): > On 07-03-19, 17:58, Jernej Skrabec wrote: > > H6 DMA controller needs additional mbus clock to be enabled. > > > > Add a quirk for it and handle it accordingly. > > > > Signed-off-by: Jernej Skrabec > > --- > > > > drivers/dma/sun6i-dma.c | 23 ++++++++++++++++++++++- > > 1 file changed, 22 insertions(+), 1 deletion(-) > > > > diff --git a/drivers/dma/sun6i-dma.c b/drivers/dma/sun6i-dma.c > > index 0cd13f17fc11..761555080325 100644 > > --- a/drivers/dma/sun6i-dma.c > > +++ b/drivers/dma/sun6i-dma.c > > @@ -129,6 +129,7 @@ struct sun6i_dma_config { > > > > u32 dst_burst_lengths; > > u32 src_addr_widths; > > u32 dst_addr_widths; > > > > + bool mbus_clk; > > > > }; > > > > /* > > > > @@ -182,6 +183,7 @@ struct sun6i_dma_dev { > > > > struct dma_device slave; > > void __iomem *base; > > struct clk *clk; > > > > + struct clk *clk_mbus; > > So rather than have mbus_clk and then a ptr, why not use the ptr and use > NULL value to check for..? > I'm not sure what you mean here. clk_mbus will hold a reference to a clock retrieved by devm_clk_get() so it has to be "struct clk *". What I'm missing here? > > int irq; > > spinlock_t lock; > > struct reset_control *rstc; > > > > @@ -1208,6 +1210,14 @@ static int sun6i_dma_probe(struct platform_device > > *pdev)> > > return PTR_ERR(sdc->clk); > > > > } > > > > + if (sdc->cfg->mbus_clk) { > > where is the populated? I was expecting this to be set based on DT! Of course it is based on DT. Check patch 5, where quirks structure attached to H6 DMA compatible contains ".mbus_clk = true,". "sdc->cfg" points to this quirk structure. > > > + sdc->clk_mbus = devm_clk_get(&pdev->dev, "mbus"); > > + if (IS_ERR(sdc->clk_mbus)) { > > + dev_err(&pdev->dev, "No mbus clock specified\n"); > > + return PTR_ERR(sdc->clk_mbus); > > + } > > + } > > + > > > > sdc->rstc = devm_reset_control_get(&pdev->dev, NULL); > > if (IS_ERR(sdc->rstc)) { > > > > dev_err(&pdev->dev, "No reset controller specified\n"); > > > > @@ -1312,11 +1322,19 @@ static int sun6i_dma_probe(struct platform_device > > *pdev)> > > goto err_reset_assert; > > > > } > > > > + if (sdc->cfg->mbus_clk) { > > + ret = clk_prepare_enable(sdc->clk_mbus); > > + if (ret) { > > + dev_err(&pdev->dev, "Couldn't enable mbus clock\n"); > > + goto err_clk_disable; > > + } > > + } > > + > > > > ret = devm_request_irq(&pdev->dev, sdc->irq, sun6i_dma_interrupt, 0, > > > > dev_name(&pdev->dev), sdc); > > > > if (ret) { > > > > dev_err(&pdev->dev, "Cannot request IRQ\n"); > > > > - goto err_clk_disable; > > + goto err_mbus_clk_disable; > > > > } > > > > ret = dma_async_device_register(&sdc->slave); > > > > @@ -1341,6 +1359,8 @@ static int sun6i_dma_probe(struct platform_device > > *pdev)> > > dma_async_device_unregister(&sdc->slave); > > > > err_irq_disable: > > sun6i_kill_tasklet(sdc); > > > > +err_mbus_clk_disable: > > + clk_disable_unprepare(sdc->clk_mbus); > > > > err_clk_disable: > > clk_disable_unprepare(sdc->clk); > > > > err_reset_assert: > > @@ -1359,6 +1379,7 @@ static int sun6i_dma_remove(struct platform_device > > *pdev)> > > sun6i_kill_tasklet(sdc); > > > > + clk_disable_unprepare(sdc->clk_mbus); > > > > clk_disable_unprepare(sdc->clk); > > reset_control_assert(sdc->rstc);