From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1754031AbbCXUFS (ORCPT ); Tue, 24 Mar 2015 16:05:18 -0400 Received: from mta-out1.inet.fi ([62.71.2.203]:48633 "EHLO jenni2.inet.fi" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752238AbbCXUFP (ORCPT ); Tue, 24 Mar 2015 16:05:15 -0400 Date: Tue, 24 Mar 2015 22:04:42 +0200 From: "Kirill A. Shutemov" To: Konstantin Khlebnikov Cc: "Kirill A. Shutemov" , Andrew Morton , Andrea Arcangeli , Hugh Dickins , Dave Hansen , Mel Gorman , Rik van Riel , Vlastimil Babka , Christoph Lameter , Naoya Horiguchi , Steve Capper , "Aneesh Kumar K.V" , Johannes Weiner , Michal Hocko , Jerome Marchand , Linux Kernel Mailing List , "linux-mm@kvack.org" Subject: Re: [PATCH 00/16] Sanitize usage of ->flags and ->mapping for tail pages Message-ID: <20150324200442.GA6269@node.dhcp.inet.fi> References: <1426784902-125149-1-git-send-email-kirill.shutemov@linux.intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: User-Agent: Mutt/1.5.23.1 (2014-03-12) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Mar 24, 2015 at 08:39:49PM +0300, Konstantin Khlebnikov wrote: > On Thu, Mar 19, 2015 at 8:08 PM, Kirill A. Shutemov > wrote: > > Currently we take naive approach to page flags on compound -- we set the > > flag on the page without consideration if the flag makes sense for tail > > page or for compound page in general. This patchset try to sort this out > > by defining per-flag policy on what need to be done if page-flag helper > > operate on compound page. > > > > The last patch in patchset also sanitize usege of page->mapping for tail > > pages. We don't define meaning of page->mapping for tail pages. Currently > > it's always NULL, which can be inconsistent with head page and potentially > > lead to problems. > > > > For now I catched one case of illigal usage of page flags or ->mapping: > > sound subsystem allocates pages with __GFP_COMP and maps them with PTEs. > > It leads to setting dirty bit on tail pages and access to tail_page's > > ->mapping. I don't see any bad behaviour caused by this, but worth fixing > > anyway. > > Do you mean call of set_page_dirty() from zap_pte_range() ? No. I trigger it earlier: set_page_dirty() from do_shared_fault(). > I think this should be replaced with vma operation: > vma->vm_ops->set_page_dirty() Does anybody know why would we want to dirtying pages with ->mapping == NULL? I don't see a place where we can make any use of this. We probably could avoid dirting such pages. Hm? -- Kirill A. Shutemov