GNU bug report logs - #28630
27.0.50; C-g while a non-main thread is sitting crashes Emacs

Previous Next

Package: emacs;

Reported by: Alex <agrambot <at> gmail.com>

Date: Thu, 28 Sep 2017 07:24:01 UTC

Severity: normal

Found in version 27.0.50

Done: Eli Zaretskii <eliz <at> gnu.org>

Bug is archived. No further changes may be made.

Full log


View this message in rfc822 format

From: help-debbugs <at> gnu.org (GNU bug Tracking System)
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: tracker <at> debbugs.gnu.org
Subject: bug#28630: closed (27.0.50; C-g while a non-main thread is
 sitting crashes Emacs)
Date: Wed, 04 Oct 2017 09:25:02 +0000
[Message part 1 (text/plain, inline)]
Your message dated Wed, 04 Oct 2017 12:23:19 +0300
with message-id <834lrfz2pk.fsf <at> gnu.org>
and subject line Re: bug#28630: 27.0.50; C-g while a non-main thread is sitting crashes Emacs
has caused the debbugs.gnu.org bug report #28630,
regarding 27.0.50; C-g while a non-main thread is sitting crashes Emacs
to be marked as done.

(If you believe you have received this mail in error, please contact
help-debbugs <at> gnu.org.)


-- 
28630: http://debbugs.gnu.org/cgi/bugreport.cgi?bug=28630
GNU Bug Tracking System
Contact help-debbugs <at> gnu.org with problems
[Message part 2 (message/rfc822, inline)]
From: Alex <agrambot <at> gmail.com>
To: bug-gnu-emacs <at> gnu.org
Subject: 27.0.50; C-g while a non-main thread is sitting crashes Emacs
Date: Thu, 28 Sep 2017 01:22:58 -0600
Evaluate the following in emacs -Q:

(make-thread
 (lambda ()
   (message "hello")
   (sit-for 2)
   (message "there")))

Executing C-g before this finishes crashes Emacs. Here's a backtrace:

#0  0x00007fffefa8bfcf in __GI_raise (sig=sig <at> entry=6) at ../sysdeps/unix/sysv/linux/raise.c:51
#1  0x00007fffefa8d3fa in __GI_abort () at abort.c:89
#2  0x00007fffefac9bd0 in __libc_message (do_abort=do_abort <at> entry=2, fmt=fmt <at> entry=0x7fffefbbd2c5 "*** %s ***: %s terminated\n") at ../sysdeps/posix/libc_fatal.c:175
#3  0x00007fffefb521b7 in __GI___fortify_fail (msg=0x7fffefbbd284 <longjmp_msg> "longjmp causes uninitialized stack frame") at fortify_fail.c:30
#4  0x00007fffefb520ed in ____longjmp_chk () at ../sysdeps/unix/sysv/linux/x86_64/____longjmp_chk.S:100
#5  0x00007fffefb5204b in __longjmp_chk (env=env <at> entry=0xbbd960 <getcjmp>, val=val <at> entry=1) at ../setjmp/longjmp.c:38
#6  0x00000000004f3007 in quit_throw_to_read_char (from_signal=from_signal <at> entry=false) at keyboard.c:10537
#7  0x0000000000501a4c in set_waiting_for_input (time_to_clear=time_to_clear <at> entry=0x7fffffffd940) at keyboard.c:10311
#8  0x00000000005a5d6d in wait_reading_process_output (time_limit=time_limit <at> entry=30, nsecs=nsecs <at> entry=0, read_kbd=read_kbd <at> entry=-1, do_display=do_display <at> entry=true, wait_for_cell=..., 
    wait_for_cell <at> entry=..., wait_proc=wait_proc <at> entry=0x0, just_wait_proc=0) at process.c:5172
#9  0x0000000000424000 in sit_for (timeout=..., reading=reading <at> entry=true, display_option=display_option <at> entry=1)
    at dispnew.c:5764
#10 0x00000000004fdeef in read_char (commandflag=commandflag <at> entry=1, map=..., 
    map <at> entry=..., prev_event=..., used_mouse_menu=used_mouse_menu <at> entry=0x7fffffffe31b, end_time=end_time <at> entry=0x0)
    at keyboard.c:2724
#11 0x00000000004feb2c in read_key_sequence (keybuf=keybuf <at> entry=0x7fffffffe420, prompt=..., 
    prompt <at> entry=..., dont_downcase_last=dont_downcase_last <at> entry=false, can_return_switch_frame=can_return_switch_frame <at> entry=true, fix_current_buffer=fix_current_buffer <at> entry=true, prevent_redisplay=prevent_redisplay <at> entry=false, bufsize=30) at keyboard.c:9154
#12 0x0000000000500576 in command_loop_1 () at keyboard.c:1372
#13 0x000000000056495e in internal_condition_case (bfun=bfun <at> entry=0x500350 <command_loop_1>, handlers=..., 
    handlers <at> entry=..., hfun=hfun <at> entry=0x4f6eb0 <cmd_error>) at eval.c:1332
#14 0x00000000004f2444 in command_loop_2 (ignore=..., ignore <at> entry=...) at keyboard.c:1114
#15 0x00000000005648cd in internal_catch (tag=..., tag <at> entry=..., func=func <at> entry=0x4f2420 <command_loop_2>, arg=..., 
    arg <at> entry=...) at eval.c:1097
#16 0x00000000004f23db in command_loop () at keyboard.c:1093
#17 0x00000000004f6ac3 in recursive_edit_1 () at keyboard.c:699
#18 0x00000000004f6de6 in Frecursive_edit () at keyboard.c:770
#19 0x000000000041a3f1 in main (argc=<optimized out>,
#argv=0x7fffffffe7a8) at emacs.c:1713

In GNU Emacs 27.0.50 (build 1, x86_64-pc-linux-gnu, GTK+ Version 3.22.18)
 of 2017-09-28 built on lylat
Repository revision: 1f02ae39310f15bf683642b9aee1cf162bd391e6
Windowing system distributor 'The X.Org Foundation', version 11.0.11903000
System Description:	Debian GNU/Linux testing (buster)

Configured features:
XPM JPEG TIFF GIF PNG RSVG IMAGEMAGICK SOUND GPM DBUS GSETTINGS NOTIFY
ACL LIBSELINUX GNUTLS LIBXML2 FREETYPE M17N_FLT LIBOTF XFT ZLIB
TOOLKIT_SCROLL_BARS GTK3 X11 LCMS2



[Message part 3 (message/rfc822, inline)]
From: Eli Zaretskii <eliz <at> gnu.org>
To: YAMAMOTO Mitsuharu <mituharu <at> math.s.chiba-u.ac.jp>
Cc: 28630-done <at> debbugs.gnu.org, tom <at> tromey.com, agrambot <at> gmail.com
Subject: Re: bug#28630: 27.0.50;
 C-g while a non-main thread is sitting crashes Emacs
Date: Wed, 04 Oct 2017 12:23:19 +0300
> Date: Wed, 04 Oct 2017 17:32:40 +0900
> From: YAMAMOTO Mitsuharu <mituharu <at> math.s.chiba-u.ac.jp>
> Cc: agrambot <at> gmail.com,
> 	28630 <at> debbugs.gnu.org,
> 	tom <at> tromey.com
> 
> > OOC, could you please see whether on X the sit-for call is
> > interrupted or not?  That is, do you see the "there" message after
> > typing C-g?
> 
> Not interrupted (I see "there") on GTK+3, GTK+2, Athena, no toolkit,
> and (my internal version of) the Mac port.

That's what I thought should happen, thanks for confirming.


This bug report was last modified 7 years and 284 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.