From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: from mail-pl0-f71.google.com (mail-pl0-f71.google.com [209.85.160.71]) by kanga.kvack.org (Postfix) with ESMTP id EEDF96B0005 for ; Thu, 31 May 2018 18:52:58 -0400 (EDT) Received: by mail-pl0-f71.google.com with SMTP id f35-v6so14072593plb.10 for ; Thu, 31 May 2018 15:52:58 -0700 (PDT) Received: from mail.linuxfoundation.org (mail.linuxfoundation.org. [140.211.169.12]) by mx.google.com with ESMTPS id f17-v6si1566033pgv.383.2018.05.31.15.52.57 for (version=TLS1_2 cipher=ECDHE-RSA-AES128-GCM-SHA256 bits=128/128); Thu, 31 May 2018 15:52:58 -0700 (PDT) Date: Thu, 31 May 2018 15:52:56 -0700 From: Andrew Morton Subject: Re: [PATCH] mm/shmem: Zero out unused vma fields in shmem_pseudo_vma_init() Message-Id: <20180531155256.a5f557c9e620a6d7e85e4ca1@linux-foundation.org> In-Reply-To: <20180531135602.20321-1-kirill.shutemov@linux.intel.com> References: <20180531135602.20321-1-kirill.shutemov@linux.intel.com> Mime-Version: 1.0 Content-Type: text/plain; charset=US-ASCII Content-Transfer-Encoding: 7bit Sender: owner-linux-mm@kvack.org List-ID: To: "Kirill A. Shutemov" Cc: Hugh Dickins , linux-mm@kvack.org, linux-kernel@vger.kernel.org On Thu, 31 May 2018 16:56:02 +0300 "Kirill A. Shutemov" wrote: > shmem/tmpfs uses pseudo vma to allocate page with correct NUMA policy. > > The pseudo vma doesn't have vm_page_prot set. We are going to encode > encryption KeyID in vm_page_prot. Having garbage there causes problems. > > Zero out all unused fields in the pseudo vma. > So there are no known problems in the current mainline kernel? > --- a/mm/shmem.c > +++ b/mm/shmem.c > @@ -1404,10 +1404,9 @@ static void shmem_pseudo_vma_init(struct vm_area_struct *vma, > struct shmem_inode_info *info, pgoff_t index) > { > /* Create a pseudo vma that just contains the policy */ > - vma->vm_start = 0; > + memset(vma, 0, sizeof(*vma)); > /* Bias interleave by inode number to distribute better across nodes */ > vma->vm_pgoff = index + info->vfs_inode.i_ino; > - vma->vm_ops = NULL; > vma->vm_policy = mpol_shared_policy_lookup(&info->policy, index); > }