Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp3217067imu; Sun, 6 Jan 2019 22:19:53 -0800 (PST) X-Google-Smtp-Source: ALg8bN5QTz6Eo2GZZfXAVMR+Oh+2VR9/0qW6VyhSR9BCGlDoWZDMzn0N3P+pH21AJUeaszGvinsu X-Received: by 2002:a17:902:4624:: with SMTP id o33mr59076401pld.289.1546841993317; Sun, 06 Jan 2019 22:19:53 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546841993; cv=none; d=google.com; s=arc-20160816; b=ZCe0fiIFhnN35DKDC/n2/w3vVlXbRsSpEoRcc1CCbLHgCuMM9Xpk6QIWEYw631J5HD H0JO8XI52aBAYfPjsD+8XqXXKB7cBQGTxMotDW9nHmhPY1pyvHtvUN9W3ogB8VYfBYv4 Xzoo0yY3YXkfBfXdsJHJR5In9u+7+rtvI5CbUTGZrwjNlA6Kw8VNqTkKxcDze/VTdYaK 68+E3cUSUakY8CdOEiubW9ZkBL6VFOMNw2wA3dvnKtZkr7hqInjCWieqEJUzyPapCNN5 WC9kCswnT1EHiuWVC6wKJya82XmDQCc8viR14NKvYnQQvCBZgD79L03iXYP5DHs1OqLm UxWA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:cc:to:subject:message-id:date:from :in-reply-to:references:mime-version:dkim-signature; bh=0vzhVfMyaVE2G7X9WbbGn0gD3CbF4zU9/bkHOHmr54c=; b=jbKSiIZ4BhbyYsIL5Wh3f1+V2FY7F/vcb/kQe56oBGk2pXMvjIedoEuVJs+uguogHL KtW+L1HqQn8dUGWQ+oAfw1njHBEz9NeAvz+gwRlG79WODXdS/qlb0zvpwTp4uP/hCXkI S3By1dNWl3kIZz7saOzueh9vhECpNEmSNcYiaw/4nxQzpNqRDBnqgyKR8OwIBvEAI7EV xJhRJ/lbDKxTHvVhRAdy1HWTuok3GsuFLnjfVVhbGfPldMSXtBXYbmRPjrzYkDm53sgR YTm/jdbywlgG9iFP7b7h/Eqpxz4EuDMZIZpRryVKxCyKpiiAfPoRShXoLTqND1rrTizN ZBrg== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NroKfAQ+; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id k2si3071960pgh.63.2019.01.06.22.19.23; Sun, 06 Jan 2019 22:19:53 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20161025 header.b=NroKfAQ+; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1726257AbfAGGR3 (ORCPT + 99 others); Mon, 7 Jan 2019 01:17:29 -0500 Received: from mail-lj1-f196.google.com ([209.85.208.196]:45829 "EHLO mail-lj1-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725306AbfAGGR3 (ORCPT ); Mon, 7 Jan 2019 01:17:29 -0500 Received: by mail-lj1-f196.google.com with SMTP id s5-v6so37088481ljd.12 for ; Sun, 06 Jan 2019 22:17:25 -0800 (PST) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20161025; h=mime-version:references:in-reply-to:from:date:message-id:subject:to :cc; bh=0vzhVfMyaVE2G7X9WbbGn0gD3CbF4zU9/bkHOHmr54c=; b=NroKfAQ+6X0bqmf78NspHZegaUkFDwj1v8kkevhQyOMI3CpAeqHEUeFrnVdrJAA5LQ qnGhmcjuIIws6t6IUKBWdVm/MnqNSEs1HJ5oBI2ci91fX93qsmYsN/ZQpXhAlcT2eKdP CLfOclT416eLauCYx8m/JB9XeBTmSOrv9/vZXvFL5XTjOKL3h9/GVaaErSxZQontiQoK cCGzgu5yGHrRDqYnhimNJxeNzBqLVmN7hyqSRqGLwoD/j+gyd8BmBCR6VTsr+Pn7QA0J T5ghYOc8OjATBjg2EzYauQCR44QgITSmJ0Gu5FU+YACENuJNV7F1cNfOQ4fjApuGQ1Ds dPdA== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:mime-version:references:in-reply-to:from:date :message-id:subject:to:cc; bh=0vzhVfMyaVE2G7X9WbbGn0gD3CbF4zU9/bkHOHmr54c=; b=OSWFIZSJzIAsG7guhhFJRlAevhKtYfsl8ET3tLmRR6ab4V8ixDYyctmoJWfBmLWoeX GFz9JQXi7cGpLZT2qrK/zJTL+o82FKrPstm1ApMGEzhcF+xQdnIGpaESxVbhWd8MAyaV mbK0Pe517S4OgCMuwgExTQSIOVln8NvZthvct4YS8HtzAAkZaBGTXemD4viB9mxUdrr/ bdkeYmYvLe3O88EZJkOzf29IfeROU0J1IWa3vdHQxHI/lVR2EPlRDsHs4g+XzangOxlE fZHahrVnzUvIM4wfYMqNf1sy0q/z3yDoVWEHbKWhJV8yDjhv077x3v7ZnLjmqqFdNFq+ l+Lw== X-Gm-Message-State: AJcUukdiWUs14llVX5FzPGrv7DA14VCG/gBdKJ+rwBEGDeB4VQ3+5ygb aldlMw0VtzrZoye9+QwzthTgmMut6i6rEN25TpE= X-Received: by 2002:a2e:9c52:: with SMTP id t18-v6mr27550357ljj.149.1546841844697; Sun, 06 Jan 2019 22:17:24 -0800 (PST) MIME-Version: 1.0 References: <20181106120544.GA3783@jordon-HP-15-Notebook-PC> <20181115014737.GA2353@rapoport-lnx> In-Reply-To: From: Souptick Joarder Date: Mon, 7 Jan 2019 11:47:12 +0530 Message-ID: Subject: Re: [PATCH v3] mm: Create the new vm_fault_t type To: rppt@linux.ibm.com, Andrew Morton , Michal Hocko , Dan Williams , Matthew Wilcox Cc: "Kirill A. Shutemov" , vbabka@suse.cz, riel@redhat.com, Linux-MM , linux-kernel@vger.kernel.org Content-Type: text/plain; charset="UTF-8" Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Fri, Dec 14, 2018 at 10:35 AM Souptick Joarder wrote: > > Hi Andrew, > > On Sat, Nov 24, 2018 at 10:16 AM Souptick Joarder wrote: > > > > On Thu, Nov 15, 2018 at 7:17 AM Mike Rapoport wrote: > > > > > > On Tue, Nov 06, 2018 at 05:36:42PM +0530, Souptick Joarder wrote: > > > > Page fault handlers are supposed to return VM_FAULT codes, > > > > but some drivers/file systems mistakenly return error > > > > numbers. Now that all drivers/file systems have been converted > > > > to use the vm_fault_t return type, change the type definition > > > > to no longer be compatible with 'int'. By making it an unsigned > > > > int, the function prototype becomes incompatible with a function > > > > which returns int. Sparse will detect any attempts to return a > > > > value which is not a VM_FAULT code. > > > > > > > > VM_FAULT_SET_HINDEX and VM_FAULT_GET_HINDEX values are changed > > > > to avoid conflict with other VM_FAULT codes. > > > > > > > > Signed-off-by: Souptick Joarder > > > > > > For the docs part > > > Reviewed-by: Mike Rapoport > > > > > > > --- > > > > v2: Updated the change log and corrected the document part. > > > > name added to the enum that kernel-doc able to parse it. > > > > > > > > v3: Corrected the documentation. > > > > If no further comment, can we get this patch in queue for 4.21 ? > > Do I need to make any further improvement for this patch ? If no further comment, can we get this patch in queue for 5.0-rcX ? > > > > > > > > > > include/linux/mm.h | 46 ------------------------------ > > > > include/linux/mm_types.h | 73 +++++++++++++++++++++++++++++++++++++++++++++++- > > > > 2 files changed, 72 insertions(+), 47 deletions(-) > > > > > > > > diff --git a/include/linux/mm.h b/include/linux/mm.h > > > > index fcf9cc9..511a3ce 100644 > > > > --- a/include/linux/mm.h > > > > +++ b/include/linux/mm.h > > > > @@ -1267,52 +1267,6 @@ static inline void clear_page_pfmemalloc(struct page *page) > > > > } > > > > > > > > /* > > > > - * Different kinds of faults, as returned by handle_mm_fault(). > > > > - * Used to decide whether a process gets delivered SIGBUS or > > > > - * just gets major/minor fault counters bumped up. > > > > - */ > > > > - > > > > -#define VM_FAULT_OOM 0x0001 > > > > -#define VM_FAULT_SIGBUS 0x0002 > > > > -#define VM_FAULT_MAJOR 0x0004 > > > > -#define VM_FAULT_WRITE 0x0008 /* Special case for get_user_pages */ > > > > -#define VM_FAULT_HWPOISON 0x0010 /* Hit poisoned small page */ > > > > -#define VM_FAULT_HWPOISON_LARGE 0x0020 /* Hit poisoned large page. Index encoded in upper bits */ > > > > -#define VM_FAULT_SIGSEGV 0x0040 > > > > - > > > > -#define VM_FAULT_NOPAGE 0x0100 /* ->fault installed the pte, not return page */ > > > > -#define VM_FAULT_LOCKED 0x0200 /* ->fault locked the returned page */ > > > > -#define VM_FAULT_RETRY 0x0400 /* ->fault blocked, must retry */ > > > > -#define VM_FAULT_FALLBACK 0x0800 /* huge page fault failed, fall back to small */ > > > > -#define VM_FAULT_DONE_COW 0x1000 /* ->fault has fully handled COW */ > > > > -#define VM_FAULT_NEEDDSYNC 0x2000 /* ->fault did not modify page tables > > > > - * and needs fsync() to complete (for > > > > - * synchronous page faults in DAX) */ > > > > - > > > > -#define VM_FAULT_ERROR (VM_FAULT_OOM | VM_FAULT_SIGBUS | VM_FAULT_SIGSEGV | \ > > > > - VM_FAULT_HWPOISON | VM_FAULT_HWPOISON_LARGE | \ > > > > - VM_FAULT_FALLBACK) > > > > - > > > > -#define VM_FAULT_RESULT_TRACE \ > > > > - { VM_FAULT_OOM, "OOM" }, \ > > > > - { VM_FAULT_SIGBUS, "SIGBUS" }, \ > > > > - { VM_FAULT_MAJOR, "MAJOR" }, \ > > > > - { VM_FAULT_WRITE, "WRITE" }, \ > > > > - { VM_FAULT_HWPOISON, "HWPOISON" }, \ > > > > - { VM_FAULT_HWPOISON_LARGE, "HWPOISON_LARGE" }, \ > > > > - { VM_FAULT_SIGSEGV, "SIGSEGV" }, \ > > > > - { VM_FAULT_NOPAGE, "NOPAGE" }, \ > > > > - { VM_FAULT_LOCKED, "LOCKED" }, \ > > > > - { VM_FAULT_RETRY, "RETRY" }, \ > > > > - { VM_FAULT_FALLBACK, "FALLBACK" }, \ > > > > - { VM_FAULT_DONE_COW, "DONE_COW" }, \ > > > > - { VM_FAULT_NEEDDSYNC, "NEEDDSYNC" } > > > > - > > > > -/* Encode hstate index for a hwpoisoned large page */ > > > > -#define VM_FAULT_SET_HINDEX(x) ((x) << 12) > > > > -#define VM_FAULT_GET_HINDEX(x) (((x) >> 12) & 0xf) > > > > - > > > > -/* > > > > * Can be called by the pagefault handler when it gets a VM_FAULT_OOM. > > > > */ > > > > extern void pagefault_out_of_memory(void); > > > > diff --git a/include/linux/mm_types.h b/include/linux/mm_types.h > > > > index 5ed8f62..cb25016 100644 > > > > --- a/include/linux/mm_types.h > > > > +++ b/include/linux/mm_types.h > > > > @@ -22,7 +22,6 @@ > > > > #endif > > > > #define AT_VECTOR_SIZE (2*(AT_VECTOR_SIZE_ARCH + AT_VECTOR_SIZE_BASE + 1)) > > > > > > > > -typedef int vm_fault_t; > > > > > > > > struct address_space; > > > > struct mem_cgroup; > > > > @@ -609,6 +608,78 @@ static inline bool mm_tlb_flush_nested(struct mm_struct *mm) > > > > > > > > struct vm_fault; > > > > > > > > +/** > > > > + * typedef vm_fault_t - Return type for page fault handlers. > > > > + * > > > > + * Page fault handlers return a bitmask of %VM_FAULT values. > > > > + */ > > > > +typedef __bitwise unsigned int vm_fault_t; > > > > + > > > > +/** > > > > + * enum vm_fault_reason - Page fault handlers return a bitmask of > > > > + * these values to tell the core VM what happened when handling the > > > > + * fault. Used to decide whether a process gets delivered SIGBUS or > > > > + * just gets major/minor fault counters bumped up. > > > > + * > > > > + * @VM_FAULT_OOM: Out Of Memory > > > > + * @VM_FAULT_SIGBUS: Bad access > > > > + * @VM_FAULT_MAJOR: Page read from storage > > > > + * @VM_FAULT_WRITE: Special case for get_user_pages > > > > + * @VM_FAULT_HWPOISON: Hit poisoned small page > > > > + * @VM_FAULT_HWPOISON_LARGE: Hit poisoned large page. Index encoded > > > > + * in upper bits > > > > + * @VM_FAULT_SIGSEGV: segmentation fault > > > > + * @VM_FAULT_NOPAGE: ->fault installed the pte, not return page > > > > + * @VM_FAULT_LOCKED: ->fault locked the returned page > > > > + * @VM_FAULT_RETRY: ->fault blocked, must retry > > > > + * @VM_FAULT_FALLBACK: huge page fault failed, fall back to small > > > > + * @VM_FAULT_DONE_COW: ->fault has fully handled COW > > > > + * @VM_FAULT_NEEDDSYNC: ->fault did not modify page tables and needs > > > > + * fsync() to complete (for synchronous page faults > > > > + * in DAX) > > > > + * @VM_FAULT_HINDEX_MASK: mask HINDEX value > > > > + * > > > > + */ > > > > +enum vm_fault_reason { > > > > + VM_FAULT_OOM = (__force vm_fault_t)0x000001, > > > > + VM_FAULT_SIGBUS = (__force vm_fault_t)0x000002, > > > > + VM_FAULT_MAJOR = (__force vm_fault_t)0x000004, > > > > + VM_FAULT_WRITE = (__force vm_fault_t)0x000008, > > > > + VM_FAULT_HWPOISON = (__force vm_fault_t)0x000010, > > > > + VM_FAULT_HWPOISON_LARGE = (__force vm_fault_t)0x000020, > > > > + VM_FAULT_SIGSEGV = (__force vm_fault_t)0x000040, > > > > + VM_FAULT_NOPAGE = (__force vm_fault_t)0x000100, > > > > + VM_FAULT_LOCKED = (__force vm_fault_t)0x000200, > > > > + VM_FAULT_RETRY = (__force vm_fault_t)0x000400, > > > > + VM_FAULT_FALLBACK = (__force vm_fault_t)0x000800, > > > > + VM_FAULT_DONE_COW = (__force vm_fault_t)0x001000, > > > > + VM_FAULT_NEEDDSYNC = (__force vm_fault_t)0x002000, > > > > + VM_FAULT_HINDEX_MASK = (__force vm_fault_t)0x0f0000, > > > > +}; > > > > + > > > > +/* Encode hstate index for a hwpoisoned large page */ > > > > +#define VM_FAULT_SET_HINDEX(x) ((__force vm_fault_t)((x) << 16)) > > > > +#define VM_FAULT_GET_HINDEX(x) (((x) >> 16) & 0xf) > > > > + > > > > +#define VM_FAULT_ERROR (VM_FAULT_OOM | VM_FAULT_SIGBUS | \ > > > > + VM_FAULT_SIGSEGV | VM_FAULT_HWPOISON | \ > > > > + VM_FAULT_HWPOISON_LARGE | VM_FAULT_FALLBACK) > > > > + > > > > +#define VM_FAULT_RESULT_TRACE \ > > > > + { VM_FAULT_OOM, "OOM" }, \ > > > > + { VM_FAULT_SIGBUS, "SIGBUS" }, \ > > > > + { VM_FAULT_MAJOR, "MAJOR" }, \ > > > > + { VM_FAULT_WRITE, "WRITE" }, \ > > > > + { VM_FAULT_HWPOISON, "HWPOISON" }, \ > > > > + { VM_FAULT_HWPOISON_LARGE, "HWPOISON_LARGE" }, \ > > > > + { VM_FAULT_SIGSEGV, "SIGSEGV" }, \ > > > > + { VM_FAULT_NOPAGE, "NOPAGE" }, \ > > > > + { VM_FAULT_LOCKED, "LOCKED" }, \ > > > > + { VM_FAULT_RETRY, "RETRY" }, \ > > > > + { VM_FAULT_FALLBACK, "FALLBACK" }, \ > > > > + { VM_FAULT_DONE_COW, "DONE_COW" }, \ > > > > + { VM_FAULT_NEEDDSYNC, "NEEDDSYNC" } > > > > + > > > > struct vm_special_mapping { > > > > const char *name; /* The name, e.g. "[vdso]". */ > > > > > > > > -- > > > > 1.9.1 > > > > > > > > > > -- > > > Sincerely yours, > > > Mike. > > >