After an evaluation, GNOME has moved from Bugzilla to GitLab. Learn more about GitLab.
No new issues can be reported in GNOME Bugzilla anymore.
To report an issue in a GNOME project, go to GNOME GitLab.
Do not go to GNOME Gitlab for: Bluefish, Doxygen, GnuCash, GStreamer, java-gnome, LDTP, NetworkManager, Tomboy.
Bug 534995 - incessant failures running gtk apps without gnome desktop
incessant failures running gtk apps without gnome desktop
Status: RESOLVED INCOMPLETE
Product: gtk+
Classification: Platform
Component: Backend: X11
2.12.x
Other All
: Normal critical
: ---
Assigned To: gtk-bugs
gtk-bugs
Depends on:
Blocks:
 
 
Reported: 2008-05-26 22:37 UTC by Tom Horsley
Modified: 2014-03-28 13:28 UTC
See Also:
GNOME target: ---
GNOME version: ---



Description Tom Horsley 2008-05-26 22:37:38 UTC
Steps to reproduce:
Virtually every time I run any gtk app over an ssh forwarded connection
to my display which is NOT running gnome desktop (I've got a minimal fvwm
session up), the first time I run the app, it always crashes like so:

The program 'synaptic' received an X Window System error.
This probably reflects a bug in the program.
The error was 'BadAccess (attempt to access private resource denied)'.
  (Details: serial 442 error_code 10 request_code 148 minor_code 5)
  (Note to programmers: normally, X errors are reported asynchronously;
   that is, you will receive the error a while after causing it.
   To debug your program, run it with the --sync command line
   option to change this behavior. You can then get a meaningful
   backtrace from your debugger if you break on the gdk_x_error() function.)

I then run the app a second time, and it works fine.

I have this deep suspicion that the gtk toolkit is expecting something
to be already setup by the gnome desktop environment (what, I have no idea),
and its fallback code does the setup, but can't keep the original app from
crashing. Then when I run it a second time, the setup has been done by the
failed app, and everything works (it is only a theory :-).

Whatever it is only affects gtk apps (no problem running Qt apps, or simple
X11 progs like xlogo and such), and the first gtk app that crashes seems to
fix everything for all subsequent gtk apps.

I file this report in the hope that someone will be curious enough to fix it,
but for the forseeable future, I guess I'll just run all gtk apps twice the
first time.

This behavior spans a vast number of different linux distros. The above message
comes from trying to run synaptic on an ubuntu 8.04 system, but I see similar
behavior with things like gedit on fedora 8 and 9, etc. The common thread in
all cases is a gtk app and a non-gnome session at the other end of the ssh
forwarded connection (using -Y or -X on the ssh command makes no difference).

Stack trace:


Other information:
Comment 1 Matthias Clasen 2008-05-27 03:41:25 UTC
Have you done what the error message asks you to do ?
Comment 2 Tom Horsley 2008-05-27 11:25:31 UTC
I spent quite a while trying to find the ubuntu debuginfo files so I could
try and get a backtrace, but had no luck. I'm gonna try again when I have
time on a fedora box (I may already have one with most of the debuginfo
files already loaded).

In my investigations, however, I discovered a new fact: It doesn't appear
to be merely the first time I run a gtk app over ssh, it is the first time
I run one after booting the remote system. Apparently whatever state changes
is something that happens on the remote system, not on my X server.

This makes reproducing the problem a pain, since I always have to reboot
the remote system to make it happen again (of course, most of them are
virtual Xen machines, but it happens with real remote machines as well).
Comment 3 Tom Horsley 2008-05-27 12:29:52 UTC
Found debuginfo, and a new fact: This only happens when the remote machine
is set to boot a runlevel 3 (no gdm), if it boots runlevel 5 (gdm starts),
then the 1st time aborts don't happen. Here's a similar error from running
gedit on a fedora 8 virtual machine with most of the debuginfo files
loaded so I can get a backtrace.

Gdk-ERROR **: The program 'gedit' received an X Window System error.
This probably reflects a bug in the program.
The error was 'BadAccess (attempt to access private resource denied)'.
  (Details: serial 184 error_code 10 request_code 148 minor_code 5)
  (Note to programmers: normally, X errors are reported asynchronously;
   that is, you will receive the error a while after causing it.
   To debug your program, run it with the --sync command line
   option to change this behavior. You can then get a meaningful
   backtrace from your debugger if you break on the gdk_x_error() function.)
