Received: by 2002:a05:6a10:22f:0:0:0:0 with SMTP id 15csp4737059pxk; Wed, 30 Sep 2020 10:19:36 -0700 (PDT) X-Google-Smtp-Source: ABdhPJypNcQgzGdyydd6T8bO7qgyX8mIWFVhUrV5N27wejWlpr2rwBDyeknidSgoctWZNTICURth X-Received: by 2002:a05:6402:1859:: with SMTP id v25mr3984454edy.118.1601486376023; Wed, 30 Sep 2020 10:19:36 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1601486376; cv=none; d=google.com; s=arc-20160816; b=UUJVfoQOnqyZaKZF4z6bWkE1ZQfrrPPkFw7BTwSqzm7Vp75NkH9I1jBIlWuP0AZdEP EUAo6c8UV4aspYVjZ1Dh9cECiLlz8WSpGAWBrkv7a3qZseLi76+aNkEAOtMoNaxYMRNb Csozf5QsyN5GOTbDwbSsJz61696E7tFYECgCtDeEeyodh0ow0eeepU7WaGlMLkYkrYMS 3YU1k2ux1o5NhJ5E6mMoKrN5vnC43QudOJcRC1rmeXc9/yNJoky9zJnWhcZwqF7faR4E 6CPwTHHofPcsYFDU1Ewsw7BhwjI7eXy7SbpwM/3eVJErbrIhaeqv3/tWC6uJyW/0QSi9 Vqyg== 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; bh=pIdTpoIPruFr7zDIb5GEOw9aXWxj4OPiHxHv5ba4g4M=; b=OMeRuvlgaUI7RBcnlmMifX90IkniAbS1vM+BQB2sPbPvBJh58k7lSK0ECVAYIgASih 46KXHOL4v8hMJJ0M1VxRPwMUBre/SYWFUNSSa+1GESgMJVVxVOufGpdeLBA1sWEOYbGM Xb0WE1ljNaSflcpe1yDRlfEwYHU1nVnm25zs0LGBiQ1pPPobRh2UgoI/DlN0uhwVGaTg 0LG4SLtiCxopF0UyiQqRddIMumpt9sIf1Tya12uwdtOSV24gTctyz4MnEH2dcQFreHcZ KpoPuKxa9iBYzTxrNtjuuRwvfJUTYSemPxK1UABYfGRLZzGpFyLqM030s9zC/986NLYG i59A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@crapouillou.net header.s=mail header.b=OsmF8Szl; 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=crapouillou.net Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id s19si1516894edx.480.2020.09.30.10.19.13; Wed, 30 Sep 2020 10:19:36 -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=@crapouillou.net header.s=mail header.b=OsmF8Szl; 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=crapouillou.net Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1731529AbgI3RRQ (ORCPT + 99 others); Wed, 30 Sep 2020 13:17:16 -0400 Received: from crapouillou.net ([89.234.176.41]:33972 "EHLO crapouillou.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731500AbgI3RRH (ORCPT ); Wed, 30 Sep 2020 13:17:07 -0400 DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=crapouillou.net; s=mail; t=1601486219; h=from:from:sender:reply-to:subject:subject:date:date: message-id:message-id:to:to:cc:cc:mime-version:mime-version: content-type:content-transfer-encoding:content-transfer-encoding: in-reply-to:in-reply-to:references:references; bh=pIdTpoIPruFr7zDIb5GEOw9aXWxj4OPiHxHv5ba4g4M=; b=OsmF8Szlaf1dkvepalM6e6Wg9Av0V4QRmzmc4gtuZGzQgljOp2uaP/tpzHshzIdOzpy3xt BZwh6RSsb/u80Di9iucXTw/aoKPwww71tbT5kOhmLhvVmhxSnhzErpgtv+fIG0T+M/KDzQ C9rg6fxTyXIAiGBmhz6S+sPSucmC3UU= From: Paul Cercueil To: Christoph Hellwig Cc: Stephen Rothwell , Dave Airlie , DRI , Linux Next Mailing List , Linux Kernel Mailing List , Paul Cercueil Subject: [PATCH 2/3] drm/ingenic: Update code to mmap GEM buffers cached Date: Wed, 30 Sep 2020 19:16:43 +0200 Message-Id: <20200930171644.299363-2-paul@crapouillou.net> In-Reply-To: <20200930165212.GA8833@lst.de> References: <20200930165212.GA8833@lst.de> MIME-Version: 1.0 Content-Transfer-Encoding: 8bit Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org The DMA API changed at the same time commit 37054fc81443 ("gpu/drm: ingenic: Add option to mmap GEM buffers cached") was added. Rework the code to work with the new DMA API. Signed-off-by: Paul Cercueil --- drivers/gpu/drm/ingenic/ingenic-drm-drv.c | 24 +++++++---------------- 1 file changed, 7 insertions(+), 17 deletions(-) diff --git a/drivers/gpu/drm/ingenic/ingenic-drm-drv.c b/drivers/gpu/drm/ingenic/ingenic-drm-drv.c index 0225dc1f5eb8..07a1da7266e4 100644 --- a/drivers/gpu/drm/ingenic/ingenic-drm-drv.c +++ b/drivers/gpu/drm/ingenic/ingenic-drm-drv.c @@ -526,12 +526,10 @@ void ingenic_drm_sync_data(struct device *dev, struct drm_plane_state *state) { const struct drm_format_info *finfo = state->fb->format; - struct ingenic_drm *priv = dev_get_drvdata(dev); struct drm_atomic_helper_damage_iter iter; unsigned int offset, i; struct drm_rect clip; dma_addr_t paddr; - void *addr; if (!ingenic_drm_cached_gem_buf) return; @@ -541,12 +539,11 @@ void ingenic_drm_sync_data(struct device *dev, drm_atomic_for_each_plane_damage(&iter, &clip) { for (i = 0; i < finfo->num_planes; i++) { paddr = drm_fb_cma_get_gem_addr(state->fb, state, i); - addr = phys_to_virt(paddr); /* Ignore x1/x2 values, invalidate complete lines */ offset = clip.y1 * state->fb->pitches[i]; - dma_cache_sync(priv->dev, addr + offset, + dma_sync_single_for_device(dev, paddr + offset, (clip.y2 - clip.y1) * state->fb->pitches[i], DMA_TO_DEVICE); } @@ -766,14 +763,6 @@ static int ingenic_drm_gem_mmap(struct drm_gem_object *obj, struct vm_area_struct *vma) { struct drm_gem_cma_object *cma_obj = to_drm_gem_cma_obj(obj); - struct device *dev = cma_obj->base.dev->dev; - unsigned long attrs; - int ret; - - if (ingenic_drm_cached_gem_buf) - attrs = DMA_ATTR_NON_CONSISTENT; - else - attrs = DMA_ATTR_WRITE_COMBINE; /* * Clear the VM_PFNMAP flag that was set by drm_gem_mmap(), and set the @@ -784,12 +773,13 @@ static int ingenic_drm_gem_mmap(struct drm_gem_object *obj, vma->vm_pgoff = 0; vma->vm_page_prot = vm_get_page_prot(vma->vm_flags); - ret = dma_mmap_attrs(dev, vma, cma_obj->vaddr, cma_obj->paddr, - vma->vm_end - vma->vm_start, attrs); - if (ret) - drm_gem_vm_close(vma); + if (!ingenic_drm_cached_gem_buf) + vma->vm_page_prot = pgprot_writecombine(vma->vm_page_prot); - return ret; + return remap_pfn_range(vma, vma->vm_start, + cma_obj->paddr >> PAGE_SHIFT, + vma->vm_end - vma->vm_start, + vma->vm_page_prot); } static int ingenic_drm_gem_cma_mmap(struct file *filp, -- 2.28.0