mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 549c729771
			
		
	
	
		549c729771
		
			
		
	
	
	
	
		
			
			Extend some inode methods with an additional user namespace argument. A filesystem that is aware of idmapped mounts will receive the user namespace the mount has been marked with. This can be used for additional permission checking and also to enable filesystems to translate between uids and gids if they need to. We have implemented all relevant helpers in earlier patches. As requested we simply extend the exisiting inode method instead of introducing new ones. This is a little more code churn but it's mostly mechanical and doesnt't leave us with additional inode methods. Link: https://lore.kernel.org/r/20210121131959.646623-25-christian.brauner@ubuntu.com Cc: Christoph Hellwig <hch@lst.de> Cc: David Howells <dhowells@redhat.com> Cc: Al Viro <viro@zeniv.linux.org.uk> Cc: linux-fsdevel@vger.kernel.org Reviewed-by: Christoph Hellwig <hch@lst.de> Signed-off-by: Christian Brauner <christian.brauner@ubuntu.com>
		
			
				
	
	
		
			44 lines
		
	
	
		
			1005 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1005 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * JFFS2 -- Journalling Flash File System, Version 2.
 | |
|  *
 | |
|  * Copyright © 2006  NEC Corporation
 | |
|  *
 | |
|  * Created by KaiGai Kohei <kaigai@ak.jp.nec.com>
 | |
|  *
 | |
|  * For licensing information, see the file 'LICENCE' in this directory.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| struct jffs2_acl_entry {
 | |
| 	jint16_t	e_tag;
 | |
| 	jint16_t	e_perm;
 | |
| 	jint32_t	e_id;
 | |
| };
 | |
| 
 | |
| struct jffs2_acl_entry_short {
 | |
| 	jint16_t	e_tag;
 | |
| 	jint16_t	e_perm;
 | |
| };
 | |
| 
 | |
| struct jffs2_acl_header {
 | |
| 	jint32_t	a_version;
 | |
| 	struct jffs2_acl_entry	a_entries[];
 | |
| };
 | |
| 
 | |
| #ifdef CONFIG_JFFS2_FS_POSIX_ACL
 | |
| 
 | |
| struct posix_acl *jffs2_get_acl(struct inode *inode, int type);
 | |
| int jffs2_set_acl(struct user_namespace *mnt_userns, struct inode *inode,
 | |
| 		  struct posix_acl *acl, int type);
 | |
| extern int jffs2_init_acl_pre(struct inode *, struct inode *, umode_t *);
 | |
| extern int jffs2_init_acl_post(struct inode *);
 | |
| 
 | |
| #else
 | |
| 
 | |
| #define jffs2_get_acl				(NULL)
 | |
| #define jffs2_set_acl				(NULL)
 | |
| #define jffs2_init_acl_pre(dir_i,inode,mode)	(0)
 | |
| #define jffs2_init_acl_post(inode)		(0)
 | |
| 
 | |
| #endif	/* CONFIG_JFFS2_FS_POSIX_ACL */
 |