From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S261177AbVFTLaX (ORCPT ); Mon, 20 Jun 2005 07:30:23 -0400 Received: (majordomo@vger.kernel.org) by vger.kernel.org id S261189AbVFTLaX (ORCPT ); Mon, 20 Jun 2005 07:30:23 -0400 Received: from wproxy.gmail.com ([64.233.184.198]:13755 "EHLO wproxy.gmail.com") by vger.kernel.org with ESMTP id S261177AbVFTLaL convert rfc822-to-8bit (ORCPT ); Mon, 20 Jun 2005 07:30:11 -0400 DomainKey-Signature: a=rsa-sha1; q=dns; c=nofws; s=beta; d=gmail.com; h=received:message-id:date:from:reply-to:to:subject:cc:in-reply-to:mime-version:content-type:content-transfer-encoding:content-disposition:references; b=YKejgKd/1ox7nfTy5Y5p+zcSy8uGL+a7N4SMAEBOgDqSqrYyxsOcYxaYVMUc6BwZrPTycDxj8C7rCz3xxUJNi8p+v6JBhKbNRlRCGrpN+7JiEVtVf9CfF8cxigvoD7RGLHCInuCc7f/aHFVUyxuLAmK85V7NWupEdOZzrGw+PK0= Message-ID: <3f250c71050620043066ff0262@mail.gmail.com> Date: Mon, 20 Jun 2005 07:30:10 -0400 From: Mauricio Lin Reply-To: Mauricio Lin To: Carsten Otte Subject: Re: How to identify cow (copy-on-write) pages during kernel execution? Cc: linux-kernel@vger.kernel.org In-Reply-To: <5c77e707050620040930b4d0cf@mail.gmail.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7BIT Content-Disposition: inline References: <3f250c7105061922454dfe31ed@mail.gmail.com> <5c77e707050620040930b4d0cf@mail.gmail.com> Sender: linux-kernel-owner@vger.kernel.org X-Mailing-List: linux-kernel@vger.kernel.org Hi, On 6/20/05, Carsten Otte wrote: > On 6/20/05, Mauricio Lin wrote: > > I would like to know if there is a way to identify > > struct page that is cow (copy-on-write). > > > > The way I figured out to identify cow pages is when > > copy-on-write happens. I mean I identify cow pages > > inside the do_wp_page(), the function that handles > > copy-on-write. I have checked do_no_page() as well. > > > > I have included a field (is_cow) in the struct page to > > identify cow page. > > > > struct page { > > ... > > atomic_t is_cow; > > } > > > > But I wonder if it is possible to identify cow pages > > before copy-on-write happens. So identify cow pages in > > advance before any process tries to write to a cow > > page. > > > > I have checked the do_fork(), copy_process() and > > copy_mm() function to try to identify cow pages during > > the process creation, but no success. In copy_mm(), > > just the mm (of current process) is provided to the > > child process, but there are no references to struct > > pages related to mm and its VMAs. > > > > So when a page struct is considered a cow in the > > kernel and its count variable is updated? Certainly > > the counter page (page->_count) is updated when a page > > is shared because of copy-on-write feature. > > How can I identify cow pages when it becomes cow? Is > > there any feasible way to perform that? > Franky, one cannot predict which pages will get copied on > write since that is related to the behaviour of the process: > if the process writes, then the corresponding page gets copied. > If the vma has the VM_WRITE flag set, and the pte is read-only, > the page is a candidate to become subject to copy on write. So the only way to identify copy-on-write pages is when page fault related to copy-on-write happens, right? I mean in the handle_pte_fault() that calls do_wp_page(). BR, Mauricio Lin.