Skip to content

Commit

Permalink
---
Browse files Browse the repository at this point in the history
yaml
---
r: 156605
b: refs/heads/master
c: 704b836
h: refs/heads/master
i:
  156603: e8a3870
v: v3
  • Loading branch information
Oleg Nesterov authored and James Morris committed Aug 10, 2009
1 parent 7eeba22 commit d6b9eac
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 12 deletions.
2 changes: 1 addition & 1 deletion [refs]
Original file line number Diff line number Diff line change
@@ -1,2 +1,2 @@
---
refs/heads/master: 00f89d218523b9bf6b522349c039d5ac80aa536d
refs/heads/master: 704b836cbf19e885f8366bccb2e4b0474346c02d
22 changes: 11 additions & 11 deletions trunk/fs/proc/base.c
Original file line number Diff line number Diff line change
Expand Up @@ -234,19 +234,19 @@ static int check_mem_permission(struct task_struct *task)

struct mm_struct *mm_for_maps(struct task_struct *task)
{
struct mm_struct *mm = get_task_mm(task);
struct mm_struct *mm;

if (mm && mm != current->mm) {
/*
* task->mm can be changed before security check,
* in that case we must notice the change after.
*/
if (!ptrace_may_access(task, PTRACE_MODE_READ) ||
mm != task->mm) {
mmput(mm);
mm = NULL;
}
if (mutex_lock_killable(&task->cred_guard_mutex))
return NULL;

mm = get_task_mm(task);
if (mm && mm != current->mm &&
!ptrace_may_access(task, PTRACE_MODE_READ)) {
mmput(mm);
mm = NULL;
}
mutex_unlock(&task->cred_guard_mutex);

return mm;
}

Expand Down

0 comments on commit d6b9eac

Please sign in to comment.