* Re: [uml-devel] Question about the kernel thread in UML TT mode
[not found] <000c01c55c59$37dd1e50$9eb3c68a@SHZ.ST.COM>
@ 2005-05-19 13:31 ` Blaisorblade
2005-05-19 14:56 ` Jeff Dike
0 siblings, 1 reply; 5+ messages in thread
From: Blaisorblade @ 2005-05-19 13:31 UTC (permalink / raw)
To: user-mode-linux-devel; +Cc: Alex LIU, 'Jeff Dike'
On Thursday 19 May 2005 11:57, Alex LIU wrote:
> On May 18, 2005 9:31 PM, Jeff wrote:
> >> But P and Q are different threads and they will be scheduled
> >> differently,right?
> > No, they're two different ways of looking at the same thread. They're
> > scheduled somewhat differently, but that's just reflecting the two ways
> > of
> looking at it. If it's runnable on the host, it's runnable inside UML, but
> not the other way around.
> Then how does the UML thread interact with its corresponding host thread in
> TT mode? Also use the switch_pipe?
> >> And in the function outer_tramp, the thread A see the thread B was
> >> stopped with a SIGSTOP signal. Why? Since the thread B is blocked by
> >> the signal SIGUSR1...
> > The handler calls suspend_new_thread, which stops itself.
> Exactly! I'm wrong...
> Then I have another question:
> In UML function new_thread_handler, the current sigcontext is defined as
> following:
> UPT_SC(¤t->thread.regs.regs) = (void *) (&sig + 1);
> Why? What does "&sig + 1" mean?
I think that's because sig is on the stack, and &sig + 1 points to the datas
saved by the kernel when entering the signal handler, i.e. the registers of
the caller, saved to be restored on return.
--
Paolo Giarrusso, aka Blaisorblade
Skype user "PaoloGiarrusso"
Linux registered user n. 292729
http://www.user-mode-linux.org/~blaisorblade
-------------------------------------------------------
This SF.Net email is sponsored by Oracle Space Sweepstakes
Want to be the first software developer in space?
Enter now for the Oracle Space Sweepstakes!
http://ads.osdn.com/?ad_id=7412&alloc_id=16344&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 5+ messages in thread
* [uml-devel] Question about the kernel thread in UML TT mode
@ 2005-05-17 9:38 Alex LIU
2005-05-17 15:53 ` Jeff Dike
0 siblings, 1 reply; 5+ messages in thread
From: Alex LIU @ 2005-05-17 9:38 UTC (permalink / raw)
To: UML-dev
Hi,all:
In UML,when do_fork was called,the new process P will be created in UML. Then in copy_thread_tt(in fact in start_fork_tramp)the corresponding process Q will be created in the host linux. I know the pid of the corresponding host process Q is appointed as the extern_pid of the UML process P. But then how will the 2 processes do next individually?
In UML,the function copy_thread_tt call start_fork_tramp, which cloned a thread. Once the thread was created it will run the outer_tramp function,in which cloned another thread. Once the second thread was created it will run the tramp function(fork_tramp or new_thread_proc). In fact the first thread is a temp one.it will kill itself later.Then why does UML clone 2 threads in copy_thread_tt?
In UML,when the kernel_thread was called,the UML kernel thread P will be created in copy_process. And the corresponding host thread Q will be create in copy_thread_tt. Then the host thread Q will run its SIGUSR1 signal handler new_thread_handler,which will call run_kernel_thread function and exited at last. But I think it should be the UML kernel thread P that call run_kernel_thread function, any problems?
Thanks a lot!
Alex
-------------------------------------------------------
This SF.Net email is sponsored by Oracle Space Sweepstakes
Want to be the first software developer in space?
Enter now for the Oracle Space Sweepstakes!
http://ads.osdn.com/?ad_idt12&alloc_id\x16344&op�k
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 5+ messages in thread
* Re: [uml-devel] Question about the kernel thread in UML TT mode
2005-05-17 9:38 Alex LIU
@ 2005-05-17 15:53 ` Jeff Dike
[not found] ` <000e01c55b91$039466d0$9eb3c68a@SHZ.ST.COM>
0 siblings, 1 reply; 5+ messages in thread
From: Jeff Dike @ 2005-05-17 15:53 UTC (permalink / raw)
To: Alex LIU; +Cc: UML-dev
On Tue, May 17, 2005 at 05:38:21PM +0800, Alex LIU wrote:
> In UML,when do_fork was called,the new process P will be created in UML. Then in copy_thread_tt(in fact in start_fork_tramp)the corresponding process Q will be created in the host linux. I know the pid of the corresponding host process Q is appointed as the extern_pid of the UML process P. But then how will the 2 processes do next individually?
They aren't really two processes. But they set up signal handlers, and the
timer, and then go to sleep until that process is scheduled.
> In UML,the function copy_thread_tt call start_fork_tramp, which cloned a thread. Once the thread was created it will run the outer_tramp function,in which cloned another thread. Once the second thread was created it will run the tramp function(fork_tramp or new_thread_proc). In fact the first thread is a temp one.it will kill itself later.Then why does UML clone 2 threads in copy_thread_tt?
To avoid zombies - the parent process is expected to reap exited children,
but as far as UML is concerned, the parent may not wake up for along time,
leaving the child as a zombie for an arbitrary time.
The two threads are the double-fork trick. The parent of the new process
is the first temporary thread, which exits immediately, leaving the new child
to be inherited by init, which will reap children immediately, eliminating
zombies.
> In UML,when the kernel_thread was called,the UML kernel thread P will be created in copy_process. And the corresponding host thread Q will be create in copy_thread_tt. Then the host thread Q will run its SIGUSR1 signal handler new_thread_handler,which will call run_kernel_thread function and exited at last. But I think it should be the UML kernel thread P that call run_kernel_thread function, any problems?
P and Q are the same thing, so it makes no sense to say the handler should be
run in one rather than the other.
Jeff
-------------------------------------------------------
This SF.Net email is sponsored by Oracle Space Sweepstakes
Want to be the first software developer in space?
Enter now for the Oracle Space Sweepstakes!
http://ads.osdn.com/?ad_id=7412&alloc_id=16344&op=click
_______________________________________________
User-mode-linux-devel mailing list
User-mode-linux-devel@lists.sourceforge.net
https://lists.sourceforge.net/lists/listinfo/user-mode-linux-devel
^ permalink raw reply [flat|nested] 5+ messages in thread
end of thread, other threads:[~2005-05-19 15:02 UTC | newest]
Thread overview: 5+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <000c01c55c59$37dd1e50$9eb3c68a@SHZ.ST.COM>
2005-05-19 13:31 ` [uml-devel] Question about the kernel thread in UML TT mode Blaisorblade
2005-05-19 14:56 ` Jeff Dike
2005-05-17 9:38 Alex LIU
2005-05-17 15:53 ` Jeff Dike
[not found] ` <000e01c55b91$039466d0$9eb3c68a@SHZ.ST.COM>
2005-05-18 13:31 ` Jeff Dike
This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.