From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S941608AbcJYJkS (ORCPT ); Tue, 25 Oct 2016 05:40:18 -0400 Received: from mail-wm0-f67.google.com ([74.125.82.67]:40179 "EHLO mail-wm0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935582AbcJYJkM (ORCPT ); Tue, 25 Oct 2016 05:40:12 -0400 Date: Tue, 25 Oct 2016 11:40:07 +0200 From: Ingo Molnar To: Dave Airlie Cc: mcgrof@suse.com, torvalds@linux-foundation.org, dan.j.williams@intel.com, x86@kernel.org, linux-kernel@vger.kernel.org, dri-devel@lists.freedesktop.org, Toshi Kani , Borislav Petkov , "H. Peter Anvin" , Andy Lutomirski , Denys Vlasenko , Brian Gerst Subject: Re: [PATCH 1/2] x86/io: add interface to reserve io memtype for a resource range. (v1.1) Message-ID: <20161025094007.GA15819@gmail.com> References: <1477290706-7696-1-git-send-email-airlied@redhat.com> <1477290706-7696-2-git-send-email-airlied@redhat.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1477290706-7696-2-git-send-email-airlied@redhat.com> 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 * Dave Airlie wrote: > A recent change to the mm code in: > 87744ab3832b83ba71b931f86f9cfdb000d07da5 > mm: fix cache mode tracking in vm_insert_mixed() > > started enforcing checking the memory type against the registered list for > amixed pfn insertion mappings. It happens that the drm drivers for a number > of gpus relied on this being broken. Currently the driver only inserted > VRAM mappings into the tracking table when they came from the kernel, > and userspace mappings never landed in the table. This led to a regression > where all the mapping end up as UC instead of WC now. > > I've considered a number of solutions but since this needs to be fixed > in fixes and not next, and some of the solutions were going to introduce > overhead that hadn't been there before I didn't consider them viable at > this stage. These mainly concerned hooking into the TTM io reserve APIs, > but these API have a bunch of fast paths I didn't want to unwind to add > this to. > > The solution I've decided on is to add a new API like the arch_phys_wc > APIs (these would have worked but wc_del didn't take a range), and > use them from the drivers to add a WC compatible mapping to the table > for all VRAM on those GPUs. This means we can then create userspace > mapping that won't get degraded to UC. > > v1.1: use CONFIG_X86_PAT > Cc: Toshi Kani > Cc: Borislav Petkov > Cc: H. Peter Anvin > Cc: Andy Lutomirski > Cc: Denys Vlasenko > Cc: Brian Gerst > Cc: x86@kernel.org > Cc: mcgrof@suse.com > Cc: Dan Williams > Signed-off-by: Dave Airlie > --- > arch/x86/include/asm/io.h | 6 ++++++ > arch/x86/mm/pat.c | 13 +++++++++++++ > include/linux/io.h | 13 +++++++++++++ > 3 files changed, 32 insertions(+) These changes look good to me in principle: Acked-by: Ingo Molnar I think it would be best to merge these fixes via the DRM tree? Thanks, Ingo