|
@@ -890,7 +890,7 @@ static struct file_operations proc_seccomp_operations = {
|
|
};
|
|
};
|
|
#endif /* CONFIG_SECCOMP */
|
|
#endif /* CONFIG_SECCOMP */
|
|
|
|
|
|
-static int proc_pid_follow_link(struct dentry *dentry, struct nameidata *nd)
|
|
|
|
|
|
+static void *proc_pid_follow_link(struct dentry *dentry, struct nameidata *nd)
|
|
{
|
|
{
|
|
struct inode *inode = dentry->d_inode;
|
|
struct inode *inode = dentry->d_inode;
|
|
int error = -EACCES;
|
|
int error = -EACCES;
|
|
@@ -907,7 +907,7 @@ static int proc_pid_follow_link(struct dentry *dentry, struct nameidata *nd)
|
|
error = PROC_I(inode)->op.proc_get_link(inode, &nd->dentry, &nd->mnt);
|
|
error = PROC_I(inode)->op.proc_get_link(inode, &nd->dentry, &nd->mnt);
|
|
nd->last_type = LAST_BIND;
|
|
nd->last_type = LAST_BIND;
|
|
out:
|
|
out:
|
|
- return error;
|
|
|
|
|
|
+ return ERR_PTR(error);
|
|
}
|
|
}
|
|
|
|
|
|
static int do_proc_readlink(struct dentry *dentry, struct vfsmount *mnt,
|
|
static int do_proc_readlink(struct dentry *dentry, struct vfsmount *mnt,
|
|
@@ -1692,11 +1692,11 @@ static int proc_self_readlink(struct dentry *dentry, char __user *buffer,
|
|
return vfs_readlink(dentry,buffer,buflen,tmp);
|
|
return vfs_readlink(dentry,buffer,buflen,tmp);
|
|
}
|
|
}
|
|
|
|
|
|
-static int proc_self_follow_link(struct dentry *dentry, struct nameidata *nd)
|
|
|
|
|
|
+static void *proc_self_follow_link(struct dentry *dentry, struct nameidata *nd)
|
|
{
|
|
{
|
|
char tmp[30];
|
|
char tmp[30];
|
|
sprintf(tmp, "%d", current->tgid);
|
|
sprintf(tmp, "%d", current->tgid);
|
|
- return vfs_follow_link(nd,tmp);
|
|
|
|
|
|
+ return ERR_PTR(vfs_follow_link(nd,tmp));
|
|
}
|
|
}
|
|
|
|
|
|
static struct inode_operations proc_self_inode_operations = {
|
|
static struct inode_operations proc_self_inode_operations = {
|