From: Ali Bahrami <ali_gnu2@emvision.com>
To: Po Lu <luangruo@yahoo.com>
Cc: 69762@debbugs.gnu.org
Subject: bug#69762: X11 versions of Emacs 29 on sparc fail at startup
Date: Fri, 15 Mar 2024 22:58:44 -0600 [thread overview]
Message-ID: <344699e3-8dad-4cde-adcd-35ebec4900e7@emvision.com> (raw)
In-Reply-To: <871q8bt4au.fsf@yahoo.com>
On 3/15/24 6:21 PM, Po Lu wrote:
> Ali Bahrami <ali_gnu2@emvision.com> writes:
>
>> Standing by for the next iteration. Thank you!
>>
>> - Ali
>
> How about this? Thanks.
>
> diff --git a/src/xterm.c b/src/xterm.c
> index c8a43785564..c4cd9386270 100644
> --- a/src/xterm.c
> +++ b/src/xterm.c
> @@ -7297,11 +7297,11 @@ x_sync_init_fences (struct frame *f)
> /* The drawable given below is only used to
> determine the screen on which the fence is
> created. */
> - FRAME_X_WINDOW (f),
> + dpyinfo->root_window,
> False);
> output->sync_fences[1]
> = XSyncCreateFence (FRAME_X_DISPLAY (f),
> - FRAME_X_WINDOW (f),
> + dpyinfo->root_window,
> False);
>
> XChangeProperty (FRAME_X_DISPLAY (f), FRAME_OUTER_WINDOW (f),
I'm afraid that it still fails with the same error:
% src/emacs
X protocol error: BadDrawable (invalid Pixmap or Window parameter) on protocol request 134
Serial no: 1318
Failing resource ID (if any): 0x43020000
Minor code: 14
This is a bug! Please report this to bug-gnu-emacs@gnu.org!
-----
The following isn't a fix, but I've come up with
a workaround.
I was looking at the code for x_sync_init_fences() that
we've been doing these experiments on. I noticed that
that this code is not always used:
/* Sync fences aren't supported by the X server. */
if (dpyinfo->xsync_major < 3
|| (dpyinfo->xsync_major == 3
&& dpyinfo->xsync_minor < 1))
return;
Hence, the sync fence support is optional, and emacs is
willing to run without it.
It's also only compiled in when built on systems that know
the extension, guarded by a '#ifdef HAVE_XSYNCTRIGGERFENCE'.
And lastly, it's only called for non-GTK X11, which essentially
means, only for Lucid:
xfns.c
#if defined HAVE_XSYNCTRIGGERFENCE && !defined USE_GTK \
&& defined HAVE_CLOCK_GETTIME
x_sync_init_fences (f);
#endif
So this works on Solaris 10 sparc, because those
old X11 bits lack the sync fence extension. And it
"works" on current Solaris GTK, because it's not used.
Hence, the workaround, which is to put this at the top
of x_sync_init_fences():
/* This feature does not work properly on sparc */
#ifdef __sparc
return;
#endif
With that in place, Lucid emacs starts, and runs normally.
This is clearly not a proper fix, but it is an effective
workaround, and presumably, no worse that using emacs 28.2,
which completely lacks sync fence support.
I wonder if we might be looking at a problem with the
sync fence extension on sparc?
Although I now have usable way around the issue, I'm willing
to continue with any experiments you want to try. Let me
know...
Thanks!
- Ali
next prev parent reply other threads:[~2024-03-16 4:58 UTC|newest]
Thread overview: 26+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-03-12 17:57 bug#69762: X11 versions of Emacs 29 on sparc fail at startup ali_gnu2
2024-03-13 0:34 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-13 17:02 ` ali_gnu2
2024-03-14 0:17 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-14 5:56 ` Ali Bahrami
2024-03-14 6:16 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-15 1:48 ` Ali Bahrami
2024-03-15 2:46 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-15 4:22 ` Ali Bahrami
2024-03-15 6:42 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-15 16:37 ` Ali Bahrami
2024-03-16 0:21 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-16 4:58 ` Ali Bahrami [this message]
2024-03-16 6:28 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-16 6:32 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-17 1:13 ` Ali Bahrami
2024-03-16 11:14 ` Eli Zaretskii
2024-03-16 12:24 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-17 1:38 ` ali_gnu2
2024-03-17 11:54 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-03-23 17:00 ` Alan Coopersmith
2024-04-03 17:48 ` Alan Coopersmith via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-06 10:34 ` Eli Zaretskii
2024-04-06 11:07 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-06 16:36 ` ali_gnu2
2024-04-07 0:53 ` Po Lu via Bug reports for GNU Emacs, the Swiss army knife of text editors
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=344699e3-8dad-4cde-adcd-35ebec4900e7@emvision.com \
--to=ali_gnu2@emvision.com \
--cc=69762@debbugs.gnu.org \
--cc=luangruo@yahoo.com \
/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.