Received: by 2002:a25:4158:0:0:0:0:0 with SMTP id o85csp3698519yba; Mon, 29 Apr 2019 07:07:24 -0700 (PDT) X-Google-Smtp-Source: APXvYqxVm7uPNGSMpxUWMKadLs2udT2tRO8UGHSaRs4ESY2Cq36k6GRZY+gec5VdgNFt6noJw2Pa X-Received: by 2002:a17:902:b181:: with SMTP id s1mr39678168plr.9.1556546844044; Mon, 29 Apr 2019 07:07:24 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1556546844; cv=none; d=google.com; s=arc-20160816; b=IdS/ejcmRoMT8n+T0aPGH1gJLHywtq9P4hch92QI/ExQJqpLy27tOcuA+wF9mYzM8p 3ZFlK1jgSA1L5WF3ETrcez4SfYFUphhOE6cSBTxb2PVOrGr3nHh/K5JMcOxc3SBiJ4gT 9jp/HDyArIKhXBpM871CN0FII5dZAQz61dI/Qk16fZCbaD2sRGs/v7edkeAkl1TAESEo OgMytfMjFdcalV5LUJPfX9JmyLzGnC/I2g0Ex9PB5q0pbYVKcw04cbOPJw137wjOUvpk VC5DCUUZaIbUOv+2v6AKyCnt6nt6aJ6ZK1zDgQjpbyaWrQcnptSrcosyJGJEueUs5NMh 3iZQ== 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=0KbzvPdgC4kdBFqEzh88grrAfpm3ruAqR7MKQDv8kOU=; b=IycCzYJ5YNEi1bruTIqphyWXO8biswhE3tZbiFFkAudn6thLb1YfCGyWiQWM1HG9lV HWXJYDKOSZFbvee4pFfkHnMEBuvaUTD/AkEzkmmKspWDmP9DygCEQaf/iWOsxoxLb32X /MyKR8koivRQD9z3fffiQBa/9RN1h2fGaUq2K1t6ECm5Bi9+NdsfLPHPcUsStbfK8PyN uOkhNyvcCKSp7FWxhzpo0bleCddX57P/kA5JUW6z6XgpFLfLz6RgS7NiliBFu/BXtcGU gIgTPsrB53a9JYZgafzCWV1rKfuFwhCOtU8Bs9wPFDqy2XxCOJV7WbTffDG/+RDWhJ0W KDKQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=p3+1k8xq; 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 b98si31450640plb.375.2019.04.29.07.07.07; Mon, 29 Apr 2019 07:07:24 -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=p3+1k8xq; 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 S1728284AbfD2OFp (ORCPT + 99 others); Mon, 29 Apr 2019 10:05:45 -0400 Received: from mail.kernel.org ([198.145.29.99]:55532 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728239AbfD2OFp (ORCPT ); Mon, 29 Apr 2019 10:05:45 -0400 Received: from localhost (unknown [171.76.113.243]) (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 2F7F421655; Mon, 29 Apr 2019 14:05:43 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1556546744; bh=qVipqbpF74NslrIJAp2+g2vf/JWQWFLexrajOnRDUME=; h=Date:From:To:Cc:Subject:References:In-Reply-To:From; b=p3+1k8xq616yFT7vtr8zz46qwCOa5a6V/y261xa0fS2qnBYuLYJyKsbAYmM7hLitL fjn8DDIuZaH2gGmzjcNxTjXKiK/x1c4nBCPY41rJshPGlL3B1JbdGz1J2YH18KI2J1 vZrKmC68zix+9Akq8rvNGJvMTflpDK+LzAw7mcRU= Date: Mon, 29 Apr 2019 19:35:37 +0530 From: Vinod Koul To: Baolin Wang Cc: Dan Williams , eric.long@unisoc.com, Orson Zhai , Chunyan Zhang , Mark Brown , dmaengine@vger.kernel.org, LKML Subject: Re: [PATCH 4/7] dmaengine: sprd: Add device validation to support multiple controllers Message-ID: <20190429140537.GN3845@vkoul-mobl.Dlink> References: <20190429115723.GK3845@vkoul-mobl.Dlink> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.11.3 (2019-02-01) Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 29-04-19, 20:20, Baolin Wang wrote: > On Mon, 29 Apr 2019 at 19:57, Vinod Koul wrote: > > > > On 15-04-19, 20:14, Baolin Wang wrote: > > > From: Eric Long > > > > > > Since we can support multiple DMA engine controllers, we should add > > > device validation in filter function to check if the correct controller > > > to be requested. > > > > > > Signed-off-by: Eric Long > > > Signed-off-by: Baolin Wang > > > --- > > > drivers/dma/sprd-dma.c | 5 +++++ > > > 1 file changed, 5 insertions(+) > > > > > > diff --git a/drivers/dma/sprd-dma.c b/drivers/dma/sprd-dma.c > > > index 0f92e60..9f99d4b 100644 > > > --- a/drivers/dma/sprd-dma.c > > > +++ b/drivers/dma/sprd-dma.c > > > @@ -1020,8 +1020,13 @@ static void sprd_dma_free_desc(struct virt_dma_desc *vd) > > > static bool sprd_dma_filter_fn(struct dma_chan *chan, void *param) > > > { > > > struct sprd_dma_chn *schan = to_sprd_dma_chan(chan); > > > + struct of_phandle_args *dma_spec = > > > + container_of(param, struct of_phandle_args, args[0]); > > > u32 slave_id = *(u32 *)param; > > > > > > + if (chan->device->dev->of_node != dma_spec->np) > > > > Are you not using of_dma_find_controller() that does this, so this would > > be useless! > > Yes, we can use of_dma_find_controller(), but that will be a little > complicated than current solution. Since we need introduce one > structure to save the node to validate in the filter function like > below, which seems make things complicated. But if you still like to > use of_dma_find_controller(), I can change to use it in next version. Sorry I should have clarified more.. of_dma_find_controller() is called by xlate, so you already run this check, so why use this :) -- ~Vinod