From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mga04.intel.com ([192.55.52.120]:17109 "EHLO mga04.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933992AbeGCQr5 (ORCPT ); Tue, 3 Jul 2018 12:47:57 -0400 Date: Tue, 3 Jul 2018 10:47:54 -0600 From: Ross Zwisler To: Dan Williams Cc: mingo@kernel.org, Al Viro , Andrew Morton , Andy Lutomirski , Borislav Petkov , Linus Torvalds , Peter Zijlstra , Thomas Gleixner , Tony Luck , Ross Zwisler , linux-kernel@vger.kernel.org, linux-fsdevel@vger.kernel.org, x86@kernel.org Subject: Re: [PATCH] x86/asm/memcpy_mcsafe: Fix copy_to_user_mcsafe() exception handling Message-ID: <20180703164754.GB30451@linux.intel.com> References: <20180702165803.GB19488@linux.intel.com> <153056565378.3420.295180898468362039.stgit@dwillia2-desk3.amr.corp.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <153056565378.3420.295180898468362039.stgit@dwillia2-desk3.amr.corp.intel.com> Sender: linux-fsdevel-owner@vger.kernel.org List-ID: On Mon, Jul 02, 2018 at 02:16:10PM -0700, Dan Williams wrote: > All copy_to_user() implementations need to be prepared to handle faults > accessing userspace. The __memcpy_mcsafe() implementation handles both > mmu-faults on the user destination and machine-check-exceptions on the > source buffer. However, the memcpy_mcsafe() wrapper may silently > fallback to memcpy() depending on build options and cpu-capabilities. > > Force copy_to_user_mcsafe() to always use __memcpy_mcsafe() when > available, and otherwise disable all of the copy_to_user_mcsafe() > infrastructure when __memcpy_mcsafe() is not available, i.e. > CONFIG_X86_MCE=n. > > This fixes crashes of the form: > run fstests generic/323 at 2018-07-02 12:46:23 > BUG: unable to handle kernel paging request at 00007f0d50001000 > RIP: 0010:__memcpy+0x12/0x20 > [..] > Call Trace: > copyout_mcsafe+0x3a/0x50 > _copy_to_iter_mcsafe+0xa1/0x4a0 > ? dax_alive+0x30/0x50 > dax_iomap_actor+0x1f9/0x280 > ? dax_iomap_rw+0x100/0x100 > iomap_apply+0xba/0x130 > ? dax_iomap_rw+0x100/0x100 > dax_iomap_rw+0x95/0x100 > ? dax_iomap_rw+0x100/0x100 > xfs_file_dax_read+0x7b/0x1d0 [xfs] > xfs_file_read_iter+0xa7/0xc0 [xfs] > aio_read+0x11c/0x1a0 > > Fixes: 8780356ef630 ("x86/asm/memcpy_mcsafe: Define copy_to_iter_mcsafe()") > Cc: Al Viro > Cc: Andrew Morton > Cc: Andy Lutomirski > Cc: Borislav Petkov > Cc: Linus Torvalds > Cc: Peter Zijlstra > Cc: Thomas Gleixner > Cc: Tony Luck > Reported-by: Ross Zwisler > Signed-off-by: Dan Williams Tested-by: Ross Zwisler