linux-next: manual merge of the vfs tree with the overlayfs tree

From: Stephen Rothwell
Date: Mon Jul 09 2018 - 20:22:28 EST


Hi all,

Today's linux-next merge of the vfs tree got a conflict in:

include/linux/fs.h

between commit:

5c299f73cc9e ("vfs: add path_open()")

from the overlayfs tree and commit:

bfd4fa6990f0 ("turn filp_clone_open() into inline wrapper for dentry_open()")

from the vfs tree.

I fixed it up (see below) and can carry the fix as necessary. This
is now fixed as far as linux-next is concerned, but any non trivial
conflicts should be mentioned to your upstream maintainer when your tree
is submitted for merging. You may also want to consider cooperating
with the maintainer of the conflicting tree to minimise any particularly
complex conflicts.

--
Cheers,
Stephen Rothwell

diff --cc include/linux/fs.h
index be8de5925a12,b3a210bfea85..000000000000
--- a/include/linux/fs.h
+++ b/include/linux/fs.h
@@@ -152,10 -158,10 +158,13 @@@ typedef int (dio_iodone_t)(struct kioc
#define FMODE_NONOTIFY ((__force fmode_t)0x4000000)

/* File is capable of returning -EAGAIN if I/O will block */
--#define FMODE_NOWAIT ((__force fmode_t)0x8000000)
++#define FMODE_NOWAIT ((__force fmode_t)0x8000000)
+
+ /* File represents mount that needs unmounting */
-#define FMODE_NEED_UNMOUNT ((__force fmode_t)0x10000000)
++#define FMODE_NEED_UNMOUNT ((__force fmode_t)0x10000000)
+
+/* File does not contribute to nr_files count */
- #define FMODE_NOACCOUNT ((__force fmode_t)0x20000000)
++#define FMODE_NOACCOUNT ((__force fmode_t)0x20000000)

/*
* Flag for rw_copy_check_uvector and compat_rw_copy_check_uvector
@@@ -2419,8 -2445,10 +2442,12 @@@ extern struct file *filp_open(const cha
extern struct file *file_open_root(struct dentry *, struct vfsmount *,
const char *, int, umode_t);
extern struct file * dentry_open(const struct path *, int, const struct cred *);
+extern struct file *path_open(const struct path *, int, struct inode *,
+ const struct cred *, bool);
+ static inline struct file *file_clone_open(struct file *file)
+ {
+ return dentry_open(&file->f_path, file->f_flags, file->f_cred);
+ }
extern int filp_close(struct file *, fl_owner_t id);

extern struct filename *getname_flags(const char __user *, int, int *);

Attachment: pgplc6t1r_ja8.pgp
Description: OpenPGP digital signature