* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
@ 2009-01-28 23:06 Markus Triska
2011-09-11 21:08 ` Lars Magne Ingebrigtsen
0 siblings, 1 reply; 14+ messages in thread
From: Markus Triska @ 2009-01-28 23:06 UTC (permalink / raw)
To: emacs-pretest-bug
When you do:
$ emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
then Emacs crashes with:
Program received signal EXC_BAD_ACCESS, Could not access memory.
Reason: KERN_INVALID_ADDRESS at address: 0xbf7ffffc
0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
(gdb) bt
#0 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
#1 0x0013bdf8 in mark_object (arg=40166549) at alloc.c:5655
#2 0x0013bdf8 in mark_object (arg=40166557) at alloc.c:5655
#3 0x0013bdf8 in mark_object (arg=40166565) at alloc.c:5655
#4 0x0013bdf8 in mark_object (arg=40166573) at alloc.c:5655
#5 0x0013bdf8 in mark_object (arg=40166581) at alloc.c:5655
#6 0x0013bdf8 in mark_object (arg=40166589) at alloc.c:5655
...
Throwing an error or making GC stackless seems much preferable here.
In GNU Emacs 23.0.60.1 (i386-apple-darwin8.11.1, GTK+ Version 2.12.9)
of 2009-01-28 on mt-computer.local
Windowing system distributor `The XFree86 Project, Inc', version 11.0.40400000
Important settings:
value of $LC_ALL: nil
value of $LC_COLLATE: nil
value of $LC_CTYPE: nil
value of $LC_MESSAGES: nil
value of $LC_MONETARY: nil
value of $LC_NUMERIC: nil
value of $LC_TIME: nil
value of $LANG: en_GB.UTF-8
value of $XMODIFIERS: nil
locale-coding-system: nil
default-enable-multibyte-characters: t
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2009-01-28 23:06 bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs Markus Triska
@ 2011-09-11 21:08 ` Lars Magne Ingebrigtsen
2011-09-11 21:54 ` Andreas Schwab
2016-01-10 22:12 ` Alan J Third
0 siblings, 2 replies; 14+ messages in thread
From: Lars Magne Ingebrigtsen @ 2011-09-11 21:08 UTC (permalink / raw)
To: Markus Triska; +Cc: 2099
Markus Triska <markus.triska@gmx.at> writes:
> When you do:
>
> $ emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
>
> then Emacs crashes with:
>
> Program received signal EXC_BAD_ACCESS, Could not access memory.
> Reason: KERN_INVALID_ADDRESS at address: 0xbf7ffffc
> 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
> (gdb) bt
> #0 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
I can confirm that the crash is still present in Emacs 24:
[larsi@stories ~/src/emacs/trunk]$ gdb --args ./src/emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
[...]
(gdb) run
Starting program: /home/larsi/src/emacs/trunk/src/emacs -Q --eval \(let\ \(v\)\ \(while\ t\ \(setq\ v\ \(cons\ v\ v\)\)\)\)
[Thread debugging using libthread_db enabled]
Program received signal SIGSEGV, Segmentation fault.
mark_object (arg=21115190) at alloc.c:5396
5396 {
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog http://lars.ingebrigtsen.no/
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2011-09-11 21:54 ` Andreas Schwab
@ 2011-09-11 21:53 ` Lars Magne Ingebrigtsen
2011-09-11 23:47 ` Lars Magne Ingebrigtsen
0 siblings, 1 reply; 14+ messages in thread
From: Lars Magne Ingebrigtsen @ 2011-09-11 21:53 UTC (permalink / raw)
To: Andreas Schwab; +Cc: Markus Triska, 2099
Andreas Schwab <schwab@linux-m68k.org> writes:
> This creates a deeply nested object that is doomed to overflow the stack
> during garbage collecting. There are many ways to shoot yourself in the
> foot.
But it would be nice if Emacs did something other than segfault. :-)
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog http://lars.ingebrigtsen.no/
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2011-09-11 21:08 ` Lars Magne Ingebrigtsen
@ 2011-09-11 21:54 ` Andreas Schwab
2011-09-11 21:53 ` Lars Magne Ingebrigtsen
2016-01-10 22:12 ` Alan J Third
1 sibling, 1 reply; 14+ messages in thread
From: Andreas Schwab @ 2011-09-11 21:54 UTC (permalink / raw)
To: Lars Magne Ingebrigtsen; +Cc: Markus Triska, 2099
Lars Magne Ingebrigtsen <larsi@gnus.org> writes:
> I can confirm that the crash is still present in Emacs 24:
>
> [larsi@stories ~/src/emacs/trunk]$ gdb --args ./src/emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
This creates a deeply nested object that is doomed to overflow the stack
during garbage collecting. There are many ways to shoot yourself in the
foot.
Andreas.
--
Andreas Schwab, schwab@linux-m68k.org
GPG Key fingerprint = 58CA 54C7 6D53 942B 1756 01D3 44D5 214B 8276 4ED5
"And now for something completely different."
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2011-09-11 21:53 ` Lars Magne Ingebrigtsen
@ 2011-09-11 23:47 ` Lars Magne Ingebrigtsen
0 siblings, 0 replies; 14+ messages in thread
From: Lars Magne Ingebrigtsen @ 2011-09-11 23:47 UTC (permalink / raw)
To: 2099
So, the problem here seems simply to be that we blow up the stack by
recursing so ridiculously deep? I think?
Looking at mark_object, it seems like it could pretty easily be
rewritten to be non-recursive, just by changing it into a loop, and
using a stack to do visit all the objects.
But that's probably not an Emacs 24.1 thing.
The other question is what other interesting deep-nesting bugs a
structure like that might reveal, so even if we fix the mark_object
case, that might not help us much. Difficult to say...
--
(domestic pets only, the antidote for overdose, milk.)
bloggy blog http://lars.ingebrigtsen.no/
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2011-09-11 21:08 ` Lars Magne Ingebrigtsen
2011-09-11 21:54 ` Andreas Schwab
@ 2016-01-10 22:12 ` Alan J Third
2016-01-11 15:11 ` Eli Zaretskii
1 sibling, 1 reply; 14+ messages in thread
From: Alan J Third @ 2016-01-10 22:12 UTC (permalink / raw)
To: Lars Magne Ingebrigtsen; +Cc: Markus Triska, 2099
Lars Magne Ingebrigtsen <larsi@gnus.org> writes:
> Markus Triska <markus.triska@gmx.at> writes:
>
>> When you do:
>>
>> $ emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
>>
>> then Emacs crashes with:
>>
>> Program received signal EXC_BAD_ACCESS, Could not access memory.
>> Reason: KERN_INVALID_ADDRESS at address: 0xbf7ffffc
>> 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
>> (gdb) bt
>> #0 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
>
> I can confirm that the crash is still present in Emacs 24:
And Emacs 25:
Fatal error 11: Segmentation fault
--
Alan Third
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-10 22:12 ` Alan J Third
@ 2016-01-11 15:11 ` Eli Zaretskii
2016-01-11 17:49 ` Alan J Third
0 siblings, 1 reply; 14+ messages in thread
From: Eli Zaretskii @ 2016-01-11 15:11 UTC (permalink / raw)
To: Alan J Third; +Cc: larsi, markus.triska, 2099
> From: Alan J Third <alan@idiocy.org>
> Date: Sun, 10 Jan 2016 22:12:10 +0000
> Cc: Markus Triska <markus.triska@gmx.at>, 2099@debbugs.gnu.org
>
> > Markus Triska <address@hidden> writes:
> >
> >> When you do:
> >>
> >> $ emacs -Q --eval "(let (v) (while t (setq v (cons v v))))"
> >>
> >> then Emacs crashes with:
> >>
> >> Program received signal EXC_BAD_ACCESS, Could not access memory.
> >> Reason: KERN_INVALID_ADDRESS at address: 0xbf7ffffc
> >> 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
> >> (gdb) bt
> >> #0 0x0013bc1a in mark_object (arg=40166541) at alloc.c:5372
> >
> > I can confirm that the crash is still present in Emacs 24:
>
> And Emacs 25:
>
> Fatal error 11: Segmentation fault
Of course: this is expected.
I admit I don't really understand what is the purpose of this bug
report; perhaps the OP could clarify.
Here's my take on this:
. What happens is clear: stack overflow during GC. Since the stack
space is always limited, one can always overflow it by
deliberately consing larger and larger objects.
. When stack overflow happens during GC, Emacs commits suicide,
because such fatal errors are not recoverable with the current
code.
. Making GC non-recursive is a large job, that will most probably
require significant changes in GC as a whole, not just in the
recursive mark step. If someone wants to work on that, they
surely don't need this bug as an inspiration.
IOW, this is a known limitation of the current GC implementation. So
I think we should mark this bug "wishlist" (or maybe even "wontfix"),
and leave it at that.
Any objections/comments/suggestions?
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 15:11 ` Eli Zaretskii
@ 2016-01-11 17:49 ` Alan J Third
2016-01-11 19:10 ` markus.triska
0 siblings, 1 reply; 14+ messages in thread
From: Alan J Third @ 2016-01-11 17:49 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: larsi, 2099, markus.triska
Eli Zaretskii <eliz@gnu.org> writes:
> this is a known limitation of the current GC implementation. So
> I think we should mark this bug "wishlist" (or maybe even "wontfix"),
> and leave it at that.
>
> Any objections/comments/suggestions?
My inclination would be to go with "wontfix", but I'm new around here so
I don't know that my opinion counts for much.
--
Alan Third
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 17:49 ` Alan J Third
@ 2016-01-11 19:10 ` markus.triska
2016-01-11 19:16 ` Eli Zaretskii
0 siblings, 1 reply; 14+ messages in thread
From: markus.triska @ 2016-01-11 19:10 UTC (permalink / raw)
To: Alan J Third; +Cc: larsi, 2099
Hi Alan,
Alan Third writes:
> My inclination would be to go with "wontfix", but I'm new around here so
> I don't know that my opinion counts for much.
Marking this as "wontfix" seems particularly inapplicable to me: This
shortcoming crashes Emacs and potentially causes data loss for users,
not only in such an artificial test case but in other situations too.
This shortcoming prevents my testing Emacs in many other ways that would
help me to find and correct more shortcomings and make Emacs more robust.
All the best,
Markus
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 19:10 ` markus.triska
@ 2016-01-11 19:16 ` Eli Zaretskii
2016-01-11 19:57 ` markus.triska
0 siblings, 1 reply; 14+ messages in thread
From: Eli Zaretskii @ 2016-01-11 19:16 UTC (permalink / raw)
To: markus.triska; +Cc: alan, larsi, 2099
> From: markus.triska@gmx.at
> Cc: "Eli Zaretskii" <eliz@gnu.org>, 2099@debbugs.gnu.org, larsi@gnus.org
> Date: Mon, 11 Jan 2016 20:10:26 +0100
>
> Marking this as "wontfix" seems particularly inapplicable to me: This
> shortcoming crashes Emacs and potentially causes data loss for users,
> not only in such an artificial test case but in other situations too.
> This shortcoming prevents my testing Emacs in many other ways that would
> help me to find and correct more shortcomings and make Emacs more robust.
Sorry, I don't understand: what testing? Can you describe the
real-life use case behind this bug report? The recipe as shown looks
like a deliberate way to cause Emacs to overflow its stack; surely,
that's not what you intended to test?
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 19:16 ` Eli Zaretskii
@ 2016-01-11 19:57 ` markus.triska
2016-01-11 20:32 ` Alan J Third
2016-01-11 20:32 ` Eli Zaretskii
0 siblings, 2 replies; 14+ messages in thread
From: markus.triska @ 2016-01-11 19:57 UTC (permalink / raw)
To: eliz; +Cc: alan, larsi, 2099
> Sorry, I don't understand: what testing? Can you describe the
> real-life use case behind this bug report? The recipe as shown looks
> like a deliberate way to cause Emacs to overflow its stack; surely,
> that's not what you intended to test?
That's not what I intended to test: Emacs crashing on such datastructures
prevents more serious automatic tests that can, among other data, also
create such structures. So far, this shortcoming has prevented my working
further on such tests.
I find it hard to believe that a way to crash Emacs is somehow *not*
considered a bug. If that is the case, I agree with what Glenn recently
said: Just deal with this report in any way you wish.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 19:57 ` markus.triska
@ 2016-01-11 20:32 ` Alan J Third
2016-01-11 20:45 ` Eli Zaretskii
2016-01-11 20:32 ` Eli Zaretskii
1 sibling, 1 reply; 14+ messages in thread
From: Alan J Third @ 2016-01-11 20:32 UTC (permalink / raw)
To: markus.triska; +Cc: larsi, 2099
markus.triska@gmx.at writes:
> I find it hard to believe that a way to crash Emacs is somehow *not*
> considered a bug. If that is the case, I agree with what Glenn recently
> said: Just deal with this report in any way you wish.
My thinking was simply that it sounds like it will require
reimplementation of the GC, and that's not likely to happen any time
soon, or perhaps ever.
Looking over the debbugs docs again, though, it should probably be
changed to wishlist, as Eli suggested originally. Like you say, a crash
is surely a bug, even if it is hard to fix.
FWIW I found a 'real-world' bug report, bug#16039, which appears to have
the same cause, although it requires a different remedy.
--
Alan Third
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 19:57 ` markus.triska
2016-01-11 20:32 ` Alan J Third
@ 2016-01-11 20:32 ` Eli Zaretskii
1 sibling, 0 replies; 14+ messages in thread
From: Eli Zaretskii @ 2016-01-11 20:32 UTC (permalink / raw)
To: markus.triska; +Cc: alan, larsi, 2099
> From: markus.triska@gmx.at
> Cc: alan@idiocy.org, 2099@debbugs.gnu.org, larsi@gnus.org
> Date: Mon, 11 Jan 2016 20:57:49 +0100
>
> > Sorry, I don't understand: what testing? Can you describe the
> > real-life use case behind this bug report? The recipe as shown looks
> > like a deliberate way to cause Emacs to overflow its stack; surely,
> > that's not what you intended to test?
>
> That's not what I intended to test: Emacs crashing on such datastructures
> prevents more serious automatic tests that can, among other data, also
> create such structures.
I'm asking to describe the data structures that you intended to test,
and their purpose. The recipe that you posted when you filed the bug
conses an infinitely large object in an infinite loop. Can you please
tell what is the purpose of creating such a data structure in this
way? It's clear that at some point Emacs will run out of memory, and
it is also clear that at some other point it will GC. So what is
being tested by such a data structure, given that these outcomes are
known in advance?
> So far, this shortcoming has prevented my working further on such
> tests.
Knowing more about those tests might help us become more motivated to
work on the problems that interfere with your testing, or suggest how
to work around them.
> I find it hard to believe that a way to crash Emacs is somehow *not*
> considered a bug.
There could be many ways to overcome these problems, some of them
easier than others. It all depends on what problems get in your way.
For example, there could be a way of letting Emacs run out of heap
memory without triggering GC -- would that help you continue with your
testing? I don't know, maybe you could tell.
IOW, if there are practical issues for which you'd like to have a
solution or a workaround, so that you could continue with your
testing, we could try helping you on that way. I'm sure you agree
that leaving the bug without any action will not help you make any
progress with your project. Please help us help you in any practical
way that's possible, by telling more about the specific aspects of
Emacs you'd like to test.
> If that is the case, I agree with what Glenn recently said: Just
> deal with this report in any way you wish.
Relax, no one said this isn't a bug, so this is uncalled for. I'm
just trying to understand what is being tested here. I couldn't
understand that from the recipe you posted, because that recipe has an
outcome that's known in advance.
^ permalink raw reply [flat|nested] 14+ messages in thread
* bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs
2016-01-11 20:32 ` Alan J Third
@ 2016-01-11 20:45 ` Eli Zaretskii
0 siblings, 0 replies; 14+ messages in thread
From: Eli Zaretskii @ 2016-01-11 20:45 UTC (permalink / raw)
To: Alan J Third; +Cc: larsi, markus.triska, 2099
> From: Alan J Third <alan@idiocy.org>
> Cc: eliz@gnu.org, 2099@debbugs.gnu.org, larsi@gnus.org
> Date: Mon, 11 Jan 2016 20:32:48 +0000
>
> FWIW I found a 'real-world' bug report, bug#16039, which appears to have
> the same cause, although it requires a different remedy.
No, that's a different cause. That bug is about stack overflow in
regexp matcher, not in GC. Such stack overflows should nowadays be
recoverable (at least on most platforms), unlike a stack overflow in
GC that still isn't.
^ permalink raw reply [flat|nested] 14+ messages in thread
end of thread, other threads:[~2016-01-11 20:45 UTC | newest]
Thread overview: 14+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2009-01-28 23:06 bug#2099: 23.0.60; `mark_object' with larger nested objects crashes Emacs Markus Triska
2011-09-11 21:08 ` Lars Magne Ingebrigtsen
2011-09-11 21:54 ` Andreas Schwab
2011-09-11 21:53 ` Lars Magne Ingebrigtsen
2011-09-11 23:47 ` Lars Magne Ingebrigtsen
2016-01-10 22:12 ` Alan J Third
2016-01-11 15:11 ` Eli Zaretskii
2016-01-11 17:49 ` Alan J Third
2016-01-11 19:10 ` markus.triska
2016-01-11 19:16 ` Eli Zaretskii
2016-01-11 19:57 ` markus.triska
2016-01-11 20:32 ` Alan J Third
2016-01-11 20:45 ` Eli Zaretskii
2016-01-11 20:32 ` Eli Zaretskii
Code repositories for project(s) associated with this external index
https://git.savannah.gnu.org/cgit/emacs.git
https://git.savannah.gnu.org/cgit/emacs/org-mode.git
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.