Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1759915AbZC1Cf4 (ORCPT ); Fri, 27 Mar 2009 22:35:56 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S1752284AbZC1Cfs (ORCPT ); Fri, 27 Mar 2009 22:35:48 -0400 Received: from outbound-mail-03.bluehost.com ([69.89.21.13]:51338 "HELO outbound-mail-03.bluehost.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with SMTP id S1751310AbZC1Cfr (ORCPT ); Fri, 27 Mar 2009 22:35:47 -0400 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=default; d=virtuousgeek.org; h=Received:Date:From:To:Cc:Subject:Message-ID:In-Reply-To:References:X-Mailer:Mime-Version:Content-Type:Content-Transfer-Encoding:X-Identified-User; b=sDCqq83JMhSRtttNAVfTCeDmgursXAo2MQPvuEmMvb0ZPJu1izSf7DzsrqTwgpWl/RvweobEBakyKfb+aQq6cALwI/549Ivb5lJQDn7CnQcjBlMaYns7kYLnBfosp/m4; Date: Fri, 27 Mar 2009 19:35:42 -0700 From: Jesse Barnes To: Peter Zijlstra Cc: Eric Anholt , linux-kernel@vger.kernel.org, dri-devel@lists.sourceforge.net Subject: Re: [PATCH 1/6] drm/i915: Fix lock order reversal in GTT pwrite path. Message-ID: <20090327193542.28ffcc10@hobbes> In-Reply-To: <1238201672.4039.396.camel@laptop> References: <1238017510-26784-1-git-send-email-eric@anholt.net> <1238017510-26784-2-git-send-email-eric@anholt.net> <20090326174320.4f16c822@hobbes> <1238201672.4039.396.camel@laptop> X-Mailer: Claws Mail 3.5.0 (GTK+ 2.14.4; x86_64-pc-linux-gnu) Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit X-Identified-User: {10642:box514.bluehost.com:virtuous:virtuousgeek.org} {sentby:smtp auth 75.111.28.251 authed with jbarnes@virtuousgeek.org} Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Content-Length: 2315 Lines: 54 On Sat, 28 Mar 2009 01:54:32 +0100 Peter Zijlstra wrote: > On Thu, 2009-03-26 at 17:43 -0700, Jesse Barnes wrote: > > On Wed, 25 Mar 2009 14:45:05 -0700 > > Eric Anholt wrote: > > > > > Since the pagefault path determines that the lock order we use > > > has to be mmap_sem -> struct_mutex, we can't allow page faults to > > > occur while the struct_mutex is held. To fix this in pwrite, we > > > first try optimistically to see if we can copy from user without > > > faulting. If it fails, fall back to using get_user_pages to pin > > > the user's memory, and map those pages atomically when copying it > > > to the GPU. > > > > > > Signed-off-by: Eric Anholt > > > --- > > > + /* Pin the user pages containing the data. We can't > > > fault while > > > + * holding the struct mutex, and all of the pwrite > > > implementations > > > + * want to hold it while dereferencing the user data. > > > + */ > > > + first_data_page = data_ptr / PAGE_SIZE; > > > + last_data_page = (data_ptr + args->size - 1) / PAGE_SIZE; > > > + num_pages = last_data_page - first_data_page + 1; > > > + > > > + user_pages = kcalloc(num_pages, sizeof(struct page *), > > > GFP_KERNEL); > > > + if (user_pages == NULL) > > > + return -ENOMEM; > > > > If kmalloc limits us to a 128k allocation (and maybe less under > > pressure), then we'll be limited to 128k/8 page pointers on 64 bit, > > or 64M per pwrite... Is that ok? Or do we need to handle multiple > > passes here? > > While officially supported, a 128k kmalloc is _very_ likely to fail, > it would require an order 5 page allocation to back that, and that is > well outside of comfortable. Yeah, my "and maybe less" could have been worded a tad more strongly. ;) Do we have stats on which kmalloc buckets have available allocations anywhere for machines under various workloads? I know under heavy pressure even 8k allocations can fail, but since this is a GFP_KERNEL things should be a *little* better. -- Jesse Barnes, Intel Open Source Technology Center -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/