diff options
Diffstat (limited to 'fs/proc/base.c')
| -rw-r--r-- | fs/proc/base.c | 14 | 
1 files changed, 10 insertions, 4 deletions
| diff --git a/fs/proc/base.c b/fs/proc/base.c index eafa39a3a88c..1a76d751cf3c 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c @@ -261,7 +261,7 @@ static ssize_t proc_pid_cmdline_read(struct file *file, char __user *buf,  	 * Inherently racy -- command line shares address space  	 * with code and data.  	 */ -	rv = access_remote_vm(mm, arg_end - 1, &c, 1, 0); +	rv = access_remote_vm(mm, arg_end - 1, &c, 1, FOLL_ANON);  	if (rv <= 0)  		goto out_free_page; @@ -279,7 +279,7 @@ static ssize_t proc_pid_cmdline_read(struct file *file, char __user *buf,  			int nr_read;  			_count = min3(count, len, PAGE_SIZE); -			nr_read = access_remote_vm(mm, p, page, _count, 0); +			nr_read = access_remote_vm(mm, p, page, _count, FOLL_ANON);  			if (nr_read < 0)  				rv = nr_read;  			if (nr_read <= 0) @@ -325,7 +325,7 @@ static ssize_t proc_pid_cmdline_read(struct file *file, char __user *buf,  				bool final;  				_count = min3(count, len, PAGE_SIZE); -				nr_read = access_remote_vm(mm, p, page, _count, 0); +				nr_read = access_remote_vm(mm, p, page, _count, FOLL_ANON);  				if (nr_read < 0)  					rv = nr_read;  				if (nr_read <= 0) @@ -946,7 +946,7 @@ static ssize_t environ_read(struct file *file, char __user *buf,  		max_len = min_t(size_t, PAGE_SIZE, count);  		this_len = min(max_len, this_len); -		retval = access_remote_vm(mm, (env_start + src), page, this_len, 0); +		retval = access_remote_vm(mm, (env_start + src), page, this_len, FOLL_ANON);  		if (retval <= 0) {  			ret = retval; @@ -1693,6 +1693,12 @@ void task_dump_owner(struct task_struct *task, umode_t mode,  	kuid_t uid;  	kgid_t gid; +	if (unlikely(task->flags & PF_KTHREAD)) { +		*ruid = GLOBAL_ROOT_UID; +		*rgid = GLOBAL_ROOT_GID; +		return; +	} +  	/* Default to the tasks effective ownership */  	rcu_read_lock();  	cred = __task_cred(task); | 
