GNU bug report logs - #16737
24.3.50; Yank causes hang

Previous Next

Package: emacs;

Reported by: Sujith Manoharan <sujith <at> msujith.org>

Date: Thu, 13 Feb 2014 03:49:02 UTC

Severity: important

Tags: moreinfo, patch

Merged with 17026, 17101, 17172, 19320, 20283

Found in versions 24.3.50, 24.4, 25.0.50

Done: Tassilo Horn <tsdh <at> gnu.org>

Bug is archived. No further changes may be made.

Full log


Message #93 received at 16737 <at> debbugs.gnu.org (full text, mbox):

From: Vincent Bernat <bernat <at> luffy.cx>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: 16737 <at> debbugs.gnu.org, Oleh Krehel <o.krehel <at> tue.nl>
Subject: Re: bug#16737: Timed out waiting for reply from selection owner
Date: Sat, 17 Jan 2015 22:43:21 +0100
 ❦ 17 janvier 2015 20:07 +0200, Eli Zaretskii <eliz <at> gnu.org> :

>> The thing is, I don't know how to get a backtrace - I'm only a novice
>> with GDB.  I was hoping someone would post a sequence of commands to
>> get a proper backtrace for this problem.
>
> During those 5 seconds, attach GDB to the Emacs process:
>
>   $ gdb -p PID
>
> where PID is the numeric process ID of Emacs; you can find that out
> in advance, before you start the reproducing sequence, and prepare the
> above command line, so that all you need to do is hit RET.
>
> Then, when GDB displays its prompt "(gdb)", type this:
>
>   thread apply all bt
>
> This will show a backtrace of every thread in the Emacs process.

I also have the same problem. It happens randomly when I try to paste or
when I try to kill something. Once it happens, it happens often. I
usually restart emacs after cursing it a lot. The backtrace is always
the same:

#0  0x00007fdbf286d009 in __pselect (nfds=nfds <at> entry=27,
 readfds=readfds <at> entry=0x7fff9569f510, writefds=writefds <at> entry=0x0,
 exceptfds=exceptfds <at> entry=0x0, timeout=<optimized out>,
 timeout <at> entry=0x7fff9569faf0, sigmask=sigmask <at> entry=0x0) at
 ../sysdeps/unix/sysv/linux/pselect.c:77
#1  0x00000000005d4ac2 in xg_select (fds_lim=27,
 rfds=rfds <at> entry=0x7fff9569fb10, wfds=wfds <at> entry=0x0,
 efds=efds <at> entry=0x0, timeout=timeout <at> entry=0x7fff9569faf0,
 sigmask=sigmask <at> entry=0x0) at xgselect.c:105
#2  0x0000000000599b66 in wait_reading_process_output
 (time_limit=<optimized out>, nsecs=0, read_kbd=0, do_display=false,
 wait_for_cell=12579542, wait_proc=0x0, just_wait_proc=0) at
 process.c:4606
#3  0x00000000004d2239 in x_get_foreign_selection (selection_symbol=27,
 target_type=12623842, time_stamp=12315698, frame=-1) at xselect.c:1237

When pasting, the source can be either "xsel -i -b" or the browser. So,
I don't think this is related to some advanced paste mode.

I am using:

#+begin_src lisp
(setq x-select-enable-primary t         ; Yank use the primary selection if available
      save-interprogram-paste-before-kill t ; Put clipboard/selection into kill ring
      mouse-1-click-follows-link nil)	; Don't follow links with left click
#+end_src

The use of "save-interprogram-paste-before-kill" should explain why I
get problems when killing too.

I am running Emacs 24.4 from Debian unstable.

Here is the "thread apply all bt" (I have to paste in a frame running in
tty mode to be able to complete this bug report):

(gdb) thread apply all bt

