GNU bug report logs -
#72692
Emacs 31.05 (40eecd594ac) get SIGSEGV on Linux (Linux 6.6.45 Kde Wayland)
Previous Next
Reported by: Eval EXEC <execvy <at> gmail.com>
Date: Sun, 18 Aug 2024 08:31:01 UTC
Severity: normal
Done: Eli Zaretskii <eliz <at> gnu.org>
Bug is archived. No further changes may be made.
Full log
Message #38 received at 72692 <at> debbugs.gnu.org (full text, mbox):
> Date: Sun, 18 Aug 2024 13:44:41 +0000
> From: Pip Cet <pipcet <at> protonmail.com>
> Cc: execvy <at> gmail.com, 72692 <at> debbugs.gnu.org
>
> "Eli Zaretskii" <eliz <at> gnu.org> writes:
>
> >> Cc: 72692 <at> debbugs.gnu.org
> >> Date: Sun, 18 Aug 2024 12:43:06 +0000
> >> From: Pip Cet via "Bug reports for GNU Emacs,
> >> the Swiss army knife of text editors" <bug-gnu-emacs <at> gnu.org>
> >>
> >> Thanks. That has a different fontset, so it looks like a fontset was
> >> prematurely freed while still being referred to by a face. I think the
> >> assumption made in xfaces.c, that it's always safe to free a fontset if
> >> we're freeing the realized ASCII face, is incorrect.
> >
> > Why do you think that? free_realized_face frees a face, so what other
> > face can still use the same fontset, if it's a so-called "ASCII face"?
>
> I was under the impression two faces could share the same fontset. That
> certainly is what my debugging sessions so far indicate. Maybe that's
> the bug?
We are talking about a fontset identified by face->fontset. AFAIU,
face->fontset is only non-negative for so-called "ASCII faces".
> >> I can confirm that we're sometimes leaving a frame's fontset field
> >> invalid by running this code:
> >
> > If face2->ascii_face is equal to face->ascii_face,
>
> Yes, face2->ascii_face == face == face->ascii_face.
>
> > then I see no
> > reason not to free the fontset because of that other face. The
> > comment in dispextern.h says:
> >
> > /* Fontset ID if for this face's fontset. Non-ASCII faces derived
> > from the same ASCII face have the same fontset. */
> > int fontset;
>
> So, indeed, the fontset id is shared between the ASCII face and the
> non-ASCII face. If we free the fontset because the ASCII face is
> unrealized, but the non-ASCII face is not, we hit the bug...
But AFAIK a non-ASCII face is always released together with its ASCII
face, so how can this be a problem? A "non-ASCII face" is basically
the same face as its "ASCII face" counterpart, it just uses a
different font. An example would be some well-known face, like 'bold'
or 'variable-pitch' or 'region' -- when we need to display a non-ASCII
character in this face, and the "ASCII face"s font doesn't support the
character, we internally create a new face that uses the same fontset
as the "ASCII face". This new face basically shadows the "ASCII face"
(and is never exposed to Lisp) and is for every practical purpose an
integral part of that "ASCII face" -- they always go together.
> > And how did you see that a frame's fontset was left invalid here? A
> > frame doesn't have a fontset, AFAIK.
>
> I meant "face", sorry! The non-ASCII face remains in the font cache,
> and its fontset is set to the newly freed fontset's ID, which is likely
> soon to be reused; only if it isn't, we see a crash.
That shouldn't happen, AFAIU, except for very brief periods of time,
since we free the cached faces one by one, see free_realized_faces.
> > I also think it might be unsafe to call 'message' from this place,
> > because 'message' might trigger redisplay. It is better to call
> > message_dolog or add_to_log (and ask the user to look at *Messages*).
>
> It is, thank you! Yes, fprintf or message_dolog would have been better.
fprintf is indeed the safest, but it requires Emacs to be launched
from the shell prompt.
This bug report was last modified 257 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.