Pull VFS updates from Al Viro,
Misc cleanups all over the place, mainly wrt /proc interfaces (switch
create_proc_entry to proc_create(), get rid of the deprecated
create_proc_read_entry() in favor of using proc_create_data() and
seq_file etc).
7kloc removed.
* 'for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/viro/vfs: (204 commits)
  don't bother with deferred freeing of fdtables
  proc: Move non-public stuff from linux/proc_fs.h to fs/proc/internal.h
  proc: Make the PROC_I() and PDE() macros internal to procfs
  proc: Supply a function to remove a proc entry by PDE
  take cgroup_open() and cpuset_open() to fs/proc/base.c
  ppc: Clean up scanlog
  ppc: Clean up rtas_flash driver somewhat
  hostap: proc: Use remove_proc_subtree()
  drm: proc: Use remove_proc_subtree()
  drm: proc: Use minor->index to label things, not PDE->name
  drm: Constify drm_proc_list[]
  zoran: Don't print proc_dir_entry data in debug
  reiserfs: Don't access the proc_dir_entry in r_open(), r_start() r_show()
  proc: Supply an accessor for getting the data from a PDE's parent
  airo: Use remove_proc_subtree()
  rtl8192u: Don't need to save device proc dir PDE
  rtl8187se: Use a dir under /proc/net/r8180/
  proc: Add proc_mkdir_data()
  proc: Move some bits from linux/proc_fs.h to linux/{of.h,signal.h,tty.h}
  proc: Move PDE_NET() to fs/proc/proc_net.c
  ...
		
	
			
		
			
				
	
	
		
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			49 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  linux/fs/pnode.h
 | |
|  *
 | |
|  * (C) Copyright IBM Corporation 2005.
 | |
|  *	Released under GPL v2.
 | |
|  *
 | |
|  */
 | |
| #ifndef _LINUX_PNODE_H
 | |
| #define _LINUX_PNODE_H
 | |
| 
 | |
| #include <linux/list.h>
 | |
| #include "mount.h"
 | |
| 
 | |
| #define IS_MNT_SHARED(m) ((m)->mnt.mnt_flags & MNT_SHARED)
 | |
| #define IS_MNT_SLAVE(m) ((m)->mnt_master)
 | |
| #define IS_MNT_NEW(m)  (!(m)->mnt_ns)
 | |
| #define CLEAR_MNT_SHARED(m) ((m)->mnt.mnt_flags &= ~MNT_SHARED)
 | |
| #define IS_MNT_UNBINDABLE(m) ((m)->mnt.mnt_flags & MNT_UNBINDABLE)
 | |
| 
 | |
| #define CL_EXPIRE    		0x01
 | |
| #define CL_SLAVE     		0x02
 | |
| #define CL_COPY_ALL 		0x04
 | |
| #define CL_MAKE_SHARED 		0x08
 | |
| #define CL_PRIVATE 		0x10
 | |
| #define CL_SHARED_TO_SLAVE	0x20
 | |
| #define CL_UNPRIVILEGED		0x40
 | |
| 
 | |
| static inline void set_mnt_shared(struct mount *mnt)
 | |
| {
 | |
| 	mnt->mnt.mnt_flags &= ~MNT_SHARED_MASK;
 | |
| 	mnt->mnt.mnt_flags |= MNT_SHARED;
 | |
| }
 | |
| 
 | |
| void change_mnt_propagation(struct mount *, int);
 | |
| int propagate_mnt(struct mount *, struct mountpoint *, struct mount *,
 | |
| 		struct list_head *);
 | |
| int propagate_umount(struct list_head *);
 | |
| int propagate_mount_busy(struct mount *, int);
 | |
| void mnt_release_group_id(struct mount *);
 | |
| int get_dominating_id(struct mount *mnt, const struct path *root);
 | |
| unsigned int mnt_get_count(struct mount *mnt);
 | |
| void mnt_set_mountpoint(struct mount *, struct mountpoint *,
 | |
| 			struct mount *);
 | |
| void umount_tree(struct mount *, int);
 | |
| struct mount *copy_tree(struct mount *, struct dentry *, int);
 | |
| bool is_path_reachable(struct mount *, struct dentry *,
 | |
| 			 const struct path *root);
 | |
| #endif /* _LINUX_PNODE_H */
 |