Thread 5 (Thread 0x7fdbebb6d700 (LWP 4358)):
#0  0x00007fdbf286b18d in poll () at ../sysdeps/unix/syscall-template.S:81
#1  0x00007fdbf6d57ee4 in g_main_context_poll (priority=2147483647, n_fds=2, fds=0x7fdbe40008e0, timeout=-1, context=0x13b8c00) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:4076
#2  g_main_context_iterate (context=context <at> entry=0x13b8c00, block=block <at> entry=1, dispatch=dispatch <at> entry=1, self=<optimized out>) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3776
#3  0x00007fdbf6d57ffc in g_main_context_iteration (context=0x13b8c00, may_block=may_block <at> entry=1) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3842
#4  0x00007fdbf6d58039 in glib_worker_main (data=<optimized out>) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:5589
#5  0x00007fdbf6d7e935 in g_thread_proxy (data=0x13b9000) at /tmp/buildd/glib2.0-2.42.1/./glib/gthread.c:764
#6  0x00007fdbf2d550a4 in start_thread (arg=0x7fdbebb6d700) at pthread_create.c:309
#7  0x00007fdbf2873ccd in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111

Thread 4 (Thread 0x7fdbea801700 (LWP 4359)):
#0  0x00007fdbf286b18d in poll () at ../sysdeps/unix/syscall-template.S:81
#1  0x00007fdbf6d57ee4 in g_main_context_poll (priority=2147483647, n_fds=1, fds=0x7fdbdc0010c0, timeout=-1, context=0x18f11d0) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:4076
#2  g_main_context_iterate (context=context <at> entry=0x18f11d0, block=block <at> entry=1, dispatch=dispatch <at> entry=1, self=<optimized out>) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3776
#3  0x00007fdbf6d57ffc in g_main_context_iteration (context=0x18f11d0, may_block=1) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3842
#4  0x00007fdbea80927d in ?? () from /usr/lib/x86_64-linux-gnu/gio/modules/libdconfsettings.so
#5  0x00007fdbf6d7e935 in g_thread_proxy (data=0x1896050) at /tmp/buildd/glib2.0-2.42.1/./glib/gthread.c:764
#6  0x00007fdbf2d550a4 in start_thread (arg=0x7fdbea801700) at pthread_create.c:309
#7  0x00007fdbf2873ccd in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111

Thread 3 (Thread 0x7fdbea000700 (LWP 4360)):
#0  0x00007fdbf286b18d in poll () at ../sysdeps/unix/syscall-template.S:81
#1  0x00007fdbf6d57ee4 in g_main_context_poll (priority=2147483647, n_fds=2, fds=0x7fdbe00010c0, timeout=-1, context=0x7fdbdc00d2d0) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:4076
#2  g_main_context_iterate (context=0x7fdbdc00d2d0, block=block <at> entry=1, dispatch=dispatch <at> entry=1, self=<optimized out>) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3776
#3  0x00007fdbf6d58272 in g_main_loop_run (loop=0x7fdbdc00d1f0) at /tmp/buildd/glib2.0-2.42.1/./glib/gmain.c:3975
#4  0x00007fdbf7349f76 in gdbus_shared_thread_func (user_data=0x7fdbdc00d2a0) at /tmp/buildd/glib2.0-2.42.1/./gio/gdbusprivate.c:273
#5  0x00007fdbf6d7e935 in g_thread_proxy (data=0x1896190) at /tmp/buildd/glib2.0-2.42.1/./glib/gthread.c:764
#6  0x00007fdbf2d550a4 in start_thread (arg=0x7fdbea000700) at pthread_create.c:309
#7  0x00007fdbf2873ccd in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111

Thread 2 (Thread 0x7fdbdb895700 (LWP 31847)):
#0  0x00007fdbf2b46c9e in ?? () from /usr/lib/x86_64-linux-gnu/libgomp.so.1
#1  0x00007fdbf2b446f0 in ?? () from /usr/lib/x86_64-linux-gnu/libgomp.so.1
#2  0x00007fdbf2d550a4 in start_thread (arg=0x7fdbdb895700) at pthread_create.c:309
#3  0x00007fdbf2873ccd in clone () at ../sysdeps/unix/sysv/linux/x86_64/clone.S:111

