[ python-Bugs-853411 ] After fork in subthread, signals are blocked
SourceForge.net
noreply at sourceforge.net
Wed Dec 3 11:55:59 EST 2003
Bugs item #853411, was opened at 2003-12-03 17:55
Message generated for change (Tracker Item Submitted) made by Item Submitter
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=853411&group_id=5470
Category: Threads
Group: Python 2.2.3
Status: Open
Resolution: None
Priority: 5
Submitted By: Göran Uddeborg (goeran)
Assigned to: Nobody/Anonymous (nobody)
Summary: After fork in subthread, signals are blocked
Initial Comment:
When a Python program starts a new thread, and this new
thread forks, the forked process ingores signals. It
will not terminate, or dump core if that would be
applicable, when it receives a signal.
I attach a test case which illustrates the behaviour.
In this example, the child process is sent a SEGV
signal from the subthread of the parent process. This
should cause the child process to die and produce a
core. But execution of the parent program threads
finishes, there is still a python process around,
continuing to sleep.
Apparently, Python subthreads blocks signals. On
Linux, /proc/*/status for subthreads includes the line
SigBlk: ffffffff7ffbfeff
The Python documentation says one should only install
signal handlers in the main thread, and only the main
thread will recieve signals. So this makes sense. But
when the subthread forks, the new process inherits this
signal mask, which seems to be incorrect behaviour. I
would assume, if Python sets this signal mask for
threads, it should also reset it again after a fork.
I've seen this on these two platforms:
Python 2.2.3 on Red Hat Linux RHEL 3WS (IA32)
Python 2.2.1 on Sun Solaris 8 (Sparc)
----------------------------------------------------------------------
You can respond by visiting:
https://sourceforge.net/tracker/?func=detail&atid=105470&aid=853411&group_id=5470
More information about the Python-bugs-list
mailing list