diff options
Diffstat (limited to 'fs')
-rw-r--r-- | fs/namei.c | 48 |
1 files changed, 16 insertions, 32 deletions
diff --git a/fs/namei.c b/fs/namei.c index 6ce27d6db684..b2b22f244180 100644 --- a/fs/namei.c +++ b/fs/namei.c | |||
@@ -1124,36 +1124,6 @@ int vfs_path_lookup(struct dentry *dentry, struct vfsmount *mnt, | |||
1124 | return retval; | 1124 | return retval; |
1125 | } | 1125 | } |
1126 | 1126 | ||
1127 | /** | ||
1128 | * path_lookup_open - lookup a file path with open intent | ||
1129 | * @dfd: the directory to use as base, or AT_FDCWD | ||
1130 | * @name: pointer to file name | ||
1131 | * @lookup_flags: lookup intent flags | ||
1132 | * @nd: pointer to nameidata | ||
1133 | * @open_flags: open intent flags | ||
1134 | */ | ||
1135 | static int path_lookup_open(int dfd, const char *name, | ||
1136 | unsigned int lookup_flags, struct nameidata *nd, int open_flags) | ||
1137 | { | ||
1138 | struct file *filp = get_empty_filp(); | ||
1139 | int err; | ||
1140 | |||
1141 | if (filp == NULL) | ||
1142 | return -ENFILE; | ||
1143 | nd->intent.open.file = filp; | ||
1144 | nd->intent.open.flags = open_flags; | ||
1145 | nd->intent.open.create_mode = 0; | ||
1146 | err = do_path_lookup(dfd, name, lookup_flags|LOOKUP_OPEN, nd); | ||
1147 | if (IS_ERR(nd->intent.open.file)) { | ||
1148 | if (err == 0) { | ||
1149 | err = PTR_ERR(nd->intent.open.file); | ||
1150 | path_put(&nd->path); | ||
1151 | } | ||
1152 | } else if (err != 0) | ||
1153 | release_open_intent(nd); | ||
1154 | return err; | ||
1155 | } | ||
1156 | |||
1157 | static struct dentry *__lookup_hash(struct qstr *name, | 1127 | static struct dentry *__lookup_hash(struct qstr *name, |
1158 | struct dentry *base, struct nameidata *nd) | 1128 | struct dentry *base, struct nameidata *nd) |
1159 | { | 1129 | { |
@@ -1664,8 +1634,22 @@ struct file *do_filp_open(int dfd, const char *pathname, | |||
1664 | * The simplest case - just a plain lookup. | 1634 | * The simplest case - just a plain lookup. |
1665 | */ | 1635 | */ |
1666 | if (!(flag & O_CREAT)) { | 1636 | if (!(flag & O_CREAT)) { |
1667 | error = path_lookup_open(dfd, pathname, lookup_flags(flag), | 1637 | filp = get_empty_filp(); |
1668 | &nd, flag); | 1638 | |
1639 | if (filp == NULL) | ||
1640 | return ERR_PTR(-ENFILE); | ||
1641 | nd.intent.open.file = filp; | ||
1642 | nd.intent.open.flags = flag; | ||
1643 | nd.intent.open.create_mode = 0; | ||
1644 | error = do_path_lookup(dfd, pathname, | ||
1645 | lookup_flags(flag)|LOOKUP_OPEN, &nd); | ||
1646 | if (IS_ERR(nd.intent.open.file)) { | ||
1647 | if (error == 0) { | ||
1648 | error = PTR_ERR(nd.intent.open.file); | ||
1649 | path_put(&nd.path); | ||
1650 | } | ||
1651 | } else if (error) | ||
1652 | release_open_intent(&nd); | ||
1669 | if (error) | 1653 | if (error) |
1670 | return ERR_PTR(error); | 1654 | return ERR_PTR(error); |
1671 | goto ok; | 1655 | goto ok; |