Thread 1 (Thread 0x7fdbfa101a40 (LWP 4357)):
#0  0x00007fdbf286d009 in __pselect (nfds=nfds <at> entry=27, readfds=readfds <at> entry=0x7fff9569f510, writefds=writefds <at> entry=0x0, exceptfds=exceptfds <at> entry=0x0, timeout=<optimized out>, timeout <at> entry=0x7fff9569faf0, sigmask=sigmask <at> entry=0x0) at ../sysdeps/unix/sysv/linux/pselect.c:77
#1  0x00000000005d4ac2 in xg_select (fds_lim=27, rfds=rfds <at> entry=0x7fff9569fb10, wfds=wfds <at> entry=0x0, efds=efds <at> entry=0x0, timeout=timeout <at> entry=0x7fff9569faf0, sigmask=sigmask <at> entry=0x0) at xgselect.c:105
#2  0x0000000000599b66 in wait_reading_process_output (time_limit=<optimized out>, nsecs=0, read_kbd=0, do_display=false, wait_for_cell=12579542, wait_proc=0x0, just_wait_proc=0) at process.c:4606
#3  0x00000000004d2239 in x_get_foreign_selection (selection_symbol=27, target_type=12623842, time_stamp=12315698, frame=-1) at xselect.c:1237
#4  0x000000000055c7fa in Ffuncall (nargs=<optimized out>, args=args <at> entry=0x7fff9569fe68) at eval.c:2823
#5  0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=10040525, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=0, args=<optimized out>, args <at> entry=0x0) at bytecode.c:916
#6  0x000000000055c2cf in funcall_lambda (fun=10040397, nargs=nargs <at> entry=2, arg_vector=arg_vector <at> entry=0x7fff956a0040) at eval.c:3045
#7  0x000000000055c643 in Ffuncall (nargs=3, args=args <at> entry=0x7fff956a0038) at eval.c:2873
#8  0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=10432997, maxdepth=<optimized out>, args_template=<optimized out>, nargs=<optimized out>, args=<optimized out>) at bytecode.c:916
#9  0x000000000055bc0b in eval_sub (form=form <at> entry=10432918) at eval.c:2188
#10 0x000000000055eac1 in internal_lisp_condition_case (var=<optimized out>, bodyform=10432918, handlers=<optimized out>) at eval.c:1317
#11 0x0000000000592e57 in exec_byte_code (bytestr=<optimized out>, vector=10432781, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=0, args=<optimized out>, args <at> entry=0x0) at bytecode.c:1162
#12 0x000000000055c2cf in funcall_lambda (fun=10432709, nargs=nargs <at> entry=1, arg_vector=arg_vector <at> entry=0x7fff956a0440) at eval.c:3045
#13 0x000000000055c643 in Ffuncall (nargs=2, args=args <at> entry=0x7fff956a0438) at eval.c:2873
#14 0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=10433253, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=0, args=<optimized out>, args <at> entry=0x0) at bytecode.c:916
#15 0x000000000055c2cf in funcall_lambda (fun=10433181, nargs=nargs <at> entry=0, arg_vector=arg_vector <at> entry=0x7fff956a0600) at eval.c:3045
#16 0x000000000055c643 in Ffuncall (nargs=1, args=args <at> entry=0x7fff956a05f8) at eval.c:2873
#17 0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=9638461, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=2, args=<optimized out>, args <at> entry=0x931219 <pure+939865>) at bytecode.c:916
#18 0x000000000055c367 in funcall_lambda (fun=140735700142032, nargs=nargs <at> entry=2, arg_vector=0x931219 <pure+939865>, arg_vector <at> entry=0x7fff956a0768) at eval.c:2979
#19 0x000000000055c643 in Ffuncall (nargs=3, args=args <at> entry=0x7fff956a0760) at eval.c:2873
#20 0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=85013877, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=0, args=<optimized out>, args <at> entry=0x9316e1 <pure+941089>) at bytecode.c:916
#21 0x000000000055c367 in funcall_lambda (fun=140735700142816, nargs=nargs <at> entry=0, arg_vector=0x9316e1 <pure+941089>, arg_vector <at> entry=0x7fff956a08a8) at eval.c:2979
#22 0x000000000055c643 in Ffuncall (nargs=1, args=0x7fff956a08a0) at eval.c:2873
#23 0x000000000055bdf4 in eval_sub (form=form <at> entry=187158758) at eval.c:2155
#24 0x000000000055eac1 in internal_lisp_condition_case (var=<optimized out>, bodyform=187158758, handlers=<optimized out>) at eval.c:1317
#25 0x0000000000592e57 in exec_byte_code (bytestr=<optimized out>, vector=9639509, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=3, args=<optimized out>, args <at> entry=0x931631 <pure+940913>) at bytecode.c:1162
#26 0x000000000055c367 in funcall_lambda (fun=140735700143792, nargs=nargs <at> entry=3, arg_vector=0x931631 <pure+940913>, arg_vector <at> entry=0x7fff956a0bb8) at eval.c:2979
#27 0x000000000055c643 in Ffuncall (nargs=nargs <at> entry=4, args=args <at> entry=0x7fff956a0bb0) at eval.c:2873
#28 0x000000000055d574 in Fapply (nargs=nargs <at> entry=2, args=args <at> entry=0x7fff956a0c70) at eval.c:2351
#29 0x000000000055d7e0 in apply1 (fn=fn <at> entry=15660018, arg=arg <at> entry=187158790) at eval.c:2585
#30 0x0000000000558521 in Fcall_interactively (function=15660018, record_flag=12315698, keys=12350653) at callint.c:378
#31 0x000000000055c80d in Ffuncall (nargs=<optimized out>, args=args <at> entry=0x7fff956a0e28) at eval.c:2819
#32 0x0000000000591b13 in exec_byte_code (bytestr=<optimized out>, vector=9616805, maxdepth=<optimized out>, args_template=<optimized out>, nargs=nargs <at> entry=1, args=<optimized out>, args <at> entry=0x92bd81 <pure+918209>) at bytecode.c:916
#33 0x000000000055c367 in funcall_lambda (fun=0, nargs=nargs <at> entry=1, arg_vector=0x92bd81 <pure+918209>, arg_vector <at> entry=0x7fff956a0f88) at eval.c:2979
#34 0x000000000055c643 in Ffuncall (nargs=nargs <at> entry=2, args=args <at> entry=0x7fff956a0f80) at eval.c:2873
#35 0x000000000055cafa in call1 (fn=<optimized out>, arg1=<optimized out>) at eval.c:2611
#36 0x00000000004f80cd in command_loop_1 () at keyboard.c:1559
#37 0x000000000055ab07 in internal_condition_case (bfun=bfun <at> entry=0x4f7d30 <command_loop_1>, handlers=<optimized out>, hfun=hfun <at> entry=0x4eee40 <cmd_error>) at eval.c:1348
#38 0x00000000004ea43e in command_loop_2 (ignore=ignore <at> entry=12315698) at keyboard.c:1177
#39 0x000000000055a9eb in internal_catch (tag=12363170, func=func <at> entry=0x4ea420 <command_loop_2>, arg=12315698) at eval.c:1112
#40 0x00000000004eea57 in command_loop () at keyboard.c:1156
#41 recursive_edit_1 () at keyboard.c:777
#42 0x00000000004eed70 in Frecursive_edit () at keyboard.c:848
#43 0x0000000000418579 in main (argc=0, argv=0x7fff956a1348) at emacs.c:1646
-- 
Make sure input cannot violate the limits of the program.
            - The Elements of Programming Style (Kernighan & Plauger)




This bug report was last modified 9 years and 244 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.