diff options
| author | Paul Mundt <lethal@linux-sh.org> | 2008-10-21 12:07:40 +0900 | 
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-10-20 20:17:18 -0700 | 
| commit | 2515ddc6db8eb49a79f0fe5e67ff09ac7c81eab4 (patch) | |
| tree | b5c9983fd79b6627e47e80a74b68ad15cf2d9b41 | |
| parent | a50c22eed593f474e75f693381e4d42e81762de8 (diff) | |
| download | olio-linux-3.10-2515ddc6db8eb49a79f0fe5e67ff09ac7c81eab4.tar.xz olio-linux-3.10-2515ddc6db8eb49a79f0fe5e67ff09ac7c81eab4.zip  | |
binfmt_elf_fdpic: Update for cputime changes.
Commit f06febc96ba8e0af80bcc3eaec0a109e88275fac ("timers: fix itimer/
many thread hang") introduced a new task_cputime interface and
subsequently only converted binfmt_elf over to it.  This results in the
build for binfmt_elf_fdpic blowing up given that p->signal->{u,s}time
have disappeared from underneath us.
Apply the same trivial fix from binfmt_elf to binfmt_elf_fdpic.
Signed-off-by: Paul Mundt <lethal@linux-sh.org>
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
| -rw-r--r-- | fs/binfmt_elf_fdpic.c | 19 | 
1 files changed, 7 insertions, 12 deletions
diff --git a/fs/binfmt_elf_fdpic.c b/fs/binfmt_elf_fdpic.c index 0e8367c5462..5b5424cb339 100644 --- a/fs/binfmt_elf_fdpic.c +++ b/fs/binfmt_elf_fdpic.c @@ -1390,20 +1390,15 @@ static void fill_prstatus(struct elf_prstatus *prstatus,  	prstatus->pr_pgrp = task_pgrp_vnr(p);  	prstatus->pr_sid = task_session_vnr(p);  	if (thread_group_leader(p)) { +		struct task_cputime cputime; +  		/* -		 * This is the record for the group leader.  Add in the -		 * cumulative times of previous dead threads.  This total -		 * won't include the time of each live thread whose state -		 * is included in the core dump.  The final total reported -		 * to our parent process when it calls wait4 will include -		 * those sums as well as the little bit more time it takes -		 * this and each other thread to finish dying after the -		 * core dump synchronization phase. +		 * This is the record for the group leader.  It shows the +		 * group-wide total, not its individual thread total.  		 */ -		cputime_to_timeval(cputime_add(p->utime, p->signal->utime), -				   &prstatus->pr_utime); -		cputime_to_timeval(cputime_add(p->stime, p->signal->stime), -				   &prstatus->pr_stime); +		thread_group_cputime(p, &cputime); +		cputime_to_timeval(cputime.utime, &prstatus->pr_utime); +		cputime_to_timeval(cputime.stime, &prstatus->pr_stime);  	} else {  		cputime_to_timeval(p->utime, &prstatus->pr_utime);  		cputime_to_timeval(p->stime, &prstatus->pr_stime);  |