From mboxrd@z Thu Jan 1 00:00:00 1970 From: Jeremy Fitzhardinge Subject: Re: [PATCH 1 of 4] mm: add a ptep_modify_prot transaction abstraction Date: Wed, 18 Jun 2008 17:15:36 -0700 Message-ID: <4859A528.1010107@goop.org> References: <1213831403.8011.24.camel@pasglop> <4859A149.9090004@goop.org> Mime-Version: 1.0 Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Return-path: In-Reply-To: <4859A149.9090004@goop.org> Sender: linux-kernel-owner@vger.kernel.org To: benh@kernel.crashing.org Cc: xen-devel , Peter Zijlstra , kvm-devel , x86@kernel.org, LKML , Virtualization Mailing List , Hugh Dickins , Ingo Molnar , Linus Torvalds , Thomas Gleixner List-Id: virtualization@lists.linuxfoundation.org Jeremy Fitzhardinge wrote: > Benjamin Herrenschmidt wrote: > >> On Mon, 2008-06-16 at 04:30 -0700, Jeremy Fitzhardinge wrote: >> >> >>> The only current user of this interface is mprotect >>> >>> >> Do you plan to use it with fork ultimately ? >> >> > > Good point, I'd overlooked that. I guess that means using it in > ptep_set_wrprotect(). Along the lines of: --- a/include/asm-x86/pgtable.h Wed Jun 18 13:54:49 2008 -0700 +++ b/include/asm-x86/pgtable.h Wed Jun 18 17:03:39 2008 -0700 @@ -491,7 +491,11 @@ static inline void ptep_set_wrprotect(struct mm_struct *mm, unsigned long addr, pte_t *ptep) { - clear_bit(_PAGE_BIT_RW, (unsigned long *)&ptep->pte); + pte_t pte = ptep_modify_prot_start(mm, addr, ptep); + + pte = pte_wrprotect(pte); + + ptep_modify_prot_commit(mm, addr, ptep, pte); pte_update(mm, addr, ptep); } J