switch security_inode_getattr() to struct path *
Signed-off-by: Al Viro <viro@zeniv.linux.org.uk>
This commit is contained in:
		| @@ -66,7 +66,7 @@ int vfs_getattr(struct path *path, struct kstat *stat) | ||||
| { | ||||
| 	int retval; | ||||
|  | ||||
| 	retval = security_inode_getattr(path->mnt, path->dentry); | ||||
| 	retval = security_inode_getattr(path); | ||||
| 	if (retval) | ||||
| 		return retval; | ||||
| 	return vfs_getattr_nosec(path, stat); | ||||
|   | ||||
| @@ -1556,7 +1556,7 @@ struct security_operations { | ||||
| 	int (*inode_follow_link) (struct dentry *dentry, struct nameidata *nd); | ||||
| 	int (*inode_permission) (struct inode *inode, int mask); | ||||
| 	int (*inode_setattr)	(struct dentry *dentry, struct iattr *attr); | ||||
| 	int (*inode_getattr) (struct vfsmount *mnt, struct dentry *dentry); | ||||
| 	int (*inode_getattr) (const struct path *path); | ||||
| 	int (*inode_setxattr) (struct dentry *dentry, const char *name, | ||||
| 			       const void *value, size_t size, int flags); | ||||
| 	void (*inode_post_setxattr) (struct dentry *dentry, const char *name, | ||||
| @@ -1843,7 +1843,7 @@ int security_inode_readlink(struct dentry *dentry); | ||||
| int security_inode_follow_link(struct dentry *dentry, struct nameidata *nd); | ||||
| int security_inode_permission(struct inode *inode, int mask); | ||||
| int security_inode_setattr(struct dentry *dentry, struct iattr *attr); | ||||
| int security_inode_getattr(struct vfsmount *mnt, struct dentry *dentry); | ||||
| int security_inode_getattr(const struct path *path); | ||||
| int security_inode_setxattr(struct dentry *dentry, const char *name, | ||||
| 			    const void *value, size_t size, int flags); | ||||
| void security_inode_post_setxattr(struct dentry *dentry, const char *name, | ||||
| @@ -2259,8 +2259,7 @@ static inline int security_inode_setattr(struct dentry *dentry, | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static inline int security_inode_getattr(struct vfsmount *mnt, | ||||
| 					  struct dentry *dentry) | ||||
| static inline int security_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	return 0; | ||||
| } | ||||
|   | ||||
| @@ -364,12 +364,12 @@ static int apparmor_path_chown(struct path *path, kuid_t uid, kgid_t gid) | ||||
| 	return common_perm(OP_CHOWN, path, AA_MAY_CHOWN, &cond); | ||||
| } | ||||
|  | ||||
| static int apparmor_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| static int apparmor_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	if (!mediated_filesystem(dentry)) | ||||
| 	if (!mediated_filesystem(path->dentry)) | ||||
| 		return 0; | ||||
|  | ||||
| 	return common_perm_mnt_dentry(OP_GETATTR, mnt, dentry, | ||||
| 	return common_perm_mnt_dentry(OP_GETATTR, path->mnt, path->dentry, | ||||
| 				      AA_MAY_META_READ); | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -225,7 +225,7 @@ static int cap_inode_setattr(struct dentry *dentry, struct iattr *iattr) | ||||
| 	return 0; | ||||
| } | ||||
|  | ||||
| static int cap_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| static int cap_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	return 0; | ||||
| } | ||||
|   | ||||
| @@ -608,11 +608,11 @@ int security_inode_setattr(struct dentry *dentry, struct iattr *attr) | ||||
| } | ||||
| EXPORT_SYMBOL_GPL(security_inode_setattr); | ||||
|  | ||||
| int security_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| int security_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	if (unlikely(IS_PRIVATE(dentry->d_inode))) | ||||
| 	if (unlikely(IS_PRIVATE(path->dentry->d_inode))) | ||||
| 		return 0; | ||||
| 	return security_ops->inode_getattr(mnt, dentry); | ||||
| 	return security_ops->inode_getattr(path); | ||||
| } | ||||
|  | ||||
| int security_inode_setxattr(struct dentry *dentry, const char *name, | ||||
|   | ||||
| @@ -1623,7 +1623,7 @@ static inline int dentry_has_perm(const struct cred *cred, | ||||
|    the path to help the auditing code to more easily generate the | ||||
|    pathname if needed. */ | ||||
| static inline int path_has_perm(const struct cred *cred, | ||||
| 				struct path *path, | ||||
| 				const struct path *path, | ||||
| 				u32 av) | ||||
| { | ||||
| 	struct inode *inode = path->dentry->d_inode; | ||||
| @@ -2954,15 +2954,9 @@ static int selinux_inode_setattr(struct dentry *dentry, struct iattr *iattr) | ||||
| 	return dentry_has_perm(cred, dentry, av); | ||||
| } | ||||
|  | ||||
| static int selinux_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| static int selinux_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	const struct cred *cred = current_cred(); | ||||
| 	struct path path; | ||||
|  | ||||
| 	path.dentry = dentry; | ||||
| 	path.mnt = mnt; | ||||
|  | ||||
| 	return path_has_perm(cred, &path, FILE__GETATTR); | ||||
| 	return path_has_perm(current_cred(), path, FILE__GETATTR); | ||||
| } | ||||
|  | ||||
| static int selinux_inode_setotherxattr(struct dentry *dentry, const char *name) | ||||
|   | ||||
| @@ -1034,19 +1034,16 @@ static int smack_inode_setattr(struct dentry *dentry, struct iattr *iattr) | ||||
|  * | ||||
|  * Returns 0 if access is permitted, an error code otherwise | ||||
|  */ | ||||
| static int smack_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| static int smack_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	struct smk_audit_info ad; | ||||
| 	struct path path; | ||||
| 	struct inode *inode = path->dentry->d_inode; | ||||
| 	int rc; | ||||
|  | ||||
| 	path.dentry = dentry; | ||||
| 	path.mnt = mnt; | ||||
|  | ||||
| 	smk_ad_init(&ad, __func__, LSM_AUDIT_DATA_PATH); | ||||
| 	smk_ad_setfield_u_fs_path(&ad, path); | ||||
| 	rc = smk_curacc(smk_of_inode(dentry->d_inode), MAY_READ, &ad); | ||||
| 	rc = smk_bu_inode(dentry->d_inode, MAY_READ, rc); | ||||
| 	smk_ad_setfield_u_fs_path(&ad, *path); | ||||
| 	rc = smk_curacc(smk_of_inode(inode), MAY_READ, &ad); | ||||
| 	rc = smk_bu_inode(inode, MAY_READ, rc); | ||||
| 	return rc; | ||||
| } | ||||
|  | ||||
|   | ||||
| @@ -978,7 +978,7 @@ int tomoyo_path2_perm(const u8 operation, struct path *path1, | ||||
| 		      struct path *path2); | ||||
| int tomoyo_path_number_perm(const u8 operation, struct path *path, | ||||
| 			    unsigned long number); | ||||
| int tomoyo_path_perm(const u8 operation, struct path *path, | ||||
| int tomoyo_path_perm(const u8 operation, const struct path *path, | ||||
| 		     const char *target); | ||||
| unsigned int tomoyo_poll_control(struct file *file, poll_table *wait); | ||||
| unsigned int tomoyo_poll_log(struct file *file, poll_table *wait); | ||||
|   | ||||
| @@ -145,7 +145,7 @@ static void tomoyo_add_slash(struct tomoyo_path_info *buf) | ||||
|  * | ||||
|  * Returns true on success, false otherwise. | ||||
|  */ | ||||
| static bool tomoyo_get_realpath(struct tomoyo_path_info *buf, struct path *path) | ||||
| static bool tomoyo_get_realpath(struct tomoyo_path_info *buf, const struct path *path) | ||||
| { | ||||
| 	buf->name = tomoyo_realpath_from_path(path); | ||||
| 	if (buf->name) { | ||||
| @@ -782,7 +782,7 @@ int tomoyo_check_open_permission(struct tomoyo_domain_info *domain, | ||||
|  * | ||||
|  * Returns 0 on success, negative value otherwise. | ||||
|  */ | ||||
| int tomoyo_path_perm(const u8 operation, struct path *path, const char *target) | ||||
| int tomoyo_path_perm(const u8 operation, const struct path *path, const char *target) | ||||
| { | ||||
| 	struct tomoyo_request_info r; | ||||
| 	struct tomoyo_obj_info obj = { | ||||
|   | ||||
| @@ -144,10 +144,9 @@ static int tomoyo_bprm_check_security(struct linux_binprm *bprm) | ||||
|  * | ||||
|  * Returns 0 on success, negative value otherwise. | ||||
|  */ | ||||
| static int tomoyo_inode_getattr(struct vfsmount *mnt, struct dentry *dentry) | ||||
| static int tomoyo_inode_getattr(const struct path *path) | ||||
| { | ||||
| 	struct path path = { mnt, dentry }; | ||||
| 	return tomoyo_path_perm(TOMOYO_TYPE_GETATTR, &path, NULL); | ||||
| 	return tomoyo_path_perm(TOMOYO_TYPE_GETATTR, path, NULL); | ||||
| } | ||||
|  | ||||
| /** | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Al Viro
					Al Viro