aboutsummaryrefslogtreecommitdiffstats
path: root/mm/migrate.c
diff options
context:
space:
mode:
Diffstat (limited to 'mm/migrate.c')
-rw-r--r--mm/migrate.c9
1 files changed, 7 insertions, 2 deletions
diff --git a/mm/migrate.c b/mm/migrate.c
index 385db89f0c33..9dd10da1cc23 100644
--- a/mm/migrate.c
+++ b/mm/migrate.c
@@ -1045,6 +1045,7 @@ asmlinkage long sys_move_pages(pid_t pid, unsigned long nr_pages,
1045 const int __user *nodes, 1045 const int __user *nodes,
1046 int __user *status, int flags) 1046 int __user *status, int flags)
1047{ 1047{
1048 const struct cred *cred = current_cred(), *tcred;
1048 struct task_struct *task; 1049 struct task_struct *task;
1049 struct mm_struct *mm; 1050 struct mm_struct *mm;
1050 int err; 1051 int err;
@@ -1075,12 +1076,16 @@ asmlinkage long sys_move_pages(pid_t pid, unsigned long nr_pages,
1075 * capabilities, superuser privileges or the same 1076 * capabilities, superuser privileges or the same
1076 * userid as the target process. 1077 * userid as the target process.
1077 */ 1078 */
1078 if ((current->euid != task->suid) && (current->euid != task->uid) && 1079 rcu_read_lock();
1079 (current->uid != task->suid) && (current->uid != task->uid) && 1080 tcred = __task_cred(task);
1081 if (cred->euid != tcred->suid && cred->euid != tcred->uid &&
1082 cred->uid != tcred->suid && cred->uid != tcred->uid &&
1080 !capable(CAP_SYS_NICE)) { 1083 !capable(CAP_SYS_NICE)) {
1084 rcu_read_unlock();
1081 err = -EPERM; 1085 err = -EPERM;
1082 goto out; 1086 goto out;
1083 } 1087 }
1088 rcu_read_unlock();
1084 1089
1085 err = security_task_movememory(task); 1090 err = security_task_movememory(task);
1086 if (err) 1091 if (err)