unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
From: Rainer M Krug <Rainer@krugs.de>
To: Eli Zaretskii <eliz@gnu.org>
Cc: 21428@debbugs.gnu.org, mituharu+bug-gnu-emacs-mac@math.s.chiba-u.ac.jp
Subject: bug#21428: 24.5; Crash of emacs on OS X, installed via homebrew cask
Date: Wed, 30 Sep 2015 11:49:10 +0200	[thread overview]
Message-ID: <m2zj041bl5.fsf@krugs.de> (raw)
In-Reply-To: <m2h9md327z.fsf@krugs.de> (Rainer M. Krug's message of "Tue, 29 Sep 2015 13:16:16 +0200")

[-- Attachment #1: Type: text/plain, Size: 12263 bytes --]

Rainer M Krug <Rainer@krugs.de> writes:

> Eli Zaretskii <eliz@gnu.org> writes:
>
>>> From: Rainer M Krug <Rainer@krugs.de>
>>> Cc: 21428@debbugs.gnu.org,  mituharu+bug-gnu-emacs-mac@math.s.chiba-u.ac.jp
>>> Date: Tue, 29 Sep 2015 12:17:33 +0200
>>> 
>>> > OK, for now just add GET_FROM_IMAGE to the assertion, like this:
>>> >
>>> >   eassert (it->method == GET_FROM_BUFFER
>>> > 	   || it->method == GET_FROM_DISPLAY_VECTOR
>>> > 	   || it->method == GET_FROM_STRING
>>> > 	   || it->method == GET_FROM_IMAGE);
>>> >
>>> > recompile,
>>> 
>>> Done
>>> 
>>> > and see if this gets you past the crashes in
>>> > push_prefix_prop when those inhibit-* variables are set to t.
>>> 
>>> OK
>>> 
>>> > If it does, then let's see if running with those inhibit-* variables
>>> > set to t can trigger the crashes due to invalid face ID in
>>> > get_glyph_face_and_encoding.
>>> 
>>> I assume you mean here to set them to NILL?
>>
>> No, I mean continue running with them set to t, and see if the crashes
>> in get_glyph_face_and_encoding are prevented by disabling these
>> redisplay optimizations.
>
> OK - got it. So continue the initial plan.

They are all set to t and I got the following crash:

Let me know if you need any further info - I will leave the session
open.

Rainer


,----
| xdisp.c:24350: Emacs fatal error: assertion failed: face != NULL
| 
| Breakpoint 1, terminate_due_to_signal (sig=6, backtrace_limit=2147483647) at emacs.c:370
| 370	  signal (sig, SIG_DFL);
| (gdb) bt
| #0  terminate_due_to_signal (sig=6, backtrace_limit=2147483647) at emacs.c:370
| #1  0x0000000100229d6b in die (msg=0x1003bbad3 "face != NULL", file=0x1003b70d0 "xdisp.c", line=24350) at alloc.c:6951
| #2  0x0000000100065467 in get_glyph_face_and_encoding (f=0x104811630, glyph=0x11ca93400, char2b=0x7fff5fbfb660) at xdisp.c:24350
| #3  0x00000001000b860d in fill_glyph_string (s=0x7fff5fbfb6c0, face_id=48, start=0, end=42, overlaps=0) at xdisp.c:24575
| #4  0x000000010006fb19 in draw_glyphs (w=0x11226a6b8, x=8, row=0x11fa6e100, area=TEXT_AREA, start=0, end=42, hl=DRAW_NORMAL_TEXT, overlaps=0) at xdisp.c:25242
| #5  0x000000010006f441 in x_write_glyphs (w=0x11226a6b8, updated_row=0x11fa6e100, start=0x11ca93400, updated_area=TEXT_AREA, len=42) at xdisp.c:27273
| #6  0x000000010001248a in update_text_area (w=0x11226a6b8, updated_row=0x11fa6e100, vpos=1) at dispnew.c:3611
| #7  0x00000001000100a4 in update_window_line (w=0x11226a6b8, vpos=1, mouse_face_overwritten_p=0x7fff5fbfbdd2) at dispnew.c:3854
| #8  0x0000000100007ca4 in update_window (w=0x11226a6b8, force_p=true) at dispnew.c:3477
| #9  0x000000010000681f in update_window_tree (w=0x11226a6b8, force_p=true) at dispnew.c:3219
| #10 0x00000001000067cd in update_window_tree (w=0x11ca87fa8, force_p=true) at dispnew.c:3217
| #11 0x00000001000064db in update_frame (f=0x104811630, force_p=true, inhibit_hairy_id_p=false) at dispnew.c:3108
| #12 0x0000000100052bc5 in redisplay_internal () at xdisp.c:13826
| #13 0x00000001000546f9 in redisplay () at xdisp.c:13067
| #14 0x00000001001889b9 in read_char (commandflag=1, map=4754523971, prev_event=0, used_mouse_menu=0x7fff5fbfefc7, end_time=0x0) at keyboard.c:2465
| #15 0x0000000100183919 in read_key_sequence (keybuf=0x7fff5fbff300, bufsize=30, prompt=0, dont_downcase_last=false, can_return_switch_frame=true, fix_current_buffer=true, prevent_redisplay=false) at keyboard.c:9030
| #16 0x0000000100182216 in command_loop_1 () at keyboard.c:1348
| #17 0x0000000100264d86 in internal_condition_case (bfun=0x100181c20 <command_loop_1>, handlers=17616, hfun=0x10019d490 <cmd_error>) at eval.c:1309
| #18 0x000000010019d38c in command_loop_2 (ignore=0) at keyboard.c:1088
| #19 0x0000000100263e4e in internal_catch (tag=42768, func=0x10019d360 <command_loop_2>, arg=0) at eval.c:1073
| #20 0x0000000100180f60 in command_loop () at keyboard.c:1067
| #21 0x0000000100180da2 in recursive_edit_1 () at keyboard.c:673
| #22 0x0000000100181193 in Frecursive_edit () at keyboard.c:744
| #23 0x000000010017ed3a in main (argc=1, argv=0x7fff5fbff908) at emacs.c:1643
| 
| Lisp Backtrace:
| "redisplay_internal (C function)" (0x0)
| (gdb) tb full
| Function "full" not defined.
| Make breakpoint pending on future shared library load? (y or [n]) bt full
| Please answer y or [n].
| Make breakpoint pending on future shared library load? (y or [n]) n
| (gdb) bt full
| #0  terminate_due_to_signal (sig=6, backtrace_limit=2147483647) at emacs.c:370
| No locals.
| #1  0x0000000100229d6b in die (msg=0x1003bbad3 "face != NULL", file=0x1003b70d0 "xdisp.c", line=24350) at alloc.c:6951
| No locals.
| #2  0x0000000100065467 in get_glyph_face_and_encoding (f=0x104811630, glyph=0x11ca93400, char2b=0x7fff5fbfb660) at xdisp.c:24350
| 	face = (struct face *) 0x0
| 	code = 0
| #3  0x00000001000b860d in fill_glyph_string (s=0x7fff5fbfb6c0, face_id=48, start=0, end=42, overlaps=0) at xdisp.c:24575
| 	glyph = (struct glyph *) 0x11ca93400
| 	last = (struct glyph *) 0x11ca93be0
| 	voffset = 0
| 	glyph_not_available_p = false
| #4  0x000000010006fb19 in draw_glyphs (w=0x11226a6b8, x=8, row=0x11fa6e100, area=TEXT_AREA, start=0, end=42, hl=DRAW_NORMAL_TEXT, overlaps=0) at xdisp.c:25242
| 	face_id = 48
| 	char2b = (XChar2b *) 0x7fff5fbfb660
| 	first_glyph = (struct glyph *) 0x11ca93400
| 	head = (struct glyph_string *) 0x7fff5fbfb6c0
| 	tail = (struct glyph_string *) 0x7fff5fbfb6c0
| 	s = (struct glyph_string *) 0x7fff5fbfb6c0
| 	clip_head = (struct glyph_string *) 0x0
| 	clip_tail = (struct glyph_string *) 0x0
| 	i = 0
| 	j = 1531018
| 	x_reached = 1
| 	last_x = 1257
| 	area_left = 8
| 	f = (struct frame *) 0x104811630
| 	sa_avail = 16300
| 	sa_count = 5
| 	sa_must_free = false
| #5  0x000000010006f441 in x_write_glyphs (w=0x11226a6b8, updated_row=0x11fa6e100, start=0x11ca93400, updated_area=TEXT_AREA, len=42) at xdisp.c:27273
| 	x = 16777216
| 	hpos = 0
| 	chpos = 35
| #6  0x000000010001248a in update_text_area (w=0x11226a6b8, updated_row=0x11fa6e100, vpos=1) at dispnew.c:3611
| 	current_row = (struct glyph_row *) 0x11ca42500
| 	desired_row = (struct glyph_row *) 0x11fa6e100
| 	rif = (struct redisplay_interface *) 0x1007df0a8
| 	changed_p = false
| #7  0x00000001000100a4 in update_window_line (w=0x11226a6b8, vpos=1, mouse_face_overwritten_p=0x7fff5fbfbdd2) at dispnew.c:3854
| 	current_row = (struct glyph_row *) 0x11ca42500
| 	desired_row = (struct glyph_row *) 0x11fa6e100
| 	rif = (struct redisplay_interface *) 0x1007df0a8
| 	changed_p = false
| #8  0x0000000100007ca4 in update_window (w=0x11226a6b8, force_p=true) at dispnew.c:3477
| 	vpos = 1
| 	i = 78
| 	end = (struct glyph_row *) 0x11fa76e00
| 	mode_line_row = (struct glyph_row *) 0x11fa76e00
| 	header_line_row = (struct glyph_row *) 0x11fa6e000
| 	changed_p = false
| 	mouse_face_overwritten_p = false
| 	row = (struct glyph_row *) 0x11fa6e100
| 	yb = 1402
| 	n_updated = 0
| 	desired_matrix = (struct glyph_matrix *) 0x1143f3830
| 	paused_p = false
| 	preempt_count = 17
| 	rif = (struct redisplay_interface *) 0x1007df0a8
| #9  0x000000010000681f in update_window_tree (w=0x11226a6b8, force_p=true) at dispnew.c:3219
| 	paused_p = false
| #10 0x00000001000067cd in update_window_tree (w=0x11ca87fa8, force_p=true) at dispnew.c:3217
| 	paused_p = false
| #11 0x00000001000064db in update_frame (f=0x104811630, force_p=true, inhibit_hairy_id_p=false) at dispnew.c:3108
| 	paused_p = 255
| 	root_window = (struct window *) 0x11ca87fa8
| #12 0x0000000100052bc5 in redisplay_internal () at xdisp.c:13826
| 	gcscrollbars = true
| 	f = (struct frame *) 0x104811630
| 	w = (struct window *) 0x11226a6b8
| 	sw = (struct window *) 0x11226a6b8
| 	fr = (struct frame *) 0x104811630
| 	pending = false
| 	must_finish = true
| 	match_p = true
| 	tlbufpos = {
|   charpos = 43,
|   bytepos = 43
| }
| 	tlendpos = {
|   charpos = 13586,
|   bytepos = 13586
| }
| 	number_of_visible_frames = 1
| 	count = 2
| 	sf = (struct frame *) 0x104811630
| 	polling_stopped_here = true
| 	tail = 4412463651
| 	frame = 4370535989
| 	consider_all_windows_p = true
| 	update_miniwindow_p = true
| #13 0x00000001000546f9 in redisplay () at xdisp.c:13067
| No locals.
| #14 0x00000001001889b9 in read_char (commandflag=1, map=4754523971, prev_event=0, used_mouse_menu=0x7fff5fbfefc7, end_time=0x0) at keyboard.c:2465
| 	echo_current = false
| 	c = 0
| 	jmpcount = 140734799801376
| 	local_getcjmp = 0x7fff5fbfebb0
| 	save_jump = 0x7fff5fbfeb10
| 	tem = 2
| 	save = 0
| 	previous_echo_area_message = 0
| 	also_record = 0
| 	reread = false
| 	recorded = false
| 	polling_stopped_here = false
| 	orig_kboard = (struct kboard *) 0x10120d1a0
| #15 0x0000000100183919 in read_key_sequence (keybuf=0x7fff5fbff300, bufsize=30, prompt=0, dont_downcase_last=false, can_return_switch_frame=true, fix_current_buffer=true, prevent_redisplay=false) at keyboard.c:9030
| 	interrupted_kboard = (KBOARD *) 0x10120d1a0
| 	interrupted_frame = (struct frame *) 0x104811630
| 	key = 0
| 	used_mouse_menu = false
| 	echo_local_start = 0
| 	last_real_key_start = 0
| 	keys_local_start = 0
| 	new_binding = 4303307192
| 	count = 2
| 	t = 0
| 	echo_start = 0
| 	keys_start = 0
| 	current_binding = 4754523971
| 	first_event = 0
| 	first_unbound = 31
| 	mock_input = 0
| 	fkey = {
|   parent = 4412433507,
|   map = 4412433507,
|   start = 0,
|   end = 0
| }
| 	keytran = {
|   parent = 4336943683,
|   map = 4336943683,
|   start = 0,
|   end = 0
| }
| 	indec = {
|   parent = 4412433651,
|   map = 4412433651,
|   start = 0,
|   end = 0
| }
| 	shift_translated = false
| 	delayed_switch_frame = 0
| 	original_uppercase = 0
| 	original_uppercase_position = -1
| 	dummyflag = false
| 	starting_buffer = (struct buffer *) 0x1119a7dd0
| 	fake_prefixed_keys = 0
| #16 0x0000000100182216 in command_loop_1 () at keyboard.c:1348
| 	cmd = 18099272
| 	keybuf = 0x7fff5fbff300
| 	i = 2
| 	prev_modiff = 14849
| 	prev_buffer = (struct buffer *) 0x1119a7dd0
| 	already_adjusted = false
| #17 0x0000000100264d86 in internal_condition_case (bfun=0x100181c20 <command_loop_1>, handlers=17616, hfun=0x10019d490 <cmd_error>) at eval.c:1309
| 	val = 4303324808
| 	c = (struct handler *) 0x101043ab0
| #18 0x000000010019d38c in command_loop_2 (ignore=0) at keyboard.c:1088
| 	val = 2
| #19 0x0000000100263e4e in internal_catch (tag=42768, func=0x10019d360 <command_loop_2>, arg=0) at eval.c:1073
| 	val = 0
| 	c = (struct handler *) 0x1010439c0
| #20 0x0000000100180f60 in command_loop () at keyboard.c:1067
| No locals.
| #21 0x0000000100180da2 in recursive_edit_1 () at keyboard.c:673
| 	count = 1
| 	val = 0
| #22 0x0000000100181193 in Frecursive_edit () at keyboard.c:744
| 	count = 0
| 	buffer = 0
| #23 0x000000010017ed3a in main (argc=1, argv=0x7fff5fbff908) at emacs.c:1643
| 	dummy = 140734799806464
| 	stack_bottom_variable = 0 '\0'
| 	do_initial_setlocale = true
| 	dumping = false
| 	skip_args = 0
| 	rlim = {
|   rlim_cur = 8720000,
|   rlim_max = 67104768
| }
| 	no_loadup = false
| 	junk = 0x0
| 	dname_arg = 0x0
| 	dname_arg2 = 0x7fff5fbff880 "\001"
| 	ch_to_dir = 0x0
| 	original_pwd = 0x0
| 
| Lisp Backtrace:
| "redisplay_internal (C function)" (0x0)
| (gdb)
`----


>
>>
>> IOW, if the assertion violation in push_prefix_prop is no longer in
>> the way, let's go back to our plan of trying to figure out which
>> redisplay optimizations cause the crashes in
>> get_glyph_face_and_encoding: first run with all optimizations
>> disabled, and if that avoids the crashes in
>> get_glyph_face_and_encoding, re-enable the optimizations one by one to
>> see which one reintroduces the crashes.
>
> OK - will do so.
>
>>
>> The assertion violations in push_prefix_prop are a separate issue,
>> unrelated to the original problem we are trying to solve.  It just
>> distracted us for a while, because you were unable to run without
>> hitting them.
>
> Ah - was wondering already a bit about the different non-similar
> messages.
>
> Thanks for your patience,
>
> Rainer
>
>>
>> Thanks.

-- 
Rainer M. Krug
email: Rainer<at>krugs<dot>de
PGP: 0x0F52F982

[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 454 bytes --]

  reply	other threads:[~2015-09-30  9:49 UTC|newest]

Thread overview: 100+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2015-09-07 10:08 bug#21428: 24.5; Crash of emacs on OS X, installed via homebrew cask Rainer M Krug
2015-09-07 15:14 ` Eli Zaretskii
2015-09-07 17:46   ` Rainer M Krug
2015-09-08 18:16     ` Eli Zaretskii
2015-09-09  7:39       ` Rainer M Krug
2015-09-09  8:42       ` Rainer M Krug
2015-09-11  9:50         ` Rainer M Krug
2015-09-21  8:42           ` Rainer M Krug
2015-09-21  9:37             ` Eli Zaretskii
2015-09-21 10:00               ` Rainer M Krug
2015-09-21 10:19               ` Rainer M Krug
2015-09-21 10:25                 ` Eli Zaretskii
2015-09-21 11:00             ` Eli Zaretskii
     [not found]               ` <m27fnkroj5.fsf@krugs.de>
     [not found]                 ` <83y4g0m0js.fsf@gnu.org>
     [not found]                   ` <m2y4g0q7fs.fsf@krugs.de>
2015-09-21 13:18                     ` Eli Zaretskii
2015-09-21 13:27                       ` Rainer M Krug
2015-09-21 13:35                         ` Eli Zaretskii
2015-09-21 13:46                           ` Rainer M Krug
2015-09-23  8:41                           ` Rainer M Krug
2015-09-23  9:48                             ` Eli Zaretskii
2015-09-23 10:00                               ` Rainer M Krug
2015-09-24 13:22                               ` Rainer M Krug
2015-09-24 16:29                                 ` Eli Zaretskii
2015-09-24 17:22                                   ` Rainer M Krug
2015-09-24 18:23                                     ` Eli Zaretskii
2015-09-24 18:37                                       ` Rainer M Krug
2015-09-24 18:55                                         ` Eli Zaretskii
2015-09-25  9:34                                           ` Rainer M Krug
2015-09-25 10:01                                             ` Eli Zaretskii
2015-09-25 10:46                                               ` Rainer M Krug
2015-09-25 12:30                                                 ` Rainer M Krug
2015-09-25 14:39                                                   ` Eli Zaretskii
2015-09-28  9:33                                                     ` Rainer M Krug
2015-09-28 10:03                                                       ` Eli Zaretskii
2015-09-28 11:12                                                         ` Rainer M Krug
2015-09-28 11:27                                                           ` Rainer M Krug
2015-09-28 12:00                                                             ` Eli Zaretskii
2015-09-28 12:53                                                               ` Rainer M Krug
2015-09-28 13:14                                                             ` Eli Zaretskii
2015-09-28 15:39                                                               ` Rainer M Krug
2015-09-28 16:30                                                                 ` Rainer M Krug
2015-09-28 16:42                                                                   ` Eli Zaretskii
2015-09-29  6:58                                                                     ` Rainer M Krug
2015-09-29  7:22                                                                       ` Eli Zaretskii
2015-09-29  8:01                                                                         ` Rainer M Krug
2015-09-29  8:30                                                                           ` Eli Zaretskii
2015-09-29  8:52                                                                             ` Rainer M Krug
2015-09-29  9:52                                                                               ` Eli Zaretskii
2015-09-29 10:17                                                                                 ` Rainer M Krug
2015-09-29 10:50                                                                                   ` Eli Zaretskii
2015-09-29 11:16                                                                                     ` Rainer M Krug
2015-09-30  9:49                                                                                       ` Rainer M Krug [this message]
2015-09-30 10:06                                                                                         ` Eli Zaretskii
2015-09-30 10:36                                                                                           ` Rainer M Krug
2015-09-30 18:49                                                                                             ` Eli Zaretskii
2015-09-30 10:37                                                                                           ` Rainer M Krug
2015-09-30 19:38                                                                                             ` Eli Zaretskii
2015-10-01  7:29                                                                                               ` Rainer M Krug
2015-10-01  8:21                                                                                                 ` Rainer M Krug
2015-10-01  9:36                                                                                                   ` Eli Zaretskii
2015-10-01 10:45                                                                                                     ` Rainer M Krug
2015-10-06  8:16                                                                                                       ` Rainer M Krug
2015-10-06 16:47                                                                                                         ` Eli Zaretskii
2015-10-07  8:13                                                                                                           ` Rainer M Krug
2015-10-07 15:36                                                                                                             ` Eli Zaretskii
2015-10-07 16:10                                                                                                               ` Rainer M Krug
     [not found]                                                                                                                 ` <m2vba7dxds.fsf@krugs.de>
2015-10-16 18:12                                                                                                                   ` Eli Zaretskii
2015-10-16 19:22                                                                                                                     ` Rainer M Krug
2015-10-17 12:15                                                                                                                       ` Eli Zaretskii
2015-10-22 14:28                                                                                                                         ` Rainer M Krug
2015-10-22 15:43                                                                                                                           ` Eli Zaretskii
2015-10-22 16:22                                                                                                                             ` Rainer M Krug
2015-10-22 17:05                                                                                                                               ` Eli Zaretskii
2015-10-22 17:32                                                                                                                                 ` martin rudalics
2015-10-22 17:40                                                                                                                                   ` Eli Zaretskii
2015-10-22 18:14                                                                                                                                     ` martin rudalics
2015-10-22 20:04                                                                                                                                       ` Anders Lindgren
2015-10-22 20:08                                                                                                                                         ` Eli Zaretskii
2015-10-23  9:51                                                                                                                                           ` Rainer M Krug
2015-10-23 10:44                                                                                                                                             ` Anders Lindgren
2015-10-23 11:03                                                                                                                                               ` Rainer M Krug
2015-10-23  9:52                                                                                                                                           ` Rainer M Krug
2015-10-23  8:02                                                                                                                                         ` martin rudalics
2015-10-23 18:01                                                                                                                                         ` martin rudalics
2015-10-23  9:49                                                                                                                                       ` Rainer M Krug
2015-10-23 18:01                                                                                                                                         ` martin rudalics
2015-10-23  9:45                                                                                                                                   ` Rainer M Krug
2015-10-23 18:01                                                                                                                                     ` martin rudalics
2015-10-23  9:41                                                                                                                                 ` Rainer M Krug
2015-10-25 19:04                                                                                                                               ` Eli Zaretskii
2015-10-26  7:59                                                                                                                                 ` Rainer M Krug
2015-10-26 19:09                                                                                                                                   ` Eli Zaretskii
2015-10-27 11:50                                                                                                                                     ` Rainer M Krug
2015-09-28 11:58                                                           ` Eli Zaretskii
2015-09-23  8:58                           ` Rainer M Krug
2015-09-23  9:51                             ` Eli Zaretskii
2015-09-08 23:24     ` Glenn Morris
2015-09-09  7:39       ` Rainer M Krug
2015-09-09  4:32     ` Xue Fuqiao
2015-09-09  7:38       ` Rainer M Krug
2015-09-09 14:47 ` bug#21428: possible additional case for #21428: Emacs 24.5.1 on OSX, installed via homebrew Jason May

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

  List information: https://www.gnu.org/software/emacs/

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=m2zj041bl5.fsf@krugs.de \
    --to=rainer@krugs.de \
    --cc=21428@debbugs.gnu.org \
    --cc=eliz@gnu.org \
    --cc=mituharu+bug-gnu-emacs-mac@math.s.chiba-u.ac.jp \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

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).