* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
[not found] ` <834mwsh2nu.fsf@gnu.org>
@ 2014-08-31 20:20 ` Doug Evans
2014-09-01 2:36 ` Eli Zaretskii
2014-09-01 12:48 ` Gary Benson
0 siblings, 2 replies; 16+ messages in thread
From: Doug Evans @ 2014-08-31 20:20 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: guile-devel, gdb-patches@sourceware.org
[+ guile-devel]
On Sun, Aug 31, 2014 at 12:36 PM, Eli Zaretskii <eliz@gnu.org> wrote:
>> From: Doug Evans <xdje42@gmail.com>
>> Date: Sun, 31 Aug 2014 12:07:58 -0700
>>
>> Basically, current Guile (git) starts an internal thread
>> (the "finalizer" thread), and libgc as of 7.4 now starts several
>> marker threads by default (before 7.4.0 one needed to configure
>> libgc with --enable-parallel-mark).
>>
>> When other threads are running, and they haven't blocked SIGCHLD,
>> then the kernel may send SIGCHLD to these threads, leaving gdb
>> hung in the sigsuspend calls in linux-nat.c.
>
> A heretic thought: is it at all a good idea to have Guile (and GC)
> start threads when they run under GDB? GDB is a single-threaded
> program, so having it linked against libraries that start threads
> whenever they like is IME a source of subtle problems (like this one)
> and a lot of pain down the road. Anything GDB does that affects the
> global environment of the whole program (e.g., I/O redirection) will
> also affect those threads, with who knows what consequences.
>
> So maybe The Right Way of fixing these problems is configure Guile and
> GC so that they never start any additional threads?
Users are going to want to start threads.
I've seen that already.
I think we should not shy away from them.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-08-31 20:20 ` [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile Doug Evans
@ 2014-09-01 2:36 ` Eli Zaretskii
2014-09-01 10:11 ` Ludovic Courtès
2014-09-01 12:48 ` Gary Benson
1 sibling, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-01 2:36 UTC (permalink / raw)
To: Doug Evans; +Cc: gdb-patches, guile-devel
> Date: Sun, 31 Aug 2014 13:20:48 -0700
> From: Doug Evans <xdje42@gmail.com>
> Cc: "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>, guile-devel <guile-devel@gnu.org>
>
> Users are going to want to start threads.
If users want threads in Guile, they can use Guile.
In GDB, Guile is just an extension language. I see no catastrophe in
saying there are some restrictions to what a Guile extension in GDB
can and cannot do.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 2:36 ` Eli Zaretskii
@ 2014-09-01 10:11 ` Ludovic Courtès
2014-09-01 14:39 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Ludovic Courtès @ 2014-09-01 10:11 UTC (permalink / raw)
To: gdb-patches; +Cc: guile-devel
Eli Zaretskii <eliz@gnu.org> skribis:
>> Date: Sun, 31 Aug 2014 13:20:48 -0700
>> From: Doug Evans <xdje42@gmail.com>
>> Cc: "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>, guile-devel <guile-devel@gnu.org>
>>
>> Users are going to want to start threads.
>
> If users want threads in Guile, they can use Guile.
>
> In GDB, Guile is just an extension language. I see no catastrophe in
> saying there are some restrictions to what a Guile extension in GDB
> can and cannot do.
That can be acceptable, but requiring users to re-build Guile and GC
without thread support is not, IMO.
Ludo’.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-08-31 20:20 ` [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile Doug Evans
2014-09-01 2:36 ` Eli Zaretskii
@ 2014-09-01 12:48 ` Gary Benson
2014-09-01 16:34 ` Doug Evans
1 sibling, 1 reply; 16+ messages in thread
From: Gary Benson @ 2014-09-01 12:48 UTC (permalink / raw)
To: Doug Evans; +Cc: Eli Zaretskii, gdb-patches@sourceware.org, guile-devel
Doug Evans wrote:
> On Sun, Aug 31, 2014 at 12:36 PM, Eli Zaretskii <eliz@gnu.org> wrote:
> > > From: Doug Evans <xdje42@gmail.com>
> > > Date: Sun, 31 Aug 2014 12:07:58 -0700
> > >
> > > Basically, current Guile (git) starts an internal thread (the
> > > "finalizer" thread), and libgc as of 7.4 now starts several
> > > marker threads by default (before 7.4.0 one needed to configure
> > > libgc with --enable-parallel-mark).
> > >
> > > When other threads are running, and they haven't blocked
> > > SIGCHLD, then the kernel may send SIGCHLD to these threads,
> > > leaving gdb hung in the sigsuspend calls in linux-nat.c.
> >
> > A heretic thought: is it at all a good idea to have Guile (and GC)
> > start threads when they run under GDB? GDB is a single-threaded
> > program, so having it linked against libraries that start threads
> > whenever they like is IME a source of subtle problems (like this
> > one) and a lot of pain down the road. Anything GDB does that
> > affects the global environment of the whole program (e.g., I/O
> > redirection) will also affect those threads, with who knows what
> > consequences.
> >
> > So maybe The Right Way of fixing these problems is configure Guile
> > and GC so that they never start any additional threads?
>
> Users are going to want to start threads.
> I've seen that already.
> I think we should not shy away from them.
This patch ensures the internal threads are created with SIGCHLD
blocked. Does something do this for other (user started?) threads?
Thanks,
Gary
--
http://gbenson.net/
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 10:11 ` Ludovic Courtès
@ 2014-09-01 14:39 ` Eli Zaretskii
2014-09-01 16:18 ` Ludovic Courtès
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-01 14:39 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: gdb-patches, guile-devel
> From: ludo@gnu.org (Ludovic Courtès)
> Date: Mon, 01 Sep 2014 12:11:19 +0200
> Cc: guile-devel@gnu.org
>
> Eli Zaretskii <eliz@gnu.org> skribis:
>
> > In GDB, Guile is just an extension language. I see no catastrophe in
> > saying there are some restrictions to what a Guile extension in GDB
> > can and cannot do.
>
> That can be acceptable, but requiring users to re-build Guile and GC
> without thread support is not, IMO.
Perhaps we should request GC and Guile to provide capabilities to
disable threads at run time, then.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 14:39 ` Eli Zaretskii
@ 2014-09-01 16:18 ` Ludovic Courtès
2014-09-01 17:10 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Ludovic Courtès @ 2014-09-01 16:18 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: gdb-patches, guile-devel
Eli Zaretskii <eliz@gnu.org> skribis:
>> From: ludo@gnu.org (Ludovic Courtès)
>> Date: Mon, 01 Sep 2014 12:11:19 +0200
>> Cc: guile-devel@gnu.org
>>
>> Eli Zaretskii <eliz@gnu.org> skribis:
>>
>> > In GDB, Guile is just an extension language. I see no catastrophe in
>> > saying there are some restrictions to what a Guile extension in GDB
>> > can and cannot do.
>>
>> That can be acceptable, but requiring users to re-build Guile and GC
>> without thread support is not, IMO.
>
> Perhaps we should request GC and Guile to provide capabilities to
> disable threads at run time, then.
I don’t think we need to go this far: reading the recent discussions, it
seems Doug found a way to make sure Guile’s and libgc’s internal threads
don’t receive signals that GDB is interested in, which should be enough
for practical purposes.
Ludo’.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 12:48 ` Gary Benson
@ 2014-09-01 16:34 ` Doug Evans
0 siblings, 0 replies; 16+ messages in thread
From: Doug Evans @ 2014-09-01 16:34 UTC (permalink / raw)
To: Gary Benson; +Cc: Eli Zaretskii, gdb-patches@sourceware.org, guile-devel
On Mon, Sep 1, 2014 at 5:48 AM, Gary Benson <gbenson@redhat.com> wrote:
> Doug Evans wrote:
>> On Sun, Aug 31, 2014 at 12:36 PM, Eli Zaretskii <eliz@gnu.org> wrote:
>> > > From: Doug Evans <xdje42@gmail.com>
>> > > Date: Sun, 31 Aug 2014 12:07:58 -0700
>> > >
>> > > Basically, current Guile (git) starts an internal thread (the
>> > > "finalizer" thread), and libgc as of 7.4 now starts several
>> > > marker threads by default (before 7.4.0 one needed to configure
>> > > libgc with --enable-parallel-mark).
>> > >
>> > > When other threads are running, and they haven't blocked
>> > > SIGCHLD, then the kernel may send SIGCHLD to these threads,
>> > > leaving gdb hung in the sigsuspend calls in linux-nat.c.
>> >
>> > A heretic thought: is it at all a good idea to have Guile (and GC)
>> > start threads when they run under GDB? GDB is a single-threaded
>> > program, so having it linked against libraries that start threads
>> > whenever they like is IME a source of subtle problems (like this
>> > one) and a lot of pain down the road. Anything GDB does that
>> > affects the global environment of the whole program (e.g., I/O
>> > redirection) will also affect those threads, with who knows what
>> > consequences.
>> >
>> > So maybe The Right Way of fixing these problems is configure Guile
>> > and GC so that they never start any additional threads?
>>
>> Users are going to want to start threads.
>> I've seen that already.
>> I think we should not shy away from them.
>
> This patch ensures the internal threads are created with SIGCHLD
> blocked. Does something do this for other (user started?) threads?
What to do for user-started threads is an open question, both for
Python and Guile.
For reference sake, see PR 17314.
[Still working on a testcase. What I added to the PR is just a
snippet to get thoughts down.]
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 16:18 ` Ludovic Courtès
@ 2014-09-01 17:10 ` Eli Zaretskii
2014-09-01 22:04 ` Doug Evans
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-01 17:10 UTC (permalink / raw)
To: Ludovic Courtès; +Cc: gdb-patches, guile-devel
> From: ludo@gnu.org (Ludovic Courtès)
> Cc: gdb-patches@sourceware.org, guile-devel@gnu.org
> Date: Mon, 01 Sep 2014 18:18:45 +0200
>
> Eli Zaretskii <eliz@gnu.org> skribis:
>
> > Perhaps we should request GC and Guile to provide capabilities to
> > disable threads at run time, then.
>
> I don’t think we need to go this far: reading the recent discussions, it
> seems Doug found a way to make sure Guile’s and libgc’s internal threads
> don’t receive signals that GDB is interested in, which should be enough
> for practical purposes.
That's just the tip of an iceberg, I'm afraid.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 17:10 ` Eli Zaretskii
@ 2014-09-01 22:04 ` Doug Evans
2014-09-02 15:25 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Doug Evans @ 2014-09-01 22:04 UTC (permalink / raw)
To: Eli Zaretskii
Cc: Ludovic Courtès, gdb-patches@sourceware.org, guile-devel
On Mon, Sep 1, 2014 at 10:10 AM, Eli Zaretskii <eliz@gnu.org> wrote:
>> From: ludo@gnu.org (Ludovic Courtès)
>> Cc: gdb-patches@sourceware.org, guile-devel@gnu.org
>> Date: Mon, 01 Sep 2014 18:18:45 +0200
>>
>> Eli Zaretskii <eliz@gnu.org> skribis:
>>
>> > Perhaps we should request GC and Guile to provide capabilities to
>> > disable threads at run time, then.
>>
>> I don’t think we need to go this far: reading the recent discussions, it
>> seems Doug found a way to make sure Guile’s and libgc’s internal threads
>> don’t receive signals that GDB is interested in, which should be enough
>> for practical purposes.
>
> That's just the tip of an iceberg, I'm afraid.
In the interests of seeking clarification early and clearly, can you elaborate?
I'm not saying there aren't issues, I'm just wondering if you have
anything specific that you are thinking of.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-01 22:04 ` Doug Evans
@ 2014-09-02 15:25 ` Eli Zaretskii
2014-09-05 8:26 ` Doug Evans
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-02 15:25 UTC (permalink / raw)
To: Doug Evans; +Cc: ludo, guile-devel, gdb-patches
> Date: Mon, 1 Sep 2014 15:04:16 -0700
> From: Doug Evans <xdje42@gmail.com>
> Cc: Ludovic Courtès <ludo@gnu.org>,
> guile-devel <guile-devel@gnu.org>,
> "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>
>
>> Eli Zaretskii skribis:
>>
>> > Perhaps we should request GC and Guile to provide capabilities to
>> > disable threads at run time, then.
>>
>> I don’t think we need to go this far: reading the recent discussions, it
>> seems Doug found a way to make sure Guile’s and libgc’s internal threads
>> don’t receive signals that GDB is interested in, which should be enough
>> for practical purposes.
>
> That's just the tip of an iceberg, I'm afraid.
>
> In the interests of seeking clarification early and clearly, can you elaborate?
>
> I'm not saying there aren't issues, I'm just wondering if you have
> anything specific that you are thinking of.
OK, but if no one except myself sees the danger, then that's about the
last time I'm writing about this, and will hold my peace thereafter.
With that out of my way...
Basically, anything you can do in Guile that somehow causes
process-wide changes would present a problem, if Guile threads are
allowed in GDB. Here are a few examples that come to mind:
. redirection of standard descriptors (I already mentioned this in my
initial message in this discussion)
. changing environment variables with setenv/unsetenv
. changing the current directory with chdir
. changing the process's umask
. calling setuid/seteuid or setsid
. changing the priority or affinity of the process
. setting or changing signal handlers, or raising signals
. setting or canceling interval timers
. changing resource limits with setrlimit
The full list is almost infinite, since Guile supports foreign
libraries via libffi and libltdl. So a Guile extension can load any
code that might call any API.
Since GDB is itself a program that uses at least some of the low-level
OS interfaces that underly the above Guile functionalities, the danger
of core GDB and threads running Guile extensions stomping onto each
other's feet is not just theoretical, IMO.
Moreover, the proposed solutions only address the issues we know about
at this time. Both GC and Guile are being actively maintained, so
there's a real danger they will introduce more features whose use from
a separate thread will present problems beyond those known today. I
predict this to be a constant source of maintainers' headache. We
will probably see more incidents like this one, where we released a
seriously flawed GDB.
We had our share of similar problems in Emacs compiled with GTK, where
it turned out that GTK launches threads at will, and some of those
threads manipulate signals and even start subprocesses(!). There are
several horror stories in the Emacs bug tracker about related
hard-to-debug crashes caused, e.g., by GTK usurping SIGCHLD while
Emacs was waiting for a subprocess to terminate.
In a single-threaded program, a well-behaved Guile extension can at
least minimize the damage by restoring the global state immediately
after doing whatever it needed the change in that state for. But if
the extension code runs in a separate thread, there's no way of doing
that safely and reliably.
We could introduce some synchronization mechanism, whereby, for
example, GDB's main thread could cause all other threads stop in their
tracks while it is accessing some global resource, and then resumes
them. But that means added complexity, and doesn't entirely fix the
problem (e.g., a chdir call that doesn't return to the original
directory could still cause harm to core GDB).
So I suggest to think about this now, rather than bearing the
maintenance burden in the years to come.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-02 15:25 ` Eli Zaretskii
@ 2014-09-05 8:26 ` Doug Evans
2014-09-05 8:48 ` Eli Zaretskii
0 siblings, 1 reply; 16+ messages in thread
From: Doug Evans @ 2014-09-05 8:26 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: ludo, guile-devel, gdb-patches
Eli Zaretskii <eliz@gnu.org> writes:
>> Date: Mon, 1 Sep 2014 15:04:16 -0700
>> From: Doug Evans <xdje42@gmail.com>
>> Cc: Ludovic Courtès <ludo@gnu.org>,
>> guile-devel <guile-devel@gnu.org>,
>> "gdb-patches@sourceware.org" <gdb-patches@sourceware.org>
>>
>>> Eli Zaretskii skribis:
>>>
>>> > Perhaps we should request GC and Guile to provide capabilities to
>>> > disable threads at run time, then.
>>>
>>> I don’t think we need to go this far: reading the recent discussions, it
>>> seems Doug found a way to make sure Guile’s and libgc’s internal threads
>>> don’t receive signals that GDB is interested in, which should be enough
>>> for practical purposes.
>>
>> That's just the tip of an iceberg, I'm afraid.
>>
>> In the interests of seeking clarification early and clearly, can you elaborate?
>>
>> I'm not saying there aren't issues, I'm just wondering if you have
>> anything specific that you are thinking of.
>
> OK, but if no one except myself sees the danger, then that's about the
> last time I'm writing about this, and will hold my peace thereafter.
>
> With that out of my way...
>
> Basically, anything you can do in Guile that somehow causes
> process-wide changes would present a problem, if Guile threads are
> allowed in GDB. Here are a few examples that come to mind:
>
> . redirection of standard descriptors (I already mentioned this in my
> initial message in this discussion)
>
> . changing environment variables with setenv/unsetenv
>
> . changing the current directory with chdir
>
> . changing the process's umask
>
> . calling setuid/seteuid or setsid
>
> . changing the priority or affinity of the process
>
> . setting or changing signal handlers, or raising signals
>
> . setting or canceling interval timers
>
> . changing resource limits with setrlimit
>
> The full list is almost infinite, since Guile supports foreign
> libraries via libffi and libltdl. So a Guile extension can load any
> code that might call any API.
>
> Since GDB is itself a program that uses at least some of the low-level
> OS interfaces that underly the above Guile functionalities, the danger
> of core GDB and threads running Guile extensions stomping onto each
> other's feet is not just theoretical, IMO.
>
> Moreover, the proposed solutions only address the issues we know about
> at this time. Both GC and Guile are being actively maintained, so
> there's a real danger they will introduce more features whose use from
> a separate thread will present problems beyond those known today. I
> predict this to be a constant source of maintainers' headache. We
> will probably see more incidents like this one, where we released a
> seriously flawed GDB.
>
> We had our share of similar problems in Emacs compiled with GTK, where
> it turned out that GTK launches threads at will, and some of those
> threads manipulate signals and even start subprocesses(!). There are
> several horror stories in the Emacs bug tracker about related
> hard-to-debug crashes caused, e.g., by GTK usurping SIGCHLD while
> Emacs was waiting for a subprocess to terminate.
>
> In a single-threaded program, a well-behaved Guile extension can at
> least minimize the damage by restoring the global state immediately
> after doing whatever it needed the change in that state for. But if
> the extension code runs in a separate thread, there's no way of doing
> that safely and reliably.
>
> We could introduce some synchronization mechanism, whereby, for
> example, GDB's main thread could cause all other threads stop in their
> tracks while it is accessing some global resource, and then resumes
> them. But that means added complexity, and doesn't entirely fix the
> problem (e.g., a chdir call that doesn't return to the original
> directory could still cause harm to core GDB).
>
> So I suggest to think about this now, rather than bearing the
> maintenance burden in the years to come.
I'm happy to leave users to their own devices,
we can't physically prevent them from starting threads.
We pretty much leave them that way already given the myriad
of things they can do to mess up gdb without threads.
The python side of things is too silent on whether threads are supported
there.
https://sourceware.org/gdb/current/onlinedocs/gdb/Basic-Python.html#Basic-Python
The only thing it says with regards to threads is:
"GDB takes care to mark its internal file descriptors as
close-on-exec. However, this cannot be done in a thread-safe way on
all platforms. Your Python programs should be aware of this and
should both create new file descriptors with the close-on-exec flag
set and arrange to close unneeded file descriptors before starting a
child process."
At any rate, the task at hand is getting gdb to work well with Guile,
regardless of whether the user starts any threads,
and that's the intent of the patch.
I am happy to make the default value of GC_MARKERS be 1 (regardless
of libgc version, and if not already set by the user) when initializing Guile,
that will disable libgc marker threads.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-05 8:26 ` Doug Evans
@ 2014-09-05 8:48 ` Eli Zaretskii
2014-09-05 10:51 ` Pedro Alves
2014-09-05 11:50 ` Ludovic Courtès
0 siblings, 2 replies; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-05 8:48 UTC (permalink / raw)
To: Doug Evans; +Cc: ludo, guile-devel, gdb-patches
> From: Doug Evans <xdje42@gmail.com>
> Cc: ludo@gnu.org, guile-devel@gnu.org, gdb-patches@sourceware.org
> Date: Fri, 05 Sep 2014 01:26:28 -0700
>
> we can't physically prevent [users] from starting threads.
Of course we can: if Guile gives us a way to disable threads, any user
extension that attempts to start a thread will simply fail.
> We pretty much leave them that way already given the myriad
> of things they can do to mess up gdb without threads.
?? The rest of GDB is compiled C code which users cannot change
without recompiling. And it's a single-threaded code. And it's under
our close scrutiny. So I see no problems here.
> The python side of things is too silent on whether threads are supported
> there.
> https://sourceware.org/gdb/current/onlinedocs/gdb/Basic-Python.html#Basic-Python
I simply don't know enough about Python to discuss this; I do know
about Guile. If Python extensions can start threads, then the same
considerations apply there. And if the Python side didn't disallow
that until now, it doesn't sound like a good excuse to add insult to
injury on the Guile side.
> At any rate, the task at hand is getting gdb to work well with Guile,
> regardless of whether the user starts any threads,
> and that's the intent of the patch.
If we disable threads, this patch is unneeded, as are all the future
patches I envision that will have to deal with these issues. We kill
the problem cleanly and once and for all. From where I stand, it's a
no-brainer.
> I am happy to make the default value of GC_MARKERS be 1 (regardless
> of libgc version, and if not already set by the user) when initializing Guile,
> that will disable libgc marker threads.
That'd be fine with me, thanks.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-05 8:48 ` Eli Zaretskii
@ 2014-09-05 10:51 ` Pedro Alves
2014-09-05 11:51 ` Eli Zaretskii
2014-09-05 11:50 ` Ludovic Courtès
1 sibling, 1 reply; 16+ messages in thread
From: Pedro Alves @ 2014-09-05 10:51 UTC (permalink / raw)
To: Eli Zaretskii, Doug Evans; +Cc: ludo, guile-devel, gdb-patches
On 09/05/2014 09:48 AM, Eli Zaretskii wrote:
>> From: Doug Evans <xdje42@gmail.com>
>> Cc: ludo@gnu.org, guile-devel@gnu.org, gdb-patches@sourceware.org
>> Date: Fri, 05 Sep 2014 01:26:28 -0700
>>
>> we can't physically prevent [users] from starting threads.
>
> Of course we can: if Guile gives us a way to disable threads, any user
> extension that attempts to start a thread will simply fail.
>
>> We pretty much leave them that way already given the myriad
>> of things they can do to mess up gdb without threads.
>
> ?? The rest of GDB is compiled C code which users cannot change
> without recompiling. And it's a single-threaded code. And it's under
> our close scrutiny. So I see no problems here.
>
>> The python side of things is too silent on whether threads are supported
>> there.
>> https://sourceware.org/gdb/current/onlinedocs/gdb/Basic-Python.html#Basic-Python
I'd be strongly against preventing extensions from using threads. As an
example, tromey's wip/prototype gdb frontend written as a python extension to
gdb uses threads:
https://gitorious.org/gdb-gui
Even GDB itself isn't really strictly single-threaded -- e.g., on
Windows, we spawn threads to handle I/O:
ser-mingw.c: state->thread = CreateThread (NULL, 0, thread_fn, scb, 0, &threadId);
Just last night I was debugging something in non-stop mode
where a ton of events happen behind the scenes without causing
a user-visible stop (a bunch of parallel single-steps), and
noticing how the cli/prompt becomes so unresponsive, because the event
loop handles either target events or input events in sequence, not
in parallel, and thinking that probably to completely fix this we'd
need to move stdin/readline handling to a separate thread.
Thanks,
Pedro Alves
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-05 8:48 ` Eli Zaretskii
2014-09-05 10:51 ` Pedro Alves
@ 2014-09-05 11:50 ` Ludovic Courtès
1 sibling, 0 replies; 16+ messages in thread
From: Ludovic Courtès @ 2014-09-05 11:50 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Doug Evans, guile-devel, gdb-patches
Eli Zaretskii <eliz@gnu.org> skribis:
>> From: Doug Evans <xdje42@gmail.com>
>> Cc: ludo@gnu.org, guile-devel@gnu.org, gdb-patches@sourceware.org
>> Date: Fri, 05 Sep 2014 01:26:28 -0700
>>
>> we can't physically prevent [users] from starting threads.
>
> Of course we can: if Guile gives us a way to disable threads, any user
> extension that attempts to start a thread will simply fail.
What Guile provides is a configure-time switch to disable threads (the
default is to enable threads.) However, I would find it unacceptable to
require GDB users to have a specially-configured Guile.
What I would suggest is to strongly warn against the use of threads in
the manual. If users ignore that warning, I think it’s their problem.
We might be able to annihilate thread functionality, for instance by
‘set!’ing the relevant bindings in Guile when GDB starts up. But that’s
fragile and it misses the point: that users are free to run whatever
code they want anyway, and have plenty of other ways to mess up with GDB
(the same applies to Python extensions.)
(Besides, I agree with Pedro that the long-term vision should be to
eventually permit multi-threaded extensions, although I understand that
it won’t happen overnight.)
Thanks,
Ludo’.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-05 10:51 ` Pedro Alves
@ 2014-09-05 11:51 ` Eli Zaretskii
2014-09-05 12:48 ` Pedro Alves
0 siblings, 1 reply; 16+ messages in thread
From: Eli Zaretskii @ 2014-09-05 11:51 UTC (permalink / raw)
To: Pedro Alves; +Cc: xdje42, ludo, guile-devel, gdb-patches
> Date: Fri, 05 Sep 2014 11:51:00 +0100
> From: Pedro Alves <palves@redhat.com>
> CC: ludo@gnu.org, guile-devel@gnu.org, gdb-patches@sourceware.org
>
> I'd be strongly against preventing extensions from using threads.
Then how do you propose to deal with the difficulties I listed in one
of my previous messages?
> As an example, tromey's wip/prototype gdb frontend written as a
> python extension to gdb uses threads:
You don't need to convince me that forbidding threads takes away some
significant functionality. This is a question of finding the right
balance, not whether threads are useful.
> Even GDB itself isn't really strictly single-threaded -- e.g., on
> Windows, we spawn threads to handle I/O:
That just means we already take some risk, where no other solution was
possible, or reasonably practical. It does not mean we should from
now on be casual about adding more of that. Moreover, this is _us_
doing threads, not users on whose code we have no control.
> Just last night I was debugging something in non-stop mode
> where a ton of events happen behind the scenes without causing
> a user-visible stop (a bunch of parallel single-steps), and
> noticing how the cli/prompt becomes so unresponsive, because the event
> loop handles either target events or input events in sequence, not
> in parallel, and thinking that probably to completely fix this we'd
> need to move stdin/readline handling to a separate thread.
It's fine with me to redesign GDB to be a multi-threaded program. But
you know better than I do how deeply single-threaded is the current
GDB design. I'm talking about allowing threads with arbitrary code
into our back-door, while GDB currently doesn't and cannot handle that
very well.
^ permalink raw reply [flat|nested] 16+ messages in thread
* Re: [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile
2014-09-05 11:51 ` Eli Zaretskii
@ 2014-09-05 12:48 ` Pedro Alves
0 siblings, 0 replies; 16+ messages in thread
From: Pedro Alves @ 2014-09-05 12:48 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: xdje42, ludo, guile-devel, gdb-patches
On 09/05/2014 12:51 PM, Eli Zaretskii wrote:
>> Date: Fri, 05 Sep 2014 11:51:00 +0100
>> From: Pedro Alves <palves@redhat.com>
>> CC: ludo@gnu.org, guile-devel@gnu.org, gdb-patches@sourceware.org
>>
>> I'd be strongly against preventing extensions from using threads.
>
> Then how do you propose to deal with the difficulties I listed in one
> of my previous messages?
As you said, both Guile and Python support loading foreign
libraries, so those difficulties aren't really specific
to multi-threading. Even without loading foreign
libraries, it seems to me that a single-threaded extension
script can just as well mess up gdb, but doing some of the things
you list, like e.g., messing with signal handlers and timers.
So I think we should say that you mustn't change global
environment behind gdb's feet, and if you do so, you're in
undefined territory.
I thikn we also need to make clear that you can _only_ interact
with GDB through the main thread. You can't have a random
thread call into GDB's APIs, as there's no locking.
>
>> As an example, tromey's wip/prototype gdb frontend written as a
>> python extension to gdb uses threads:
>
> You don't need to convince me that forbidding threads takes away some
> significant functionality. This is a question of finding the right
> balance, not whether threads are useful.
>
>> Even GDB itself isn't really strictly single-threaded -- e.g., on
>> Windows, we spawn threads to handle I/O:
>
> That just means we already take some risk, where no other solution was
> possible, or reasonably practical. It does not mean we should from
> now on be casual about adding more of that. Moreover, this is _us_
> doing threads, not users on whose code we have no control.
>
>> Just last night I was debugging something in non-stop mode
>> where a ton of events happen behind the scenes without causing
>> a user-visible stop (a bunch of parallel single-steps), and
>> noticing how the cli/prompt becomes so unresponsive, because the event
>> loop handles either target events or input events in sequence, not
>> in parallel, and thinking that probably to completely fix this we'd
>> need to move stdin/readline handling to a separate thread.
>
> It's fine with me to redesign GDB to be a multi-threaded program. But
> you know better than I do how deeply single-threaded is the current
> GDB design. I'm talking about allowing threads with arbitrary code
> into our back-door, while GDB currently doesn't and cannot handle that
> very well.
Ack.
Thanks,
Pedro Alves
^ permalink raw reply [flat|nested] 16+ messages in thread
end of thread, other threads:[~2014-09-05 12:48 UTC | newest]
Thread overview: 16+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <m31trwv5o1.fsf@sspiff.org>
[not found] ` <834mwsh2nu.fsf@gnu.org>
2014-08-31 20:20 ` [PATCH][PR guile/17247] Block SIGCHLD while initializing Guile Doug Evans
2014-09-01 2:36 ` Eli Zaretskii
2014-09-01 10:11 ` Ludovic Courtès
2014-09-01 14:39 ` Eli Zaretskii
2014-09-01 16:18 ` Ludovic Courtès
2014-09-01 17:10 ` Eli Zaretskii
2014-09-01 22:04 ` Doug Evans
2014-09-02 15:25 ` Eli Zaretskii
2014-09-05 8:26 ` Doug Evans
2014-09-05 8:48 ` Eli Zaretskii
2014-09-05 10:51 ` Pedro Alves
2014-09-05 11:51 ` Eli Zaretskii
2014-09-05 12:48 ` Pedro Alves
2014-09-05 11:50 ` Ludovic Courtès
2014-09-01 12:48 ` Gary Benson
2014-09-01 16:34 ` Doug Evans
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).