mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	aufs5: aufs-base
Signed-off-by: Bruce Ashfield <bruce.ashfield@gmail.com>
This commit is contained in:
		
							parent
							
								
									2b182fbb2d
								
							
						
					
					
						commit
						9ce6b74ad9
					
				
							
								
								
									
										13
									
								
								MAINTAINERS
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								MAINTAINERS
									
									
									
									
									
								
							|  | @ -3089,6 +3089,19 @@ F:	include/uapi/linux/audit.h | |||
| F:	kernel/audit* | ||||
| F:	lib/*audit.c | ||||
| 
 | ||||
| AUFS (advanced multi layered unification filesystem) FILESYSTEM | ||||
| M:	"J. R. Okajima" <hooanon05g@gmail.com> | ||||
| L:	aufs-users@lists.sourceforge.net (members only) | ||||
| L:	linux-unionfs@vger.kernel.org | ||||
| S:	Supported | ||||
| W:	http://aufs.sourceforge.net | ||||
| T:	git://github.com/sfjro/aufs4-linux.git | ||||
| F:	Documentation/ABI/testing/debugfs-aufs | ||||
| F:	Documentation/ABI/testing/sysfs-aufs | ||||
| F:	Documentation/filesystems/aufs/ | ||||
| F:	fs/aufs/ | ||||
| F:	include/uapi/linux/aufs_type.h | ||||
| 
 | ||||
| AUXILIARY DISPLAY DRIVERS | ||||
| M:	Miguel Ojeda <ojeda@kernel.org> | ||||
| S:	Maintained | ||||
|  |  | |||
|  | @ -810,6 +810,24 @@ out_putf: | |||
| 	return error; | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * for AUFS | ||||
|  * no get/put for file. | ||||
|  */ | ||||
| struct file *loop_backing_file(struct super_block *sb) | ||||
| { | ||||
| 	struct file *ret; | ||||
| 	struct loop_device *l; | ||||
| 
 | ||||
| 	ret = NULL; | ||||
| 	if (MAJOR(sb->s_dev) == LOOP_MAJOR) { | ||||
| 		l = sb->s_bdev->bd_disk->private_data; | ||||
| 		ret = l->lo_backing_file; | ||||
| 	} | ||||
| 	return ret; | ||||
| } | ||||
| EXPORT_SYMBOL_GPL(loop_backing_file); | ||||
| 
 | ||||
| /* loop sysfs attributes */ | ||||
| 
 | ||||
