Received: by 2002:a05:6a10:9848:0:0:0:0 with SMTP id x8csp309606pxf; Thu, 11 Mar 2021 04:34:49 -0800 (PST) X-Google-Smtp-Source: ABdhPJx9HFopz7Vmoxzk859dlwndpr1oWpmMmxkY6GtYV6foOQVYz1epZ9vlABeHhQ98q3x3lH8S X-Received: by 2002:a05:6402:1613:: with SMTP id f19mr8426044edv.222.1615466089734; Thu, 11 Mar 2021 04:34:49 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1615466089; cv=none; d=google.com; s=arc-20160816; b=rRajN0/q2V939sZgTDlQpxmqm5myT2HboIzLGFW7U75DV1yRAsxTdOXCiDgs9LufXS bIOthQ9WAcEFCx9LmKZiC8b7wBlRjeKbzbuf9HJTGDQhkzNuRey9GSI+SvCLmi8DtKIV rMFrCoKbYUaTQLeSO8vX3UuJQwq2dhWQoQ8vV+CIbUFd0a4FpAt6/fqtxBreUHWDsYvb jPs02mSFHHOuJTKkvUx7rofV7ye3xUQYNnUPfTJ2PLVpK3bKiDnIzu/RhwXw5AqECKuz PU8Vkr0eM30lJi7ZlBgbY/Vi87iZN9B3MNHK+gMXEiT1uU2cLP/C+wQUPLpj4qp+g8ZW rETQ== 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=fWxMM6zzUTg3yn8wKJcnp7pE/vS7KdxtU0r90IqJJGA=; b=tNoO0xBrQQce+q3btt8V0ARUsvNbT7QGTevOxlkPqIm/RTaX1OHRdeICvrI2A/9RTc 5Yf9agc8UJcneYxVHUZ+d5SCJqLI8knMG+2HG6TTP5idz/yruiqqP6ULHaDuxaYVea5/ a0SgjMxQFkp6ejgIusuqIyn0tBeO103ASO5pQ2wI3wfrexloEJMWUkLOkq4JvCX2u/W+ eN6ALJQlAZPIXxEh0ZsKGNDRflXHl/OKUkmMxUqs/VMCXyk2R5vqX0KOaHaiN1dLT+vZ t3gZ7mpuW4FH1WvZeAd87PnEaMY0cqZXiJREJ5dB1dDH9+W6S/UHvPEPwE6b9JUVxRoQ K+YA== 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 p12si1543428edm.494.2021.03.11.04.34.27; Thu, 11 Mar 2021 04:34:49 -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 S232968AbhCKMdP convert rfc822-to-8bit (ORCPT + 99 others); Thu, 11 Mar 2021 07:33:15 -0500 Received: from aposti.net ([89.234.176.197]:47038 "EHLO aposti.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S233243AbhCKMcp (ORCPT ); Thu, 11 Mar 2021 07:32:45 -0500 Date: Thu, 11 Mar 2021 12:32:27 +0000 From: Paul Cercueil Subject: Re: [PATCH v2 3/5] drm: Add and export function drm_gem_cma_mmap_noncoherent To: Christoph Hellwig Cc: Maarten Lankhorst , Maxime Ripard , Thomas Zimmermann , David Airlie , Daniel Vetter , Sam Ravnborg , od@zcrc.me, dri-devel@lists.freedesktop.org, linux-kernel@vger.kernel.org, linux-mips@vger.kernel.org Message-Id: <3I1TPQ.E55GRWWDYVRG@crapouillou.net> In-Reply-To: <20210311122642.GB1739082@infradead.org> References: <20210307202835.253907-1-paul@crapouillou.net> <20210307202835.253907-4-paul@crapouillou.net> <20210311122642.GB1739082@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 jeu. 11 mars 2021 ? 12:26, Christoph Hellwig a ?crit : >> +int drm_gem_cma_mmap_noncoherent(struct drm_gem_object *obj, >> + struct vm_area_struct *vma) >> +{ >> + struct drm_gem_cma_object *cma_obj; >> + unsigned long pfn; >> + int ret; >> + >> + /* >> + * 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_pgoff -= drm_vma_node_start(&obj->vma_node); >> + vma->vm_flags &= ~VM_PFNMAP; >> + vma->vm_page_prot = vm_get_page_prot(vma->vm_flags); >> + >> + cma_obj = to_drm_gem_cma_obj(obj); >> + >> + pfn = PHYS_PFN(dma_to_phys(cma_obj->base.dev->dev, >> cma_obj->paddr)); >> + >> + ret = remap_pfn_range(vma, vma->vm_start, pfn, >> + vma->vm_end - vma->vm_start, >> + vma->vm_page_prot); > > dma_to_phys must not be used by drivers. > > I have a proper helper for this waiting for users: > > http://git.infradead.org/users/hch/misc.git/commitdiff/96a546e7229ec53aadbdb7936d1e5e6cb5958952 > > If you can confirm the helpers works for you I can try to still sneak > it to Linus for 5.12 to ease the merge pain. I can try. How do I get a page pointer from a dma_addr_t? -Paul