From: nljlistbox2@gmail.com (N. Jackson)
To: Eli Zaretskii <eliz@gnu.org>
Cc: 20808@debbugs.gnu.org
Subject: bug#20808: 24.5; Emacs looping with 100% CPU at line 15287 (?) of xdisp.c
Date: Mon, 15 Jun 2015 12:42:57 -0300 [thread overview]
Message-ID: <87a8w1uge6.fsf@moondust.localdomain> (raw)
In-Reply-To: <83616qoyyd.fsf@gnu.org> (Eli Zaretskii's message of "Sun, 14 Jun 2015 22:46:18 +0300")
At 16:46 -0300 on Sunday 2015-06-14, Eli Zaretskii wrote:
> And I understand you have set scroll-conservatively to a value larger
> than 100, is that true?
Indeed, yes:
scroll-conservatively is a variable defined in `C source code'.
Its value is 101
Original value was 0
> The loop where Emacs is evidently inflooping is this:
>
> start_y = line_bottom_y (&it1);
> do {
> RESTORE_IT (&it, &it, it1data);
> move_it_by_lines (&it, 1);
> SAVE_IT (it1, it, it1data);
> } while (line_bottom_y (&it1) - start_y < amount_to_scroll);
Yes, that's right:
15283 do {
15284 RESTORE_IT (&it, &it, it1data);
15285 move_it_by_lines (&it, 1);
15286 SAVE_IT (it1, it, it1data);
15287 } while (line_bottom_y (&it1) - start_y < amount_to_scroll);
> So what I'd like to know is values of the following variables:
>
> it.current
> it.current_y
> it.max_ascent
> it.max_descent
> it.method
> start_y
>
> With the exception of the last variable, which should stay fixed
> during the loop, please step through the loop a few times, and show
> the values of the above variables for each iteration through the loop.
At 12:03 -0300 on Monday 2015-06-15, Eli Zaretskii wrote:
> And one more: the value of ZV (a.k.a. current_buffer->zv).
I have results from the (presumably optimised) Fedora 21 build and also
from my own build which I finally managed to get to infloop the same
way.
It's not clear to me if GDB prints out the statement it just executed or
the statement that it will execute next, so I looked at the values of
the variables after each step of the loop to be sure I didn't miss
anything.
The variables don't change, and after a few spins through the loop,
I set watchpoints on them and `finish' and there was no sign of them
changing after about five minutes, after which I did a C-c.
For the Fedora 21 build (the variables don't change):
(gdb) p it.current
$11 = {pos = {charpos = 0, bytepos = 0}, overlay_string_index = 0, string_pos = {charpos = 0, bytepos = 0}, dpvec_index = 0}
(gdb) p it.current_y
$12 = 0
(gdb) p it.max_ascent
$13 = 0
(gdb) p it.max_descent
$14 = 0
(gdb) p it.method
$15 = GET_FROM_BUFFER
(gdb) p start_y
No symbol "start_y" in current context.
(gdb) p ZV
No symbol "ZV" in current context.
(gdb) p current_buffer->zv
$27 = 3255
For my build (again the variables don't change):
(gdb) p it.current
$20 = {pos = {charpos = 2840, bytepos = 2841}, overlay_string_index = -1, string_pos = {charpos = -1, bytepos = -1}, dpvec_index = -1}
(gdb) p it.current_y
$21 = 270
(gdb) p it.ascent
$22 = 11
(gdb) p it.descent
$23 = 3
(gdb) p it.method
$24 = GET_FROM_BUFFER
(gdb) p start_y
$25 = 270
(gdb) p ZV
$34 = 2840
(gdb) p current_buffer->zv
$35 = 2840
I hope this helps, and I await further instructions should further
debugging be worthwhile.
Thanks.
next prev parent reply other threads:[~2015-06-15 15:42 UTC|newest]
Thread overview: 12+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-06-14 4:15 bug#20808: 24.5; Emacs looping with 100% CPU at line 15287 (?) of xdisp.c N. Jackson
2015-06-14 14:08 ` Eli Zaretskii
2015-06-14 19:16 ` N. Jackson
2015-06-14 19:46 ` Eli Zaretskii
2015-06-15 15:03 ` Eli Zaretskii
2015-06-15 15:42 ` N. Jackson [this message]
2015-06-16 15:03 ` Eli Zaretskii
2015-06-17 1:59 ` N. Jackson
2015-06-17 2:45 ` Eli Zaretskii
2015-06-17 11:30 ` N. Jackson
2015-06-17 17:22 ` Eli Zaretskii
2015-06-17 19:00 ` N. Jackson
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
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=87a8w1uge6.fsf@moondust.localdomain \
--to=nljlistbox2@gmail.com \
--cc=20808@debbugs.gnu.org \
--cc=eliz@gnu.org \
/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 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.