Received: by 2002:a05:6a10:16a7:0:0:0:0 with SMTP id gp39csp743555pxb; Tue, 3 Nov 2020 11:16:35 -0800 (PST) X-Google-Smtp-Source: ABdhPJzMiVrV7cOpoT4U364VhRBFQtQ4Yy5IkJPLBHWx8BzEfgVTNBT7iR8yZ64mA09P6Y+2bZ2C X-Received: by 2002:a17:906:a28f:: with SMTP id i15mr22929054ejz.468.1604430994836; Tue, 03 Nov 2020 11:16:34 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1604430994; cv=none; d=google.com; s=arc-20160816; b=1K5/wc+gyf3AUBNqX+ABUXZ9Ca1CzQWm44nsXpZ5UHnQfHFEx9ahXFQ8mBdBKBh4Nc /ZNKvTWY3w+0D7L83txmwvjITMPbfjEywKzs09ptRFurA9msYVE4ur/nJEUT20dUzBVZ r/Z0B8x7dQfPpCWHDKg99UWwclAfs8P1H7YrsDCcOrjc2ceQzA2e+8V3lrSq5P3XKSYt I5Ow7IPIpguXSbrqpz8jifO4ecqcmjCV2frIM9Vemam59SQ3n80Y6rXOlmhxEfsILgTg j/lV4iy/5VyQzknRWKIOuzrN0CuYEDCnwhpwgo9ohQMiJOeHTvix7e6THrBPIPfFjTi0 kvUg== 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:cc:to:subject:from:date; bh=vvrAGaAeUuQPy0YUD0xOFpB7RNEK/ctn0nyOQSvUDv8=; b=BdemjY3PkflBhncESvuFj7EkRzMIrsrB3bJdis6tape+ROwitEnLMqkTPBhkwcoaey /V8roUkm5owylbHPBDvppnAftn9GsJQLPOOfUtxzi215Gm5KMV5I27/FzTJznA5z6iMc SwSvzQDyJAfYPe4ECuT9IEuzLYoXxtGjXQzkVpwqecMF2bl97KDgCL9lc9JxXIaswXAv oiVfRtMwrG5g3HAkhn6VNv7XIQ3m/e4Ia7P0QCgu9qa/PZYPmaroq/X0hops/rc04xfs hhNQyZ+ULVftqgXYcsgYTFCSvkwalQMVFNAmqCjJvXD9Jeqs/s6TSeaaG4QCWPF/GkBg nJ9g== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id jr1si14273080ejb.164.2020.11.03.11.16.10; Tue, 03 Nov 2020 11:16:34 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=crapouillou.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727883AbgKCTNq convert rfc822-to-8bit (ORCPT + 99 others); Tue, 3 Nov 2020 14:13:46 -0500 Received: from aposti.net ([89.234.176.197]:41592 "EHLO aposti.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725957AbgKCTNq (ORCPT ); Tue, 3 Nov 2020 14:13:46 -0500 Date: Tue, 03 Nov 2020 19:13:27 +0000 From: Paul Cercueil Subject: Re: [PATCH 3/5] drm: Add and export =?UTF-8?Q?function=0D=0A?= drm_gem_cma_mmap_noncoherent To: Christoph Hellwig Cc: David Airlie , Daniel Vetter , Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , od@zcrc.me, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org Message-Id: In-Reply-To: <20201103185058.GA20134@infradead.org> References: <20201102220651.22069-1-paul@crapouillou.net> <20201102220651.22069-4-paul@crapouillou.net> <20201103185058.GA20134@infradead.org> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1; format=flowed Content-Transfer-Encoding: 8BIT Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Hi Christoph, Le mar. 3 nov. 2020 ? 18:50, Christoph Hellwig a ?crit : > On Mon, Nov 02, 2020 at 10:06:49PM +0000, Paul Cercueil wrote: >> This function can be used by drivers that need to mmap dumb buffers >> created with non-coherent backing memory. >> >> Signed-off-by: Paul Cercueil >> --- >> drivers/gpu/drm/drm_gem_cma_helper.c | 39 >> ++++++++++++++++++++++++++++ >> include/drm/drm_gem_cma_helper.h | 2 ++ >> 2 files changed, 41 insertions(+) >> >> diff --git a/drivers/gpu/drm/drm_gem_cma_helper.c >> b/drivers/gpu/drm/drm_gem_cma_helper.c >> index 3bdd67795e20..4ed63f4896bd 100644 >> --- a/drivers/gpu/drm/drm_gem_cma_helper.c >> +++ b/drivers/gpu/drm/drm_gem_cma_helper.c >> @@ -387,6 +387,45 @@ int drm_gem_cma_mmap(struct file *filp, struct >> vm_area_struct *vma) >> } >> EXPORT_SYMBOL_GPL(drm_gem_cma_mmap); >> >> +/** >> + * drm_gem_cma_mmap_noncoherent - memory-map a CMA GEM object with >> + * non-coherent cache attribute >> + * @filp: file object >> + * @vma: VMA for the area to be mapped >> + * >> + * Just like drm_gem_cma_mmap, but for a GEM object backed by >> non-coherent >> + * memory. >> + * >> + * Returns: >> + * 0 on success or a negative error code on failure. >> + */ >> +int drm_gem_cma_mmap_noncoherent(struct file *filp, struct >> vm_area_struct *vma) >> +{ >> + struct drm_gem_cma_object *cma_obj; >> + int ret; >> + >> + ret = drm_gem_mmap(filp, vma); >> + if (ret) >> + return ret; >> + >> + cma_obj = to_drm_gem_cma_obj(vma->vm_private_data); >> + >> + /* >> + * Clear the VM_PFNMAP flag that was set by drm_gem_mmap(), and >> set the >> + * vm_pgoff (used as a fake buffer offset by DRM) to 0 as we want >> to map >> + * the whole buffer. >> + */ >> + vma->vm_flags &= ~VM_PFNMAP; >> + vma->vm_pgoff = 0; >> + vma->vm_page_prot = vm_get_page_prot(vma->vm_flags); >> + >> + return remap_pfn_range(vma, vma->vm_start, >> + cma_obj->paddr >> PAGE_SHIFT, >> + vma->vm_end - vma->vm_start, >> + vma->vm_page_prot); > > Per patch 1 cma_obj->paddr is the dma address, while remap_pfn_range > expects a physical address. This does not work. Ok, what would be the correct way to mmap_noncoherent? -Paul