Received: by 10.213.65.68 with SMTP id h4csp751608imn; Tue, 20 Mar 2018 14:33:18 -0700 (PDT) X-Google-Smtp-Source: AG47ELsqooPd3nGDo5YaxdsMnXAj3eIs4TZv7LLs5iLcf1ZW6V+cdWYbEVm5Dxk4yKHpMDLUvpeo X-Received: by 2002:a17:902:5a5:: with SMTP id f34-v6mr18164801plf.288.1521581597978; Tue, 20 Mar 2018 14:33:17 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1521581597; cv=none; d=google.com; s=arc-20160816; b=SXeHPqeh0hDUE0WTZNTWZxy3vviPH0ymNOO0OAa1ILDi3r6wY3O3ma6PFRbIXb1hL5 XzjB15naetFNgAAnkhiuStokE5ds+2nCF0LQo1+lXZP90TLN30n1NuWXyLNWqtVr7zSh JIFYUwJCBn+qqHCXejIPx+XMjlu6/OyvrEQ9djZt/jjiBDzDhBeIjWvZ42hREumJDF2z Ic+d4/JZChMYUbiTnKbYGR6iWIW6JP73xsM9/ve8EpMgAyRJmyfPpuvKm8l/Bq0yR7W4 iDn2Nai0MxlIVzZCh+JFkTqPYtwhcNMaS/C0xZCEys416rab1giq60vETIknZpFcjmlj tg+Q== 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:arc-authentication-results; bh=QKPojx7iDRYzNwRbyQdn3jlw12BxTFl1XpyRh9KCt8Y=; b=cOoTxDAC8QZdJwsjJULpiOtlwhOi62WaIZMp/Y2+zizwpGoyvbO9V4jD1TyOifHFkN 3MfPSa+/rmT/TrUy258FiVqCiJvahH+iRrPFAqQxaW273UzqrLJHT5AzsX9CvhEwVNA2 TbfJgCQiZLH/Qu+epkczl9aya4jNpbD6eYLBFZm/gyTQkZ48frm/00SIR814UcRbFJO1 8GP1uOdcA7XTjad6seewQlF7auJw+VMDuS1clNRcoKbPGpO3WBbB3Njdwrwr+dkV2JPm DvCgJ+Ni1lBEQzeEc8QhXHuS0+D32cSKvvUq2z4VoXfMvO41cXxqVv/kMRMU6cIpCXAM bwyg== 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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r7si1686173pgp.212.2018.03.20.14.33.03; Tue, 20 Mar 2018 14:33:17 -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; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=alibaba.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1751781AbeCTVcD (ORCPT + 99 others); Tue, 20 Mar 2018 17:32:03 -0400 Received: from out30-131.freemail.mail.aliyun.com ([115.124.30.131]:46123 "EHLO out30-131.freemail.mail.aliyun.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751701AbeCTVb6 (ORCPT ); Tue, 20 Mar 2018 17:31:58 -0400 X-Alimail-AntiSpam: AC=PASS;BC=-1|-1;BR=01201311R301e4;CH=green;FP=0|-1|-1|-1|0|-1|-1|-1;HT=e01e01422;MF=yang.shi@linux.alibaba.com;NM=1;PH=DS;RN=4;SR=0;TI=SMTPD_---0SzoMu-x_1521581495; Received: from e19h19392.et15sqa.tbsite.net(mailfrom:yang.shi@linux.alibaba.com fp:106.11.238.198) by smtp.aliyun-inc.com(127.0.0.1); Wed, 21 Mar 2018 05:31:45 +0800 From: Yang Shi To: akpm@linux-foundation.org Cc: yang.shi@linux.alibaba.com, linux-mm@kvack.org, linux-kernel@vger.kernel.org Subject: [RFC PATCH 2/8] mm: mmap: pass atomic parameter to do_munmap() call sites Date: Wed, 21 Mar 2018 05:31:20 +0800 Message-Id: <1521581486-99134-3-git-send-email-yang.shi@linux.alibaba.com> X-Mailer: git-send-email 1.8.3.1 In-Reply-To: <1521581486-99134-1-git-send-email-yang.shi@linux.alibaba.com> References: <1521581486-99134-1-git-send-email-yang.shi@linux.alibaba.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org It looks safe to release mmap_sem in the middle for vm_munmap and brk, so passing "false" to do_munmap() call. However it sounds not safe to mmap_region() which is called by SyS_mmap(). Signed-off-by: Yang Shi --- mm/mmap.c | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/mm/mmap.c b/mm/mmap.c index ad6ae7a..374e4ec 100644 --- a/mm/mmap.c +++ b/mm/mmap.c @@ -225,7 +225,7 @@ static struct vm_area_struct *remove_vma(struct vm_area_struct *vma) /* Always allow shrinking brk. */ if (brk <= mm->brk) { - if (!do_munmap(mm, newbrk, oldbrk-newbrk, &uf)) + if (!do_munmap(mm, newbrk, oldbrk-newbrk, &uf, false)) goto set_brk; goto out; } @@ -1643,7 +1643,7 @@ unsigned long mmap_region(struct file *file, unsigned long addr, /* Clear old maps */ while (find_vma_links(mm, addr, addr + len, &prev, &rb_link, &rb_parent)) { - if (do_munmap(mm, addr, len, uf)) + if (do_munmap(mm, addr, len, uf, true)) return -ENOMEM; } @@ -2778,7 +2778,7 @@ int vm_munmap(unsigned long start, size_t len) if (down_write_killable(&mm->mmap_sem)) return -EINTR; - ret = do_munmap(mm, start, len, &uf); + ret = do_munmap(mm, start, len, &uf, false); up_write(&mm->mmap_sem); userfaultfd_unmap_complete(mm, &uf); return ret; @@ -2945,7 +2945,7 @@ static int do_brk_flags(unsigned long addr, unsigned long request, unsigned long */ while (find_vma_links(mm, addr, addr + len, &prev, &rb_link, &rb_parent)) { - if (do_munmap(mm, addr, len, uf)) + if (do_munmap(mm, addr, len, uf, false)) return -ENOMEM; } -- 1.8.3.1