Received: by 2002:a25:86ce:0:0:0:0:0 with SMTP id y14csp519014ybm; Mon, 20 May 2019 21:55:19 -0700 (PDT) X-Google-Smtp-Source: APXvYqwCn/pUHimSwdEVoMDjDqkZmyhTyPOPradoQ1/qrA/5XnFW8H74tWXT2dwjIya+XsRYELnW X-Received: by 2002:a17:902:1ea:: with SMTP id b97mr53916348plb.317.1558414519117; Mon, 20 May 2019 21:55:19 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1558414519; cv=none; d=google.com; s=arc-20160816; b=k81kPYd2CKsKAf7FnSuf5FlzTAN8h9hbYdkxxcLKM82ClzRYdZNZZQhB52IkVSnf5w o57c5xBl0ggj7Y1PqT/1J9jv9tutNsyFzUJ7Aqp+S3QYp+rsX60f1V5Y+ZyBmszG1S32 G2uU0hQ9iPS28MX2K00wAkyKeoMyYJ2RaIPETD0d9bfb8Ni5cojT96rdr2O7bqdxn5kU LGYlynpWRH1ZhI2eOCW0S12mDwupjKsItyp+cOV5LiFlBBMH6riukaByfnOWL1rX3HIY 3Br0nKZP9De3S/zA7R8a/Tv9tnFK36RhT+qIH7vrWkl/flLmea9UdqvQApDfIOEAsi3L 52gA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:references:in-reply-to:message-id:date :subject:cc:to:from; bh=rX3tmFnDBHq8c3zM6clbCsU1d9V2kYeDMHx4D3qEo4Y=; b=kppIj4gAdQXGpVDDGDj8T6eyJoOnvlaembFuGwUsrXP5UmvQP03XUynt+fUoXUu6Y2 33wB6/mlvG+rh4+qXurMVFmmD3VYmmFn5/wW0m0PVLNbb4DTVle8J165crZLNdgdXDEH I3n6x/4CAmZA93YgEqv8OMoZW+Y/sIjS5RzWn23QtjbyAoPCqweNdSQFB7dofQ21+LUY i9+2GsJSeXXpcsfGRVHbZus2frQQ/JHqT/BU2B44D9RM7fE0GTnwNA6ydGMOLlMznF5O m4RtSVmKNbL61aPZiXjrtQYpYVy54vRwwHlQsRqCGyHlfR3KgfNisPXGhDVsMi+lndTZ EViA== ARC-Authentication-Results: i=1; mx.google.com; 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id p23si19917835plo.215.2019.05.20.21.55.04; Mon, 20 May 2019 21:55:19 -0700 (PDT) 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; 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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1727799AbfEUExf (ORCPT + 99 others); Tue, 21 May 2019 00:53:35 -0400 Received: from smtp.nue.novell.com ([195.135.221.5]:59926 "EHLO smtp.nue.novell.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1725835AbfEUExe (ORCPT ); Tue, 21 May 2019 00:53:34 -0400 Received: from emea4-mta.ukb.novell.com ([10.120.13.87]) by smtp.nue.novell.com with ESMTP (TLS encrypted); Tue, 21 May 2019 06:53:33 +0200 Received: from linux-r8p5.suse.de (nwb-a10-snat.microfocus.com [10.120.13.201]) by emea4-mta.ukb.novell.com with ESMTP (TLS encrypted); Tue, 21 May 2019 05:53:01 +0100 From: Davidlohr Bueso To: linux-mm@kvack.org, linux-kernel@vger.kernel.org Cc: akpm@linux-foundation.org, willy@infradead.org, mhocko@kernel.org, mgorman@techsingularity.net, jglisse@redhat.com, ldufour@linux.vnet.ibm.com, dave@stgolabs.net, Davidlohr Bueso Subject: [PATCH 03/14] mm: introduce mm locking wrappers Date: Mon, 20 May 2019 21:52:31 -0700 Message-Id: <20190521045242.24378-4-dave@stgolabs.net> X-Mailer: git-send-email 2.16.4 In-Reply-To: <20190521045242.24378-1-dave@stgolabs.net> References: <20190521045242.24378-1-dave@stgolabs.net> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This patch adds the necessary wrappers to encapsulate mmap_sem locking and will enable any future changes to be a lot more confined to here. In addition, future users will incrementally be added in the next patches. mm_[read/write]_[un]lock() naming is used. Signed-off-by: Davidlohr Bueso --- include/linux/mm.h | 76 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 76 insertions(+) diff --git a/include/linux/mm.h b/include/linux/mm.h index 0e8834ac32b7..780b6097ee47 100644 --- a/include/linux/mm.h +++ b/include/linux/mm.h @@ -12,6 +12,7 @@ #include #include #include +#include #include #include #include @@ -2880,5 +2881,80 @@ void __init setup_nr_node_ids(void); static inline void setup_nr_node_ids(void) {} #endif +/* + * Address space locking wrappers. + */ +static inline bool mm_is_locked(struct mm_struct *mm, + struct range_lock *mmrange) +{ + return rwsem_is_locked(&mm->mmap_sem); +} + +/* Reader wrappers */ +static inline int mm_read_trylock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + return down_read_trylock(&mm->mmap_sem); +} + +static inline void mm_read_lock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + down_read(&mm->mmap_sem); +} + +static inline void mm_read_lock_nested(struct mm_struct *mm, + struct range_lock *mmrange, int subclass) +{ + down_read_nested(&mm->mmap_sem, subclass); +} + +static inline void mm_read_unlock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + up_read(&mm->mmap_sem); +} + +/* Writer wrappers */ +static inline int mm_write_trylock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + return down_write_trylock(&mm->mmap_sem); +} + +static inline void mm_write_lock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + down_write(&mm->mmap_sem); +} + +static inline int mm_write_lock_killable(struct mm_struct *mm, + struct range_lock *mmrange) +{ + return down_write_killable(&mm->mmap_sem); +} + +static inline void mm_downgrade_write(struct mm_struct *mm, + struct range_lock *mmrange) +{ + downgrade_write(&mm->mmap_sem); +} + +static inline void mm_write_unlock(struct mm_struct *mm, + struct range_lock *mmrange) +{ + up_write(&mm->mmap_sem); +} + +static inline void mm_write_lock_nested(struct mm_struct *mm, + struct range_lock *mmrange, + int subclass) +{ + down_write_nested(&mm->mmap_sem, subclass); +} + +#define mm_write_nest_lock(mm, range, nest_lock) \ + down_write_nest_lock(&(mm)->mmap_sem, nest_lock) + #endif /* __KERNEL__ */ #endif /* _LINUX_MM_H */ -- 2.16.4