Received: by 2002:ac0:a5b6:0:0:0:0:0 with SMTP id m51-v6csp3500008imm; Tue, 29 May 2018 08:15:57 -0700 (PDT) X-Google-Smtp-Source: AB8JxZo82n54yqN0q9GnQiZZCbsRBmg9ZsipCREzFRDb8GN3RKtE4AaStnL661IDXmZqjmbUh/ON X-Received: by 2002:a62:be10:: with SMTP id l16-v6mr17538544pff.180.1527606957688; Tue, 29 May 2018 08:15:57 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1527606957; cv=none; d=google.com; s=arc-20160816; b=Ngg5pogNKTKjeL585OSz5DziOsvSjzTRTuBLEyoa+E8LLE4t9ALug9WCHmOR1228eP WuRbunWTtFWRFsmW9ciy5uPXSp6FDv+QCfnQYIlMKjvSySFcupZgPqtVFo4SO6+ZHpmN nRjypd8cxn8g4QIrQsdJNL3SvXWXixbJby106jWsbWq7bjD7Sc51NOZZFgwlLbCTnpbx xNToCsdLwXlM8qoxhQlykYue6ZDMRLmcQPIBNhqCeXxeeGawpmLklToealjC+PnkXeNe BUc6e7ASoIrsGmcMCeDU/CdcJsQFXi5MVN+S+AXLi2FPucRCx1NVBArqn8j7C6bUPIZ8 VY5w== 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=E8GLzWACiIQG8l8i+Px92snFRuLDdksLIaIzgWBkvGo=; b=KmLvCwjdJTSkAdfFXlOiJhpTUTZg07VNq8Lnx3Rj4uJY9HJSTzHE4pyMY1dqNiJujT jJh86RNZ+1e3x/vKNR8QViP1oy0CF+bmht2e/OPLXaOylGCd4Fs3xG2ETdGmcRAKyNwf UKbdWMXQil0zb+5y0AYYpMJHGfMiBknXQbmqCEIn7dn50CQSko2u0WsSJ0VEKnMNu+4k KeNjyxwNqJBK2IyQHtwEOYNHe/dO5btsd9kUkOVlU7v/Xl2O6iSoOd2r+9hkthCf3SnB +P+Cxwhavc2fCgTMH2AOMiontp0OJvUbLzmjOqr0EEpD+7S0Ezv6x3sBG30qfGSO9YaG d61Q== 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=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id x20-v6si32167498pln.235.2018.05.29.08.15.43; Tue, 29 May 2018 08:15:57 -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=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S964850AbeE2PPU (ORCPT + 99 others); Tue, 29 May 2018 11:15:20 -0400 Received: from mail-wr0-f196.google.com ([209.85.128.196]:46520 "EHLO mail-wr0-f196.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S935547AbeE2Ont (ORCPT ); Tue, 29 May 2018 10:43:49 -0400 Received: by mail-wr0-f196.google.com with SMTP id v13-v6so14287057wrp.13 for ; Tue, 29 May 2018 07:43:49 -0700 (PDT) X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20161025; h=x-gm-message-state:from:to:cc:subject:date:message-id:in-reply-to :references; bh=E8GLzWACiIQG8l8i+Px92snFRuLDdksLIaIzgWBkvGo=; b=fgIvGURaMxpzgFh8EB3+0bkTbjwQC1RysH9Pw1rqGdsKuZnrdBamQDXLTTYz0ZaRAu apsWG/rZIJbxFPfORPZxN+B9rbXq//5m/hSYesocEgdqzlXlkNOFzfcu8xTFhwmG5ws3 lGl1Po/SG4LRJ8wS2T8ke3ZhKTSH76UehEYw4kPhdutnf8ZS0s+Tlpf5cv9t/fZ6SiBb e6sjrTiOoGEP8xvi8EA5i84pwx6rdd5W4W4wwISOpTTV2Plgepc4I5IGXAWjOXWc7253 W4ePwykW4+AsXNKvuapTWkG0vyl9BU9PixnPpz86S/xubeOmi3B1p3nvL755TzjktAyt 8HIg== X-Gm-Message-State: ALKqPwdsJj+pxNw8NVsWfrfoEgrSjGd83nKhKcnqkjW+sXiC8R1ZsLUU RLSjXkbrrSxOD8uhvmNy/d0LoQ== X-Received: by 2002:adf:d84a:: with SMTP id k10-v6mr13489343wrl.26.1527605028226; Tue, 29 May 2018 07:43:48 -0700 (PDT) Received: from veci.piliscsaba.redhat.com (catv-176-63-54-97.catv.broadband.hu. [176.63.54.97]) by smtp.gmail.com with ESMTPSA id t198-v6sm18834422wmt.23.2018.05.29.07.43.47 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Tue, 29 May 2018 07:43:47 -0700 (PDT) From: Miklos Szeredi To: linux-unionfs@vger.kernel.org Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org Subject: [PATCH 06/39] vfs: add f_op->pre_mmap() Date: Tue, 29 May 2018 16:43:06 +0200 Message-Id: <20180529144339.16538-7-mszeredi@redhat.com> X-Mailer: git-send-email 2.14.3 In-Reply-To: <20180529144339.16538-1-mszeredi@redhat.com> References: <20180529144339.16538-1-mszeredi@redhat.com> Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org This is needed by overlayfs to be able to copy up a file from a read-only lower layer to a writable layer when being mapped shared. When copying up, overlayfs takes VFS locks that would violate locking order when nested inside mmap_sem. Add a new f_op->pre_mmap method, which is called before taking mmap_sem. Signed-off-by: Miklos Szeredi --- Documentation/filesystems/Locking | 1 + Documentation/filesystems/vfs.txt | 3 +++ include/linux/fs.h | 1 + mm/util.c | 5 +++++ 4 files changed, 10 insertions(+) diff --git a/Documentation/filesystems/Locking b/Documentation/filesystems/Locking index 75d2d57e2c44..60e76060baff 100644 --- a/Documentation/filesystems/Locking +++ b/Documentation/filesystems/Locking @@ -442,6 +442,7 @@ prototypes: unsigned int (*poll) (struct file *, struct poll_table_struct *); long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long); long (*compat_ioctl) (struct file *, unsigned int, unsigned long); + int (*pre_mmap) (struct file *, unsigned long, unsigned long); int (*mmap) (struct file *, struct vm_area_struct *); int (*open) (struct inode *, struct file *); int (*flush) (struct file *); diff --git a/Documentation/filesystems/vfs.txt b/Documentation/filesystems/vfs.txt index 5fd325df59e2..2bc77ea8aef4 100644 --- a/Documentation/filesystems/vfs.txt +++ b/Documentation/filesystems/vfs.txt @@ -859,6 +859,7 @@ struct file_operations { unsigned int (*poll) (struct file *, struct poll_table_struct *); long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long); long (*compat_ioctl) (struct file *, unsigned int, unsigned long); + int (*pre_mmap) (struct file *, unsigned long, unsigned long); int (*mmap) (struct file *, struct vm_area_struct *); int (*mremap)(struct file *, struct vm_area_struct *); int (*open) (struct inode *, struct file *); @@ -906,6 +907,8 @@ otherwise noted. compat_ioctl: called by the ioctl(2) system call when 32 bit system calls are used on 64 bit kernels. + pre_mmap: called before mmap, without mmap_sem being held yet. + mmap: called by the mmap(2) system call open: called by the VFS when an inode should be opened. When the VFS diff --git a/include/linux/fs.h b/include/linux/fs.h index ecc854c75611..1ea3f153b7f8 100644 --- a/include/linux/fs.h +++ b/include/linux/fs.h @@ -1716,6 +1716,7 @@ struct file_operations { __poll_t (*poll) (struct file *, struct poll_table_struct *); long (*unlocked_ioctl) (struct file *, unsigned int, unsigned long); long (*compat_ioctl) (struct file *, unsigned int, unsigned long); + int (*pre_mmap) (struct file *, unsigned long, unsigned long); int (*mmap) (struct file *, struct vm_area_struct *); unsigned long mmap_supported_flags; int (*open) (struct inode *, struct file *); diff --git a/mm/util.c b/mm/util.c index 45fc3169e7b0..11cd375e1a19 100644 --- a/mm/util.c +++ b/mm/util.c @@ -352,6 +352,11 @@ unsigned long vm_mmap_pgoff(struct file *file, unsigned long addr, ret = security_mmap_file(file, prot, flag); if (!ret) { + if (file && file->f_op->pre_mmap) { + ret = file->f_op->pre_mmap(file, prot, flag); + if (ret) + return ret; + } if (down_write_killable(&mm->mmap_sem)) return -EINTR; ret = do_mmap_pgoff(file, addr, len, prot, flag, pgoff, -- 2.14.3