Thread (55 messages) 55 messages, 9 authors, 2015-12-15

Re: [PATCH 20/24] task_diag: Only add VMAs for thread_group leader

From: Oleg Nesterov <hidden>
Date: 2015-07-15 13:32:54
Also in: lkml

On 07/14, David Ahern wrote:
On 7/14/15 1:47 PM, Oleg Nesterov wrote:
quoted
quoted
  	if (show_flags & TASK_DIAG_SHOW_VMA) {
+		/* if the request is to dump all threads of all processes
+		 * only show VMAs for group leader.
+		 */
+		if (req->dump_strategy == TASK_DIAG_DUMP_ALL_THREAD &&
+		    !thread_group_leader(tsk))
+			goto done;
+
This doesn't look right, group leader can be a zombie with ->mm == NULL,
Seriously?
Yes, the main thread can do sys_exit() / pthread_exit(), although this
is not that common.
I'll find some way to track whether VMAs have been dumped for
a pid.
In case I confused you, the thread_group_leader() check and "goto done"
above are fine, just you can't trust tsk->mm, so
quoted
quoted
  		if (i >= n)
  			err = fill_vma(tsk, skb, cb, &progress, show_flags);
so this probably needs something like find_lock_task_mm().
ok.
Yes, you just need to (try) find a subthread with ->mm != NULL if !tsk->mm,
find_lock_task_mm() can help.

Oleg.
Keyboard shortcuts
hback out one level
jnext message in thread
kprevious message in thread
ldrill in
Escclose help / fold thread tree
?toggle this help