Received: by 2002:a05:6a10:f347:0:0:0:0 with SMTP id d7csp3194995pxu; Tue, 8 Dec 2020 06:05:53 -0800 (PST) X-Google-Smtp-Source: ABdhPJywOT2R8B/GFLsj/ZSE1YkaO6NGzXo2gMNcZ2xEwsbqRI9KUHqEtP4h7NhoagHamxMe8rSh X-Received: by 2002:a17:906:9441:: with SMTP id z1mr24286090ejx.288.1607436353037; Tue, 08 Dec 2020 06:05:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1607436353; cv=none; d=google.com; s=arc-20160816; b=wJJj9dhQzZcmRsbMXtVooBJ4fQxmsKhDZJGK4jH/RDklM/GbZ/MLfAc4JK6spAYiHt y6LlUf2ZOd/n3z88UMcHyxLw1wIdPRfZ6iMKhhAtQBHfSEcBiGH5UylafPp3wi5KnCXA wUGibUVz6YD2EJFccAqryxWr4tV/UEBXhoDtYkbOvy/XG50ClVzXoJmqmaSYRTGj0LcM U6N12NAwrCAuaDVGL7MQTY74oRd3CcbVOytaoif3dRlO32NtkJoHnaW4jeWVxqn14cBv mdCf6uJ0oEb/KWD82JpP2rDA3AExstrXTIwlm5HaOybUZ4NmefIJ56HGgMJNsv0MFR9A 9W/g== 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=6S7hcESSSlEA/2/bZludXDNtIn3PwhUBBt3PlT4otXc=; b=Bp+96vMWfjEUV1n4cSZDXOSt3aDXVsq0uWuV6CnwkShPHYGbeUwifvU3T08bXd434w GR/j3IeLeSMU9K09waZc3xJcX4X3G/a2f89Hh1P7GH0Rk5xa1gvtcnU/09ICQyODcXQy nuOUGP+ivBvoESMk2kELYxPXUIActZ0ujkOmz0KRt7nMz1t+c/UtGTyXZmXKMBzond5D u8NeI0tymQwpIpP8TiYNtp0bI0JkNXRrmgGTKBukGEFd9jKDd70h9ihcZ3IB0PdpdjP6 qvPAOJ6qBfK0hAl0pMvEyokxlTMJolG8rDEIbMA0CMvTfLIw/AMhlA1/Hnlt1pagZtuN lUkQ== 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 l20si10449306edw.0.2020.12.08.06.05.22; Tue, 08 Dec 2020 06:05:53 -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 S1729544AbgLHOBT convert rfc822-to-8bit (ORCPT + 99 others); Tue, 8 Dec 2020 09:01:19 -0500 Received: from aposti.net ([89.234.176.197]:53850 "EHLO aposti.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1728546AbgLHOBT (ORCPT ); Tue, 8 Dec 2020 09:01:19 -0500 Date: Tue, 08 Dec 2020 14:00:22 +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: 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 ? 19:13, Paul Cercueil a ?crit : > 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? Waiting for your input here :) Cheers, -Paul