]> git.proxmox.com Git - mirror_ubuntu-artful-kernel.git/blame - include/linux/namei.h
security: prevent permission checking of file removal via sysfs_remove_group()
[mirror_ubuntu-artful-kernel.git] / include / linux / namei.h
CommitLineData
1da177e4
LT
1#ifndef _LINUX_NAMEI_H
2#define _LINUX_NAMEI_H
3
82b0547c 4#include <linux/dcache.h>
1da177e4
LT
5#include <linux/linkage.h>
6
7struct vfsmount;
8
9struct open_intent {
10 int flags;
11 int create_mode;
834f2a4a 12 struct file *file;
1da177e4
LT
13};
14
737bebd1 15enum { MAX_NESTED_LINKS = 8 };
1da177e4
LT
16
17struct nameidata {
18 struct dentry *dentry;
19 struct vfsmount *mnt;
20 struct qstr last;
21 unsigned int flags;
22 int last_type;
23 unsigned depth;
24 char *saved_names[MAX_NESTED_LINKS + 1];
25
26 /* Intent data */
27 union {
28 struct open_intent open;
29 } intent;
30};
31
346f20ff
JJS
32struct path {
33 struct vfsmount *mnt;
34 struct dentry *dentry;
35};
36
1da177e4
LT
37/*
38 * Type of the last component on LOOKUP_PARENT
39 */
40enum {LAST_NORM, LAST_ROOT, LAST_DOT, LAST_DOTDOT, LAST_BIND};
41
42/*
43 * The bitmask for a lookup event:
44 * - follow links at the end
45 * - require a directory
46 * - ending slashes ok even for nonexistent files
47 * - internal "there are more path compnents" flag
48 * - locked when lookup done with dcache_lock held
49 * - dentry cache is untrusted; force a real lookup
50 */
51#define LOOKUP_FOLLOW 1
52#define LOOKUP_DIRECTORY 2
53#define LOOKUP_CONTINUE 4
54#define LOOKUP_PARENT 16
55#define LOOKUP_NOALT 32
56#define LOOKUP_REVAL 64
57/*
58 * Intent data
59 */
60#define LOOKUP_OPEN (0x0100)
61#define LOOKUP_CREATE (0x0200)
62#define LOOKUP_ACCESS (0x0400)
650a8983 63#define LOOKUP_CHDIR (0x0800)
1da177e4
LT
64
65extern int FASTCALL(__user_walk(const char __user *, unsigned, struct nameidata *));
5590ff0d 66extern int FASTCALL(__user_walk_fd(int dfd, const char __user *, unsigned, struct nameidata *));
1da177e4 67#define user_path_walk(name,nd) \
5590ff0d 68 __user_walk_fd(AT_FDCWD, name, LOOKUP_FOLLOW, nd)
1da177e4 69#define user_path_walk_link(name,nd) \
5590ff0d 70 __user_walk_fd(AT_FDCWD, name, 0, nd)
1da177e4
LT
71extern int FASTCALL(path_lookup(const char *, unsigned, struct nameidata *));
72extern int FASTCALL(path_walk(const char *, struct nameidata *));
73extern int FASTCALL(link_path_walk(const char *, struct nameidata *));
74extern void path_release(struct nameidata *);
75extern void path_release_on_umount(struct nameidata *);
76
834f2a4a 77extern int __user_path_lookup_open(const char __user *, unsigned lookup_flags, struct nameidata *nd, int open_flags);
5590ff0d 78extern int path_lookup_open(int dfd, const char *name, unsigned lookup_flags, struct nameidata *, int open_flags);
834f2a4a
TM
79extern struct file *lookup_instantiate_filp(struct nameidata *nd, struct dentry *dentry,
80 int (*open)(struct inode *, struct file *));
81extern struct file *nameidata_to_filp(struct nameidata *nd, int flags);
82extern void release_open_intent(struct nameidata *);
83
1da177e4 84extern struct dentry * lookup_one_len(const char *, struct dentry *, int);
057f6c01 85extern struct dentry *lookup_one_len_kern(const char *, struct dentry *, int);
1da177e4
LT
86
87extern int follow_down(struct vfsmount **, struct dentry **);
88extern int follow_up(struct vfsmount **, struct dentry **);
89
90extern struct dentry *lock_rename(struct dentry *, struct dentry *);
91extern void unlock_rename(struct dentry *, struct dentry *);
92
93static inline void nd_set_link(struct nameidata *nd, char *path)
94{
95 nd->saved_names[nd->depth] = path;
96}
97
98static inline char *nd_get_link(struct nameidata *nd)
99{
100 return nd->saved_names[nd->depth];
101}
102
103#endif /* _LINUX_NAMEI_H */