Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751702AbcDUHat (ORCPT ); Thu, 21 Apr 2016 03:30:49 -0400 Received: from mail-wm0-f53.google.com ([74.125.82.53]:36712 "EHLO mail-wm0-f53.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751364AbcDUHar (ORCPT ); Thu, 21 Apr 2016 03:30:47 -0400 Date: Thu, 21 Apr 2016 09:30:43 +0200 From: Daniel Vetter To: Noralf =?iso-8859-1?Q?Tr=F8nnes?= Cc: dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, laurent.pinchart@ideasonboard.com, tomi.valkeinen@ti.com, linux-kernel@vger.kernel.org Subject: Re: [PATCH 5/8] fbdev: fb_defio: Export fb_deferred_io_mmap Message-ID: <20160421073043.GX2510@phenom.ffwll.local> Mail-Followup-To: Noralf =?iso-8859-1?Q?Tr=F8nnes?= , dri-devel@lists.freedesktop.org, linux-fbdev@vger.kernel.org, laurent.pinchart@ideasonboard.com, tomi.valkeinen@ti.com, linux-kernel@vger.kernel.org References: <1461165929-11344-1-git-send-email-noralf@tronnes.org> <1461165929-11344-6-git-send-email-noralf@tronnes.org> <20160420174414.GQ2510@phenom.ffwll.local> <5717CB6D.8000708@tronnes.org> MIME-Version: 1.0 Content-Type: text/plain; charset=iso-8859-1 Content-Disposition: inline Content-Transfer-Encoding: 8bit In-Reply-To: <5717CB6D.8000708@tronnes.org> X-Operating-System: Linux phenom 4.4.0-1-amd64 User-Agent: Mutt/1.5.24 (2015-08-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2002 Lines: 43 On Wed, Apr 20, 2016 at 08:33:17PM +0200, Noralf Tr?nnes wrote: > > Den 20.04.2016 19:44, skrev Daniel Vetter: > >On Wed, Apr 20, 2016 at 05:25:26PM +0200, Noralf Tr?nnes wrote: > >>Export fb_deferred_io_mmap so drivers can change vma->vm_page_prot. > >>When the framebuffer memory is allocated using dma_alloc_writecombine() > >>instead of vmalloc(), I get cache syncing problems. > >>This solves it: > >> > >>static int drm_fbdev_cma_deferred_io_mmap(struct fb_info *info, > >> struct vm_area_struct *vma) > >>{ > >> fb_deferred_io_mmap(info, vma); > >> vma->vm_page_prot = pgprot_writecombine(vma->vm_page_prot); > >Hm, do we need pgpropt_writecombine? There recently was some discussion > >(on the arc platform) that fbdev pgprots need to be fixed up in fbdev > >code. I have no idea, just repeating from memory ... > > I need it or else I get partial lines that doesn't get updated on the > display. > fbdev code that doesn't set (struct fb_ops *)->fb_mmap, gets this for free > in the default fb_mmap implementation (drivers/video/fbdev/core/fbmem.c). > It calls fb_pgprotect() at the end which is an architecture specific > function that on many platforms uses pgprot_writecombine(), but not on all. > And looking at some of the fb_mmap implementations, some of them sets > vm_page_prot to nocache for instance, so I think the safest bet is to do > this here and not in the fbdev core. And we can't call fb_pgprotect() from > fb_deferred_io_mmap() either because we don't have access to the file > pointer that powerpc needs. > I think the case you refer to was solved with using fb_pgprotect() for > the platform in question and it didn't involve deferred io. Argh, oh well. I guess another case (besides the mmap thing in udl where the default defio support from fbdev goes boom) where this isn't the most awesome thing ever. Please add your explanation to the commit message for posterity. Thanks, Daniel -- Daniel Vetter Software Engineer, Intel Corporation http://blog.ffwll.ch