Received: by 2002:a05:6a10:2726:0:0:0:0 with SMTP id ib38csp5649466pxb; Mon, 28 Mar 2022 15:29:59 -0700 (PDT) X-Google-Smtp-Source: ABdhPJwVTCf+LVxkfq0rSfgkMXkVR7YMW4tAJAHTZz+N7gS5GgGzGLO+a1RJek2sW6aygAYwe+y1 X-Received: by 2002:a05:620a:34e:b0:67b:164d:a631 with SMTP id t14-20020a05620a034e00b0067b164da631mr17901483qkm.23.1648506599595; Mon, 28 Mar 2022 15:29:59 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1648506599; cv=none; d=google.com; s=arc-20160816; b=sNIrwG/AfdekwrdCVAuLzjqW6+DoBfPKwbnYGP39az6bMNCjwwX5STc/obvON6C1mu 4HpZHG1Yuo2mzGlB+XUvZsM04l+CBejqd+bHNNRUK+HsSBhkkCOzXXahY7+C8tJmXTpI 0uVCobNmNRTMENi4mJPY53JlUmVg9Y4hWGwlaGoMLkI4JZ1Sqw/364yPTafdZti0TrY9 r70iogS2yzlNrpzz3BuVQwAPAXl9+NnZcnelZIMJWMd2f1J8JRYjkJsJJ7vgWaFBjpPu T2Z0VCphB//Co/vwODOS6sDuypyneiUo4wO52VBJ5R8pW++caJZRaHUp0qKJt3ygTXpN DoTg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :references:in-reply-to:message-id:date:subject:cc:to:from :dkim-signature:dkim-filter; bh=9SPPRQfYXqos/xXWWQfUIiy2dltWIdc2l/4SV3Of+L8=; b=vMg8dxMp5xcioOB7fQs8IcD/2Ohe6i7hK+HWTW5JhTRsYo5M/BKS+PizPrX3R2bCNV m5PxTpr7F9bpOxouy8a/6IoICI94RF83OqnUp3gI1KRHvoSH9lDkpd4t5XiPaGO6yJ+t 6gQBpKCwHvBGKVfdbpPGgB8o8XWj5Zz5fSisfJPgcppBE2/qW9kTl1LEAopkb4BWi6ud CS4Xug5qO9Il4Q07zZkUrrjBniniA1NUpNLIzbBQVMrtRhK88Ci4JP5HF3xa0PhxYEcG uOH29MQNq7/uJYXtT8EsRbEg6HbXI3fQnlU7zF2Qu6qhJfOIna0BHHGK0YfWCEC2279N ZAqQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b="U+76/Bpf"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Return-Path: Received: from lindbergh.monkeyblade.net (lindbergh.monkeyblade.net. [23.128.96.19]) by mx.google.com with ESMTPS id h1-20020a67b701000000b00324c5c3bfacsi3293506vsf.494.2022.03.28.15.29.59 (version=TLS1_3 cipher=TLS_AES_256_GCM_SHA384 bits=256/256); Mon, 28 Mar 2022 15:29:59 -0700 (PDT) Received-SPF: softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) client-ip=23.128.96.19; Authentication-Results: mx.google.com; dkim=pass header.i=@baikalelectronics.ru header.s=mail header.b="U+76/Bpf"; spf=softfail (google.com: domain of transitioning linux-kernel-owner@vger.kernel.org does not designate 23.128.96.19 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org Received: from vger.kernel.org (vger.kernel.org [23.128.96.18]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id 74C891AA06B; Mon, 28 Mar 2022 14:42:32 -0700 (PDT) Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S243314AbiC1QqQ (ORCPT + 99 others); Mon, 28 Mar 2022 12:46:16 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44352 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242660AbiC1Qpz (ORCPT ); Mon, 28 Mar 2022 12:45:55 -0400 Received: from mail.baikalelectronics.ru (mail.baikalelectronics.com [87.245.175.226]) by lindbergh.monkeyblade.net (Postfix) with ESMTP id D1F4421246; Mon, 28 Mar 2022 09:44:07 -0700 (PDT) Received: from mail.baikalelectronics.ru (unknown [192.168.51.25]) by mail.baikalelectronics.ru (Postfix) with ESMTP id 348211E495D; Thu, 24 Mar 2022 04:48:55 +0300 (MSK) DKIM-Filter: OpenDKIM Filter v2.11.0 mail.baikalelectronics.ru 348211E495D DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=baikalelectronics.ru; s=mail; t=1648086535; bh=9SPPRQfYXqos/xXWWQfUIiy2dltWIdc2l/4SV3Of+L8=; h=From:To:CC:Subject:Date:In-Reply-To:References:From; b=U+76/BpfTNVjj2/LrtAZkiu6zTfxaNNdNJs1UFeTaUJPp9ltn5HI/uoY4fx2HJ8Hw cPbj+O+3w1WocZap4Q6GIfF5OCCb0sPoE+8/H9kPvuCO6gR3VCwkSKZ16DhDj51gWF JqYmjaH9/k0Ty6agwY3hQNMaxxpkLnkVF/E1rEKU= Received: from localhost (192.168.168.10) by mail (192.168.51.25) with Microsoft SMTP Server (TLS) id 15.0.1395.4; Thu, 24 Mar 2022 04:48:54 +0300 From: Serge Semin To: Gustavo Pimentel , Vinod Koul , Jingoo Han , Bjorn Helgaas , Frank Li , Manivannan Sadhasivam CC: Serge Semin , Serge Semin , Alexey Malahov , Pavel Parkhomenko , Lorenzo Pieralisi , Rob Herring , =?UTF-8?q?Krzysztof=20Wilczy=C5=84ski?= , , , Subject: [PATCH 23/25] dmaengine: dw-edma: Bypass dma-ranges mapping for the local setup Date: Thu, 24 Mar 2022 04:48:34 +0300 Message-ID: <20220324014836.19149-24-Sergey.Semin@baikalelectronics.ru> In-Reply-To: <20220324014836.19149-1-Sergey.Semin@baikalelectronics.ru> References: <20220324014836.19149-1-Sergey.Semin@baikalelectronics.ru> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Content-Type: text/plain X-ClientProxiedBy: MAIL.baikal.int (192.168.51.25) To mail (192.168.51.25) X-Spam-Status: No, score=-2.0 required=5.0 tests=BAYES_00,DKIM_SIGNED, DKIM_VALID,DKIM_VALID_AU,HEADER_FROM_DIFFERENT_DOMAINS, MAILING_LIST_MULTI,RDNS_NONE,SPF_HELO_NONE,T_SCC_BODY_TEXT_LINE autolearn=no autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org DW eDMA doesn't perform any translation of the traffic generated on the CPU/Application side. It just generates read/write AXI-bus requests with the specified addresses. But in case if the dma-ranges DT-property is specified for a platform device node, Linux will use it to map the CPU memory regions into the DMAable bus ranges. This isn't what we want for the eDMA embedded into the locally accessed DW PCIe Root Port and End-point. In order to work that around let's set the chan_dma_dev flag for each DW eDMA channel thus forcing the client drivers to getting a custom dma-ranges-less parental device for the mappings. Note it will only work for the client drivers using the dmaengine_get_dma_device() method to get the parental DMA device. Signed-off-by: Serge Semin --- drivers/dma/dw-edma/dw-edma-core.c | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/drivers/dma/dw-edma/dw-edma-core.c b/drivers/dma/dw-edma/dw-edma-core.c index 72a51970bfba..ca5cd7c99571 100644 --- a/drivers/dma/dw-edma/dw-edma-core.c +++ b/drivers/dma/dw-edma/dw-edma-core.c @@ -716,6 +716,21 @@ static int dw_edma_alloc_chan_resources(struct dma_chan *dchan) if (chan->status != EDMA_ST_IDLE) return -EBUSY; + /* Bypass the dma-ranges based memory regions mapping since the + * inbound iATU only affects the traffic incoming from the + * PCIe bus. + */ + if (chan->dw->chip->flags & DW_EDMA_CHIP_LOCAL) { + dchan->dev->chan_dma_dev = true; + + dchan->dev->device.dma_coherent = chan->dw->chip->dev->dma_coherent; + dma_coerce_mask_and_coherent(&dchan->dev->device, + dma_get_mask(chan->dw->chip->dev)); + dchan->dev->device.dma_parms = chan->dw->chip->dev->dma_parms; + } else { + dchan->dev->chan_dma_dev = false; + } + pm_runtime_get(chan->dw->chip->dev); return 0; -- 2.35.1