Received: by 10.192.165.148 with SMTP id m20csp2823056imm; Mon, 7 May 2018 01:38:50 -0700 (PDT) X-Google-Smtp-Source: AB8JxZqLGNl4cjG3FcGmm1A0jp1/R8Fqp7VcGaKbkcUwVBATSxwlIJOMrJt4oXZp14I8RVWLjrhG X-Received: by 2002:a65:5889:: with SMTP id d9-v6mr18408847pgu.229.1525682330855; Mon, 07 May 2018 01:38:50 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1525682330; cv=none; d=google.com; s=arc-20160816; b=TSI3nuQM3ETlsPAWqfPh2Vp1P2E7KpIRySIvh8tEGX1xxOxicX5MuoNhuI/hjyU1tE RKwwvfps3cBa7M1BQo/Jsr7QjYjVaGW2H9T4VdD1uC0FzArkBSy0JXCkc7EjMfjZuqan 7yzgtfUuxWEs+PbYtsL1N630UXttP6iFIXddhJOYT31LUDw2yf69z1eArIw6iC0+EwT0 14KqqebfrNM3XDy2XqjwWR9Z0CfjxtHwh6w58hdsnFmZayTd7iazB0fPrgP3CHKOg+b8 8yYQhTk/8tpPU9hS7jYPlmf6XCnKfD8JTS4QbrCj7fvEf5E9iVuhgKY/rPVYAzOfjmRT 5qjA== 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=vLS5twYGN82CGMzjXvaKwVjddk6EawQ4lb1D1IgRYqM=; b=lFEnLPgBnzfb8PGxPr6QK4o0D8CbWlYFjtb9irDoCTMDY/h56OnNtZHeTYdQmFe9im bjE74oXM90fRbvHgu+MgVHPR1mPq+sJ9H8C3P2cCvTe9qj7CB23G4QI8n4OUF2qcyu42 j+V7WrIVb9EDtXk+mdHkxNDbzQiTBO9uGctVESHafFFp5OEWuhQU6EUDWwi+sVWX6ux+ 5BSBQBnNX/QcV7sfKFzxBwC/ll0YRjgtaFFSL1D7FXQKyS0pISHp8aklCIMAhjcuYnui /joVwPVCaUHXWByoZPc6o1+UtEKmXR5J9BaTv622KSM4RZ8GmohAIvnMbXBSMBX84Jn9 Z87g== 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 i64-v6si7230553pli.274.2018.05.07.01.38.36; Mon, 07 May 2018 01:38:50 -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 S1752115AbeEGIiY (ORCPT + 99 others); Mon, 7 May 2018 04:38:24 -0400 Received: from mail-wm0-f67.google.com ([74.125.82.67]:40260 "EHLO mail-wm0-f67.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1752052AbeEGIiR (ORCPT ); Mon, 7 May 2018 04:38:17 -0400 Received: by mail-wm0-f67.google.com with SMTP id j5-v6so13823831wme.5 for ; Mon, 07 May 2018 01:38:16 -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=vLS5twYGN82CGMzjXvaKwVjddk6EawQ4lb1D1IgRYqM=; b=gPbOmik8jVjuWfenW+xk1RFf6Tk8TWPIVGORcLtOwxAuQZ7Ets6ND6c3Djta9m9f6e 7bnQI14r1jWcnhnyuOf9A4RxQsIThiApHzsL2xDiSQTF6yYB+yXW0Ze8A4rGfJOu9Ega k8HcdE571jiwfwdyhuzrGui/4f8RAfhWSidG6rFP5Pabt+j9YfzDgRIEF/QPYNd+bPFL 2fk1IQn2kBIGsHGJgy33olKm1PVlUsBQywIZ4M5MDZYlhB2X7Bg6qGiQT7jkvCv6mdie 2KaepN2Bg74ql5xknvAMGeur7OSQOYjSAoXhR2ZSKWLiBAAvkS9OOhbEj5h291PYkHKi 1rtA== X-Gm-Message-State: ALKqPwetOD32PBJ+9aFjtuhjoXATcWDAn71v+KAM9NEnLR0dhhBkxYvJ ONJrKMPDtYviesh4jsVirE87NQ== X-Received: by 10.28.144.21 with SMTP id s21mr158902wmd.75.1525682296053; Mon, 07 May 2018 01:38:16 -0700 (PDT) Received: from veci.piliscsaba.redhat.com (C2B0E321.catv.pool.telekom.hu. [194.176.227.33]) by smtp.gmail.com with ESMTPSA id h8-v6sm5908050wmc.16.2018.05.07.01.38.14 (version=TLS1_2 cipher=ECDHE-RSA-CHACHA20-POLY1305 bits=256/256); Mon, 07 May 2018 01:38:15 -0700 (PDT) From: Miklos Szeredi To: linux-unionfs@vger.kernel.org Cc: linux-fsdevel@vger.kernel.org, linux-kernel@vger.kernel.org, Al Viro Subject: [PATCH v2 03/35] vfs: add f_op->pre_mmap() Date: Mon, 7 May 2018 10:37:35 +0200 Message-Id: <20180507083807.28792-4-mszeredi@redhat.com> X-Mailer: git-send-email 2.14.3 In-Reply-To: <20180507083807.28792-1-mszeredi@redhat.com> References: <20180507083807.28792-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 af49b55ff439..898fb798a3ff 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