Received: by 2002:a05:6a10:1d13:0:0:0:0 with SMTP id pp19csp955516pxb; Mon, 16 Aug 2021 23:43:52 -0700 (PDT) X-Google-Smtp-Source: ABdhPJz/PkCO+piZfg9PnNsrvrcygHSFKZX/ojs9PFVF8z6BwjnGJ6sYTbyIeFSFKUJyZcBDvH9q X-Received: by 2002:a5e:8e04:: with SMTP id a4mr1805664ion.56.1629182631936; Mon, 16 Aug 2021 23:43:51 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1629182631; cv=none; d=google.com; s=arc-20160816; b=1IsET8Rryw+69tybLhJBDH3YdRhqLyWhq566g5xtzQdwuNVsffmE/ooQAjE9SR1uRC dsq52PQoosYG2XjPftRCJzNybSEejP4vddnbNWQRFFZyQcP93vb58yOUuHuKeOTUs6IH SK0pKkCTIqmZTjH9m5KDSCcy5Ni3Rlb/JrpI+7InhjvFhxZiA4ON/AjOlRVB+vxlK29h 3rNlksQdlZc+7K4wZkguheukolIvDkGXZEHY+KZ1g6x3oripayPJ+v0jOlE/WkZ6VX10 1/DdxV/7GL0s83v1BNxinO9Q2lp7EOQC+rgZVkVgZfYuhBxrE4IkiqEk6NmXA7CrQ6ny rlAg== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:cc:to:subject:message-id:date:from:in-reply-to :references:mime-version:dkim-signature; bh=jkMDlfBl2+pnxiSW6B4dodNG7+PYBe1711RVtroGBcE=; b=R9In8iaIwiD1I+YynFiboOnioEARmtqD0Tr4QGLv2NF3FhM4xEZx4yodPb9KrcTbca Tyf+zRzsdZvVUEEX/bZwJ5CnepQ7NTJxU9IKAWgmm7U5WFl/2NxgCKO7NDJjcNwBwMhv ZSuRRfn4Ne/4r78F3IXPO7LWmGCHbf00JnykljH2vQ6XWLR5EP7pwiiRm+T9PTMnJ6IW qz/JjZCrhW0MU9p0zPddmlx2iNmQR45hxZP/AlR9/rc157cilqSlwrtg9KsyDacMnhIw D2iv59EhOyeLtq4VSgzakhd7njIS3SewG/6Aj674EVKSZ2/ERvkotzFp1daCwt39zghl RcZA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=em7OVWB0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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. [23.128.96.18]) by mx.google.com with ESMTP id z4si1259478ilh.138.2021.08.16.23.43.40; Mon, 16 Aug 2021 23:43:51 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@kernel.org header.s=k20201202 header.b=em7OVWB0; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 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 S234454AbhHQGna (ORCPT + 99 others); Tue, 17 Aug 2021 02:43:30 -0400 Received: from mail.kernel.org ([198.145.29.99]:35484 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S230094AbhHQGna (ORCPT ); Tue, 17 Aug 2021 02:43:30 -0400 Received: by mail.kernel.org (Postfix) with ESMTPSA id AB8B860FD8; Tue, 17 Aug 2021 06:42:57 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=k20201202; t=1629182577; bh=34kp4aM/l1m2Tcf3HPRzMsU+Qjm7SBbDZ+vfVjP0k68=; h=References:In-Reply-To:From:Date:Subject:To:Cc:From; b=em7OVWB0LXXoEkZj+7aVx8B1E1D67tQSL6OX4f+dHqChjCEjhrSAvSok8N3KDb1X+ 8Lz/brwOx2Rcf19O+KjApL8P+bh62fHA6DN24/h9K0J7B5VKQb49oG2Rirv2txSbCc QAMyasSG09HqF85es7WeGM682pqEIetcF0Y+cSKAf7nClOVihor6yDEz7Tj4Sr6duD 3xoYKPE52tpTTFBzHKacv6iElMiH+mLSXaZ+f0TFDBej2Vb2ayxsgUAvjPTQ7G155w JskvhvTbO6PYs/cphBr2W0xSw+8RoiB3RjtCqoFHSTuhpl06l6LnvppvOlmmJ68lGD W3bnCwBqavuhQ== Received: by mail-lj1-f175.google.com with SMTP id d16so13124452ljq.4; Mon, 16 Aug 2021 23:42:57 -0700 (PDT) X-Gm-Message-State: AOAM533LU5yPuPGTG6bxxx1CKy/5eulDPf2z4gOuUtJQQ8oNyEeIdtn9 Bcl8u7ZKQI6HvLJYRIBpWeExVof14vCohgRaV1o= X-Received: by 2002:a05:651c:150a:: with SMTP id e10mr1793800ljf.285.1629182575957; Mon, 16 Aug 2021 23:42:55 -0700 (PDT) MIME-Version: 1.0 References: <20210723214031.3251801-1-atish.patra@wdc.com> In-Reply-To: From: Guo Ren Date: Tue, 17 Aug 2021 14:42:44 +0800 X-Gmail-Original-Message-ID: Message-ID: Subject: Re: [RFC 0/5] Support non-coherent DMA on RISC-V using a global pool To: Atish Patra Cc: Palmer Dabbelt , devicetree , Albert Ou , Tobias Klauser , Robin Murphy , "linux-kernel@vger.kernel.org List" , Rob Herring , Atish Patra , iommu@lists.linux-foundation.org, Guo Ren , Paul Walmsley , linux-riscv , Frank Rowand , Christoph Hellwig , Dmitry Vyukov Content-Type: text/plain; charset="UTF-8" Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Aug 17, 2021 at 11:28 AM Atish Patra wrote: > > On Mon, Aug 16, 2021 at 6:37 PM Guo Ren wrote: > > > > 1 > > > > On Thu, Jul 29, 2021 at 2:19 PM Atish Patra wrote: > > > > > > On Wed, Jul 28, 2021 at 9:30 PM Palmer Dabbelt wrote: > > > > > > > > On Fri, 23 Jul 2021 14:40:26 PDT (-0700), Atish Patra wrote: > > > > > RISC-V privilege specification doesn't define an IOMMU or any method modify > > > > > PMA attributes or PTE entries to allow non-coherent mappings yet. In > > > > > the beginning, this approach was adopted assuming that most of the RISC-V > > > > > platforms would support full cache-coherent IO. Here is excerpt from the > > > > > priv spec section 3.6.5 > > > > > > > > > > "In RISC-V platforms, the use of hardware-incoherent regions is discouraged > > > > > due to software complexity, performance, and energy impacts." > > > > > > > > > > While some of the RISC-V platforms adhere to the above suggestion, not all > > > > > platforms can afford to build to fully cache-coherent I/O devices. To > > > > > address DMA for non-coherent I/O devices, we need to mark a region of memory > > > > > as non-cacheable. Some of the platforms rely on a fixed region of uncached > > > > > memory that is remapped to the system memory while some other modify > > > > > the PTE entries to achieve that. > > > > > > > > > > The patch3 solves the issue for the fist use case by using a global > > > > > pool of memory that is reserved for DMA. The device access the reserved area > > > > > of the region while corresponding CPU address will be from uncached region > > > > > As the uncached region is remapped to the beginning of the system ram, both > > > > > CPU and device get the same view. > > > > > > > > > > To facilitate streaming DMA APIs, patch 1 introduces a set of generic > > > > > cache operations. Any platform can use the generic ops to provide platform > > > > > specific cache management operations. Once the standard RISC-V CMO extension > > > > > is available, it will also use these generic ops. > > > > > > > > > > To address the second use case, Page Based Memory Attribute (PBMT) extension > > > > > is proposed. Once the extension is in good shape, we can leverage that > > > > > using CONFIG_DIRECT_REMAP. Currently, it is selected via a compile time config > > > > > option. We will probably need another arch specific hooks to know if the > > > > > platform supports direct remap at runtime. For RISC-V, it will check the > > > > > presence of PBMT extension while other arch function will simply return true > > > > > > > > IIUC this is another extension that's not yet frozen or implemented in > > > > hardware? Is this one compatible with what's in the c906, or is it > > > > doing things its own way? > > > > > > Hi Palmer, > > > This series doesn't implement the PBMT extension which is still in discussion. > > > It simply reuse the existing non-coherent dma mapping support in > > > upstream kernel and enable > > > it for RISC-V. The current version uses a non-coherent global pool. I > > > will update it to use arch_set_uncached > > > as per Christoph's suggestion. It solves the non-coherent DMA problem > > > for beagleV and not c906. > > > > > > I briefly mentioned the PBMT extension just to provide an idea how the > > > RISC-V Linux kernel > > > can support both unached window and PBMT extension. PBMT extension is > > > planned to be frozen > > > by the end of this year and none of the hardware has implemented it. > > > > > > The implementation in c906 is a non-standard one and will not be > > > supported by the default PBMT > > > extension implementation. > > The default PBMT & c908 PBMT are similar, only BIT definitions are > > different. I propose to support default PBMT first and give the back > > door to modify the PBMT definition during boot. > > The "protection_map[] = (__P000, __P001 ..__S000, __S001)" in > > mm/mmap.c has been modified by arch/mips, arm, sparc, x86, so I think > > it's proper solution direction. > > > > The reset problem is how to passing custom PBMT at the very early boot > > stage. Now I'm trying to use the DTS parsing instead of boot param hdr > > which Anup objected to. > > > > IIRC, c906 has a compatible mode that has the compliant PTE bit modifications. > Can you use that mode iOn the Allwinner D1 board to boot Linux ? I am > not sure if you have any fallback method for non-coherent DMA > if custom DMA_COHERENT bits are not enabled through enhanced mode ? We need custom PBMT(enhanced mode) to enable the dma driver on D1 (GMAC, USB, EMMC) or these drivers couldn't work. D1 hasn't any uncached region in SOC design. > > > ref: https://lore.kernel.org/linux-riscv/1623693067-53886-1-git-send-email-guoren@kernel.org/ > > > > Any comments are welcome. > > > > > > > > > > > > > > > > > if DIRECT_REMAP is enabled. This is required as arious different config > > > > > (DIRECT_REMAP, GLOBAL_POOL) will be enabled in the defconfig so that a > > > > > unified kernel image can boot on all RISC-V platforms. > > > > > > > > > > This patch series depends on Christoph's global pool support series[1]. > > > > > Tested on Qemu, HiFive unleashed and beagleV. This series is also available > > > > > at [2]. > > > > > This series also solves the non-coherent DMA support on beagleV but requires > > > > > additional beagleV specific patches[3] which will be upstreamed soon. > > > > > > > > > > > > > > > [1] https://lists.linuxfoundation.org/pipermail/iommu/2021-July/057266.html > > > > > [2] https://github.com/atishp04/linux/tree/riscv_nc_global_pool > > > > > [3] https://github.com/atishp04/linux/tree/wip_beaglev_dma_nc_global > > > > > > > > > > Atish Patra (5): > > > > > RISC-V: Implement arch_sync_dma* functions > > > > > of: Move of_dma_get_range to of_address.h > > > > > dma-mapping: Enable global non-coherent pool support for RISC-V > > > > > dma-direct: Allocate dma pages directly if global pool allocation > > > > > fails > > > > > RISC-V: Support a new config option for non-coherent DMA > > > > > > > > > > arch/riscv/Kconfig | 8 +++ > > > > > arch/riscv/include/asm/dma-noncoherent.h | 19 +++++++ > > > > > arch/riscv/mm/Makefile | 1 + > > > > > arch/riscv/mm/dma-noncoherent.c | 66 ++++++++++++++++++++++++ > > > > > drivers/of/of_private.h | 10 ---- > > > > > include/linux/of_address.h | 12 +++++ > > > > > kernel/dma/coherent.c | 49 +++++++++++++++--- > > > > > kernel/dma/direct.c | 7 ++- > > > > > 8 files changed, 152 insertions(+), 20 deletions(-) > > > > > create mode 100644 arch/riscv/include/asm/dma-noncoherent.h > > > > > create mode 100644 arch/riscv/mm/dma-noncoherent.c > > > > > > > > Can you guys please make up your minds about how this is going to be > > > > supported at the ISA level? I get a different answer every day here: > > > > sometimes it's that these systems are not compliant, sometimes that > > > > Linux is the compliance suite, sometimes that we're doing an ISA > > > > extension, and sometimes that we're doing the SBI stuff. > > > > > > > > > > I am not sure whom you have talked to. I would be happy to set up a > > > meeting so that everybody is on > > > the same page if you are getting different answers every time. > > > > > > > I don't really care all that much about what the decision is, but it's > > > > impossible to move forward without some semblance of a plan. > > > > > > > > _______________________________________________ > > > > linux-riscv mailing list > > > > linux-riscv@lists.infradead.org > > > > http://lists.infradead.org/mailman/listinfo/linux-riscv > > > > > > > > > > > > -- > > > Regards, > > > Atish > > > _______________________________________________ > > > iommu mailing list > > > iommu@lists.linux-foundation.org > > > https://lists.linuxfoundation.org/mailman/listinfo/iommu > > > > > > > > -- > > Best Regards > > Guo Ren > > > > ML: https://lore.kernel.org/linux-csky/ > > > > -- > Regards, > Atish -- Best Regards Guo Ren ML: https://lore.kernel.org/linux-csky/