aborting...
Aborted

Running again after a reboot and using gdb this time:

Breakpoint 2, gdk_x_error (display=0x8709600, error=0xbfa71278)
    at gdkmain-x11.c:614
614       if (error->error_code)
(gdb) bt
  • #0 gdk_x_error
    at gdkmain-x11.c line 614
  • #1 bonobo_x_error_handler
    at bonobo-ui-main.c line 58
  • #2 _XError
    at XlibInt.c line 2905
  • #3 process_responses
    at xcb_io.c line 138
  • #4 _XReply
    at xcb_io.c line 368
  • #5 XSync
    at Sync.c line 48
  • #6 _XSyncFunction
    at Synchro.c line 37
  • #7 _XIDHandler
    at xcb_io.c line 275
  • #8 XShmCreatePixmap
    at XShm.c line 435
  • #9 _gdk_x11_image_get_shm_pixmap
    at gdkimage-x11.c line 408
  • #10 get_shm_pixmap_for_image
    at gdkdrawable-x11.c line 1298
  • #11 draw_with_pixmaps
    at gdkdrawable-x11.c line 1362
  • #12 gdk_x11_draw_pixbuf
    at gdkdrawable-x11.c line 1425
  • #13 IA__gdk_draw_pixbuf
    at gdkdraw.c line 768
  • #14 gdk_pixmap_draw_pixbuf
    at gdkpixmap.c line 427
  • #15 IA__gdk_draw_pixbuf
    at gdkdraw.c line 768
  • #16 IA__gdk_pixbuf_render_pixmap_and_mask_for_colormap
    at gdkpixbuf-render.c line 308
  • #17 get_pixmap_and_mask
    at gtkwindow.c line 2957
  • #18 gtk_window_realize_icon
    at gtkwindow.c line 3093
  • #19 gtk_window_realize
    at gtkwindow.c line 4645
  • #20 g_cclosure_marshal_VOID__VOID
    from /lib/libgobject-2.0.so.0
  • #21 ??
    from /lib/libgobject-2.0.so.0
  • #22 g_closure_invoke
    from /lib/libgobject-2.0.so.0
  • #23 ??
    from /lib/libgobject-2.0.so.0
  • #24 g_signal_emit_valist
    from /lib/libgobject-2.0.so.0
  • #25 g_signal_emit
    from /lib/libgobject-2.0.so.0
  • #26 IA__gtk_widget_realize
    at gtkwidget.c line 3256
  • #27 gtk_window_show
    at gtkwindow.c line 4280
  • #28 g_cclosure_marshal_VOID__VOID
    from /lib/libgobject-2.0.so.0
  • #29 ??
    from /lib/libgobject-2.0.so.0
  • #30 g_closure_invoke
    from /lib/libgobject-2.0.so.0
  • #31 ??
    from /lib/libgobject-2.0.so.0
  • #32 g_signal_emit_valist
    from /lib/libgobject-2.0.so.0
  • #33 g_signal_emit
    from /lib/libgobject-2.0.so.0
  • #34 IA__gtk_widget_show
    at gtkwidget.c line 2940
  • #35 main
    at gedit.c line 570

Comment 4 Christian Dywan 2008-07-02 15:03:09 UTC
I can confirm this problem, but haven't investigated yet. One of my virtual machines is an ubuntu with gnome but no xserver or gdm, I run a few apps on it but only on remote X via ssh. The first time I try to run any gtk (gnome) program it aborts with the above error. After trying again everything is fine.
Comment 5 Matthias Clasen 2008-09-07 06:44:27 UTC
Looks like XShmCreatePixmap throws some unexpected errors, instead of returning NULL ?
Comment 6 William Jon McCann 2014-01-22 22:04:56 UTC
This backtrace is quite old. Does anyone have a more recent one with perhaps a simple application like one of the demos?
Comment 7 Javier Jardón (IRC: jjardon) 2014-03-28 13:28:04 UTC
Closing this bug report as no further information has been provided. Please feel free to reopen this bug if you can provide the information asked for.
Thanks!