diff options
| author | Thomas Gleixner <tglx@linutronix.de> | 2009-05-20 09:02:28 +0200 | 
|---|---|---|
| committer | Thomas Gleixner <tglx@linutronix.de> | 2009-05-20 09:02:28 +0200 | 
| commit | 521c180874dae86f675d23c4eade4dba8b1f2cc8 (patch) | |
| tree | 7509303da3a9a1b40a26f6811f321c89cd31737b /fs/proc/base.c | |
| parent | f1a11e0576c7a73d759d05d776692b2b2d37172b (diff) | |
| parent | 64d1304a64477629cb16b75491a77bafe6f86963 (diff) | |
Merge branch 'core/urgent' into core/futexes
Merge reason: this branch was on an pre -rc1 base, merge it up to -rc6+
              to get the latest upstream fixes.
Conflicts:
	kernel/futex.c
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'fs/proc/base.c')
| -rw-r--r-- | fs/proc/base.c | 9 | 
1 files changed, 6 insertions, 3 deletions
diff --git a/fs/proc/base.c b/fs/proc/base.c index f71559784bf..fb45615943c 100644 --- a/fs/proc/base.c +++ b/fs/proc/base.c @@ -322,7 +322,10 @@ static int proc_pid_wchan(struct task_struct *task, char *buffer)  	wchan = get_wchan(task);  	if (lookup_symbol_name(wchan, symname) < 0) -		return sprintf(buffer, "%lu", wchan); +		if (!ptrace_may_access(task, PTRACE_MODE_READ)) +			return 0; +		else +			return sprintf(buffer, "%lu", wchan);  	else  		return sprintf(buffer, "%s", symname);  } @@ -648,14 +651,14 @@ static unsigned mounts_poll(struct file *file, poll_table *wait)  {  	struct proc_mounts *p = file->private_data;  	struct mnt_namespace *ns = p->ns; -	unsigned res = 0; +	unsigned res = POLLIN | POLLRDNORM;  	poll_wait(file, &ns->poll, wait);  	spin_lock(&vfsmount_lock);  	if (p->event != ns->event) {  		p->event = ns->event; -		res = POLLERR; +		res |= POLLERR | POLLPRI;  	}  	spin_unlock(&vfsmount_lock);  | 
