From mboxrd@z Thu Jan 1 00:00:00 1970 From: Zachary Amsden Subject: Re: [patch 5/9] Guest page hinting: mlocked pages. Date: Wed, 13 Sep 2006 18:22:01 -0700 Message-ID: <4508AEB9.4080409@vmware.com> References: <20060901111022.GF15684@skybase> Mime-Version: 1.0 Content-Type: text/plain; charset="iso-8859-1" Content-Transfer-Encoding: quoted-printable Return-path: In-Reply-To: <20060901111022.GF15684@skybase> List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Sender: virtualization-bounces@lists.osdl.org Errors-To: virtualization-bounces@lists.osdl.org To: Martin Schwidefsky Cc: akpm@osdl.org, virtualization@lists.osdl.org, frankeh@watson.ibm.com, rhim@cc.gateh.edu, nickpiggin@yahoo.com.au, linux-kernel@vger.kernel.org List-Id: virtualization@lists.linuxfoundation.org Martin Schwidefsky wrote: > diff -urpN linux-2.6/mm/memory.c linux-2.6-patched/mm/memory.c > --- linux-2.6/mm/memory.c 2006-09-01 12:50:24.000000000 +0200 > +++ linux-2.6-patched/mm/memory.c 2006-09-01 12:50:24.000000000 +0200 > @@ -2523,6 +2523,31 @@ int make_pages_present(unsigned long add > BUG_ON(addr >=3D end); > BUG_ON(end > vma->vm_end); > len =3D (end+PAGE_SIZE-1)/PAGE_SIZE-addr/PAGE_SIZE; > + > + if (page_host_discards() && (vma->vm_flags & VM_LOCKED)) { > + int rlen =3D len; > + ret =3D 0; > + while (rlen > 0) { > + struct page *page_refs[32]; > + int chunk, cret, i; > + > + chunk =3D rlen < 32 ? rlen : 32; > + cret =3D get_user_pages(current, current->mm, addr, > + chunk, write, 0, > + page_refs, NULL); > + if (cret > 0) { > + for (i =3D 0; i < cret; i++) > + page_cache_release(page_refs[i]); > + ret +=3D cret; > + } > + if (cret < chunk) > + return ret ? : cret; > + addr +=3D 32*PAGE_SIZE; > + rlen -=3D 32; > + } > + return ret =3D=3D len ? 0 : -1; > + } > + > ret =3D get_user_pages(current, current->mm, addr, > len, write, 0, NULL, NULL); > if (ret < 0) > = This seems like a bit of unneeded complexity. Since you've already = changed get_user_pages, why not add a follow flag to release the page = cache, and simply pass it to get_user_pages, instead of trying to fetch = the page list back. In particular, write and force arguments to = get_user_pages look very ripe for combining into a flags field. Sure, = get_user_pages now has a bit more work to do, but it is already a = monster, and I think it would keep make_page_present much cleaner. Zach Zach