| static ssize_t loop_attr_show(struct device *dev, char *page, | ||||
|  |  | |||
|  | @ -1320,7 +1320,7 @@ enum d_walk_ret { | |||
|  * | ||||
|  * The @enter() callbacks are called with d_lock held. | ||||
|  */ | ||||
| static void d_walk(struct dentry *parent, void *data, | ||||
| void d_walk(struct dentry *parent, void *data, | ||||
| 		   enum d_walk_ret (*enter)(void *, struct dentry *)) | ||||
| { | ||||
| 	struct dentry *this_parent; | ||||
|  |  | |||
|  | @ -33,7 +33,7 @@ | |||
| 
 | ||||
| #define SETFL_MASK (O_APPEND | O_NONBLOCK | O_NDELAY | O_DIRECT | O_NOATIME) | ||||
| 
 | ||||
| static int setfl(int fd, struct file * filp, unsigned long arg) | ||||
| int setfl(int fd, struct file *filp, unsigned long arg) | ||||
| { | ||||
| 	struct inode * inode = file_inode(filp); | ||||
| 	int error = 0; | ||||
|  | @ -64,6 +64,8 @@ static int setfl(int fd, struct file * filp, unsigned long arg) | |||
| 
 | ||||
| 	if (filp->f_op->check_flags) | ||||
| 		error = filp->f_op->check_flags(arg); | ||||
| 	if (!error && filp->f_op->setfl) | ||||
| 		error = filp->f_op->setfl(filp, arg); | ||||
| 	if (error) | ||||
| 		return error; | ||||
| 
 | ||||
|  |  | |||
|  | @ -1778,7 +1778,7 @@ EXPORT_SYMBOL(generic_update_time); | |||
|  * This does the actual work of updating an inodes time or version.  Must have | ||||
|  * had called mnt_want_write() before calling this. | ||||
|  */ | ||||
| static int update_time(struct inode *inode, struct timespec64 *time, int flags) | ||||
| int update_time(struct inode *inode, struct timespec64 *time, int flags) | ||||
| { | ||||
| 	if (inode->i_op->update_time) | ||||
| 		return inode->i_op->update_time(inode, time, flags); | ||||
|  |  | |||
|  | @ -807,6 +807,12 @@ static inline int check_mnt(struct mount *mnt) | |||
| 	return mnt->mnt_ns == current->nsproxy->mnt_ns; | ||||
| } | ||||
| 
 | ||||
| /* for aufs, CONFIG_AUFS_BR_FUSE */ | ||||
| int is_current_mnt_ns(struct vfsmount *mnt) | ||||
| { | ||||
| 	return check_mnt(real_mount(mnt)); | ||||
| } | ||||
| 
 | ||||
| /*
 | ||||
|  * vfsmount lock must be held for write | ||||
|  */ | ||||
|  |  | |||
							
								
								
									
										10
									
								
								fs/splice.c
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								fs/splice.c
									
									
									
									
									
								
							|  | @ -759,8 +759,8 @@ static int warn_unsupported(struct file *file, const char *op) | |||
| /*
 | ||||
|  * Attempt to initiate a splice from pipe to file. | ||||
|  */ | ||||
| static long do_splice_from(struct pipe_inode_info *pipe, struct file *out, | ||||
| 			   loff_t *ppos, size_t len, unsigned int flags) | ||||
| long do_splice_from(struct pipe_inode_info *pipe, struct file *out, | ||||
| 		    loff_t *ppos, size_t len, unsigned int flags) | ||||
| { | ||||
| 	if (unlikely(!out->f_op->splice_write)) | ||||
| 		return warn_unsupported(out, "write"); | ||||
|  | @ -770,9 +770,9 @@ static long do_splice_from(struct pipe_inode_info *pipe, struct file *out, | |||
| /*
 | ||||
|  * Attempt to initiate a splice from a file to a pipe. | ||||
|  */ | ||||
| static long do_splice_to(struct file *in, loff_t *ppos, | ||||
| 			 struct pipe_inode_info *pipe, size_t len, | ||||
| 			 unsigned int flags) | ||||
| long do_splice_to(struct file *in, loff_t *ppos, | ||||
| 		  struct pipe_inode_info *pipe, size_t len, | ||||
| 		  unsigned int flags) | ||||
| { | ||||
| 	unsigned int p_space; | ||||
| 	int ret; | ||||
|  |  | |||
|  | @ -28,7 +28,7 @@ | |||
|  * wait == 1 case since in that case write_inode() functions do | ||||
|  * sync_dirty_buffer() and thus effectively write one block at a time. | ||||
|  */ | ||||
| static int __sync_filesystem(struct super_block *sb, int wait) | ||||
| int __sync_filesystem(struct super_block *sb, int wait) | ||||
| { | ||||
| 	if (wait) | ||||
| 		sync_inodes_sb(sb); | ||||
|  |  | |||
|  | @ -1335,6 +1335,7 @@ extern void fasync_free(struct fasync_struct *); | |||
| /* can be called from interrupts */ | ||||
| extern void kill_fasync(struct fasync_struct **, int, int); | ||||
| 
 | ||||
| extern int setfl(int fd, struct file *filp, unsigned long arg); | ||||
| extern void __f_setown(struct file *filp, struct pid *, enum pid_type, int force); | ||||
| extern int f_setown(struct file *filp, unsigned long arg, int force); | ||||
| extern void f_delown(struct file *filp); | ||||
|  | @ -2043,6 +2044,7 @@ struct file_operations { | |||
| 	ssize_t (*sendpage) (struct file *, struct page *, int, size_t, loff_t *, int); | ||||
| 	unsigned long (*get_unmapped_area)(struct file *, unsigned long, unsigned long, unsigned long, unsigned long); | ||||
| 	int (*check_flags)(int); | ||||
| 	int (*setfl)(struct file *, unsigned long); | ||||
| 	int (*flock) (struct file *, int, struct file_lock *); | ||||
| 	ssize_t (*splice_write)(struct pipe_inode_info *, struct file *, loff_t *, size_t, unsigned int); | ||||
| 	ssize_t (*splice_read)(struct file *, loff_t *, struct pipe_inode_info *, size_t, unsigned int); | ||||
|  | @ -2564,6 +2566,7 @@ extern int current_umask(void); | |||
| extern void ihold(struct inode * inode); | ||||
| extern void iput(struct inode *); | ||||
| extern int generic_update_time(struct inode *, struct timespec64 *, int); | ||||
| extern int update_time(struct inode *, struct timespec64 *, int); | ||||
| 
 | ||||
| /* /sys/fs */ | ||||
| extern struct kobject *fs_kobj; | ||||
|  | @ -2810,6 +2813,7 @@ static inline bool sb_is_blkdev_sb(struct super_block *sb) | |||
| } | ||||
| 
 | ||||
| void emergency_thaw_all(void); | ||||
| extern int __sync_filesystem(struct super_block *, int); | ||||
| extern int sync_filesystem(struct super_block *); | ||||
| extern const struct file_operations def_blk_fops; | ||||
| extern const struct file_operations def_chr_fops; | ||||
|  |  | |||
|  | @ -248,6 +248,8 @@ static inline int lockdep_match_key(struct lockdep_map *lock, | |||
| 	return lock->key == key; | ||||
| } | ||||
| 
 | ||||
| struct lock_class *lockdep_hlock_class(struct held_lock *hlock); | ||||
| 
 | ||||
| /*
 | ||||
|  * Acquire a lock. | ||||
|  * | ||||
|  |  | |||
|  | @ -7,12 +7,15 @@ struct mnt_namespace; | |||
| struct fs_struct; | ||||
| struct user_namespace; | ||||
| struct ns_common; | ||||
| struct vfsmount; | ||||
| 
 | ||||
| extern struct mnt_namespace *copy_mnt_ns(unsigned long, struct mnt_namespace *, | ||||
| 		struct user_namespace *, struct fs_struct *); | ||||
| extern void put_mnt_ns(struct mnt_namespace *ns); | ||||
| extern struct ns_common *from_mnt_ns(struct mnt_namespace *); | ||||
| 
 | ||||
| extern int is_current_mnt_ns(struct vfsmount *mnt); | ||||
| 
 | ||||
| extern const struct file_operations proc_mounts_operations; | ||||
| extern const struct file_operations proc_mountinfo_operations; | ||||
| extern const struct file_operations proc_mountstats_operations; | ||||
|  |  | |||
|  | @ -93,4 +93,10 @@ extern void splice_shrink_spd(struct splice_pipe_desc *); | |||
| 
 | ||||
| extern const struct pipe_buf_operations page_cache_pipe_buf_ops; | ||||
| extern const struct pipe_buf_operations default_pipe_buf_ops; | ||||
| 
 | ||||
| extern long do_splice_from(struct pipe_inode_info *pipe, struct file *out, | ||||
| 			   loff_t *ppos, size_t len, unsigned int flags); | ||||
| extern long do_splice_to(struct file *in, loff_t *ppos, | ||||
| 			 struct pipe_inode_info *pipe, size_t len, | ||||
| 			 unsigned int flags); | ||||
| #endif | ||||
|  |  | |||
|  | @ -189,7 +189,7 @@ static | |||
| struct lock_class lock_classes[MAX_LOCKDEP_KEYS]; | ||||
| static DECLARE_BITMAP(lock_classes_in_use, MAX_LOCKDEP_KEYS); | ||||
| 
 | ||||
| static inline struct lock_class *hlock_class(struct held_lock *hlock) | ||||
| inline struct lock_class *lockdep_hlock_class(struct held_lock *hlock) | ||||
| { | ||||
| 	unsigned int class_idx = hlock->class_idx; | ||||
| 
 | ||||
|  | @ -210,6 +210,7 @@ static inline struct lock_class *hlock_class(struct held_lock *hlock) | |||
| 	 */ | ||||
| 	return lock_classes + class_idx; | ||||
| } | ||||
| #define hlock_class(hlock) lockdep_hlock_class(hlock) | ||||
| 
 | ||||
| #ifdef CONFIG_LOCK_STAT | ||||
| static DEFINE_PER_CPU(struct lock_class_stats[MAX_LOCKDEP_KEYS], cpu_lock_stats); | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Bruce Ashfield
						Bruce Ashfield