From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1756882AbbLAUx2 (ORCPT ); Tue, 1 Dec 2015 15:53:28 -0500 Received: from mga02.intel.com ([134.134.136.20]:33411 "EHLO mga02.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1755131AbbLAUx1 (ORCPT ); Tue, 1 Dec 2015 15:53:27 -0500 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.20,370,1444719600"; d="scan'208";a="698184811" Subject: Re: [PATCH 3/9] mm: postpone page table allocation until do_set_pte() To: "Kirill A. Shutemov" , Hugh Dickins , Andrea Arcangeli , Andrew Morton References: <1447889136-6928-1-git-send-email-kirill.shutemov@linux.intel.com> <1447889136-6928-4-git-send-email-kirill.shutemov@linux.intel.com> Cc: Vlastimil Babka , Christoph Lameter , Naoya Horiguchi , Jerome Marchand , linux-kernel@vger.kernel.org, linux-mm@kvack.org From: Dave Hansen Message-ID: <565E08C5.8090607@intel.com> Date: Tue, 1 Dec 2015 12:53:25 -0800 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:38.0) Gecko/20100101 Thunderbird/38.3.0 MIME-Version: 1.0 In-Reply-To: <1447889136-6928-4-git-send-email-kirill.shutemov@linux.intel.com> Content-Type: text/plain; charset=windows-1252 Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/18/2015 03:25 PM, Kirill A. Shutemov wrote: > --- a/mm/filemap.c > +++ b/mm/filemap.c > @@ -2068,11 +2068,6 @@ void filemap_map_pages(struct fault_env *fe, ... > if (file->f_ra.mmap_miss > 0) > file->f_ra.mmap_miss--; > - do_set_pte(fe, page); > + > + fe->address += (iter.index - last_pgoff) << PAGE_SHIFT; > + if (fe->pte) > + fe->pte += iter.index - last_pgoff; > + last_pgoff = iter.index; > + if (do_set_pte(fe, NULL, page)) { > + /* failed to setup page table: giving up */ > + if (!fe->pte) > + break; > + goto unlock; > + } > unlock_page(page); > goto next; Hey Kirill, Is there a case here where do_set_pte() returns an error and _still_ manages to populate fe->pte?