Summary: | konqueror with tab crashes when klipper is running | ||
---|---|---|---|
Product: | [Applications] konqueror | Reporter: | Jacob <waif> |
Component: | general | Assignee: | Konqueror Developers <konq-bugs> |
Status: | RESOLVED DUPLICATE | ||
Severity: | crash | CC: | richard |
Priority: | NOR | ||
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | Gentoo Packages | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: |
Description
Jacob
2003-11-12 07:25:02 UTC
Not much luck with the backtracking; I'm open to suggestions in that area. First some more notes: I forgot to mention, the "system tray" where the klipper icon lives is disabled on my panel; not sure if this matters. Clicking on the pager doesn't seem to trigger the bug, even though clicking on the appropriate task in the task bar does. At any rate, I rebuilt without Gentoo patches and with -g. Apparantly it's an exit, so no quick way to get a backtrace; I imagine this is also why I'm not getting the crash handler. I stepped the best I could and backtraced some. After setting up the window with tabs, one of the steps triggered the bug. zork:/root/build/kdebase-3.1.4/konqueror% gdb ./.libs/konqueror GNU gdb 5.3 Copyright 2002 Free Software Foundation, Inc. GDB is free software, covered by the GNU General Public License, and you are welcome to change it and/or distribute copies of it under certain conditions. Type "show copying" to see the conditions. There is absolutely no warranty for GDB. Type "show warranty" for details. This GDB was configured as "i686-pc-linux-gnu"... (gdb) break main Breakpoint 1 at 0x8048520 (gdb) run /www/start/index.html Starting program: /root/build/kdebase-3.1.4/konqueror/.libs/konqueror /www/start/index.html Breakpoint 1 at 0x400531a5 [New Thread 16384 (LWP 28271)] [Switching to Thread 16384 (LWP 28271)] Breakpoint 1, 0x400531a5 in main () from /usr/kde/3.1/lib/konqueror.so (gdb) s Single stepping until exit from function main, which has no line number information. libGL error: InitDriver failed Program received signal SIGINT, Interrupt. 0x41344632 in select () from /lib/libc.so.6 (gdb) step Single stepping until exit from function select, which has no line number information. Program received signal SIGINT, Interrupt. 0x41344632 in select () from /lib/libc.so.6 (gdb) bt #0 0x41344632 in select () from /lib/libc.so.6 #1 0x40fde034 in __JCR_LIST__ () from /usr/qt/3/lib/libqt-mt.so.3 #2 0x40b54046 in QEventLoop::enterLoop() () from /usr/qt/3/lib/libqt-mt.so.3 #3 0x40b53ee8 in QEventLoop::exec() () from /usr/qt/3/lib/libqt-mt.so.3 #4 0x40b410d1 in QApplication::exec() () from /usr/qt/3/lib/libqt-mt.so.3 #5 0x400535b7 in main () from /usr/kde/3.1/lib/konqueror.so #6 0x412897a7 in __libc_start_main () from /lib/libc.so.6 (gdb) step Single stepping until exit from function select, which has no line number information. 0x40aee1bf in QEventLoop::processEvents(unsigned) () from /usr/qt/3/lib/libqt-mt.so.3 (gdb) step Single stepping until exit from function _ZN10QEventLoop13processEventsEj, which has no line number information. 0x40b54046 in QEventLoop::enterLoop() () from /usr/qt/3/lib/libqt-mt.so.3 (gdb) step Single stepping until exit from function _ZN10QEventLoop9enterLoopEv, which has no line number information. Program received signal SIGINT, Interrupt. 0x41344632 in select () from /lib/libc.so.6 (gdb) bt #0 0x41344632 in select () from /lib/libc.so.6 #1 0x40fde034 in __JCR_LIST__ () from /usr/qt/3/lib/libqt-mt.so.3 #2 0x40b54046 in QEventLoop::enterLoop() () from /usr/qt/3/lib/libqt-mt.so.3 #3 0x40b53ee8 in QEventLoop::exec() () from /usr/qt/3/lib/libqt-mt.so.3 #4 0x40b410d1 in QApplication::exec() () from /usr/qt/3/lib/libqt-mt.so.3 #5 0x400535b7 in main () from /usr/kde/3.1/lib/konqueror.so #6 0x412897a7 in __libc_start_main () from /lib/libc.so.6 (gdb) step Single stepping until exit from function select, which has no line number information. 0x40aee1bf in QEventLoop::processEvents(unsigned) () from /usr/qt/3/lib/libqt-mt.so.3 (gdb) step Single stepping until exit from function _ZN10QEventLoop13processEventsEj, which has no line number information. 0x40b54046 in QEventLoop::enterLoop() () from /usr/qt/3/lib/libqt-mt.so.3 (gdb) step Single stepping until exit from function _ZN10QEventLoop9enterLoopEv, which has no line number information. QClipboard: internal error, qt_xclb_wait_for_event recursed zone still contained 137 blocks Program exited with code 01. (gdb) bt No stack. One more note. I did some more testing, and found that my initial description (2. in the report) is inaccurate. I think 2. and 3. can be combined as: Change focus from an application in desktop A to a konqueror window with tabs in desktop B, where A does not equal B. So not all konq windows need to have tabs, just the one you're switching to. This works even if you alt-tab from a konq window with no tabs to another konq window with tabs, provided they are on different desktops. I'm willing to experiment more if someone gives me some direction, but for now I think I'll just avoid the bug (by not running klipper). I'm running KDE 3.1.93 from Gentoo packages, and just had a similar crash (SIGABRT) when starting a new instance of konqueror: Using host libthread_db library "/lib/libthread_db.so.1". [Thread debugging using libthread_db enabled] [New Thread 16384 (LWP 27708)] 0x4124e768 in waitpid () from /lib/libpthread.so.0 #0 0x4124e768 in waitpid () from /lib/libpthread.so.0 #1 0x4086d150 in __JCR_LIST__ () from /usr/kde/3.2/lib/libkdecore.so.4 #2 0x407b2feb in KCrash::defaultCrashHandler(int) (sig=6) at kcrash.cpp:246 #3 0x4124d453 in __pthread_sighandler () from /lib/libpthread.so.0 #4 <signal handler called> #5 0x413b8ff1 in kill () from /lib/libc.so.6 #6 0x4124aa60 in pthread_kill () from /lib/libpthread.so.0 #7 0x4124ad5b in raise () from /lib/libpthread.so.0 #8 0x413b8da2 in raise () from /lib/libc.so.6 #9 0x413ba35c in abort () from /lib/libc.so.6 #10 0x40f792ef in qFatal(char const*, ...) ( msg=0x410525a0 "QClipboard: internal error, qt_xclb_wait_for_event recursed") at tools/qglobal.cpp:559 #11 0x40b59437 in qt_xclb_wait_for_event(_XDisplay*, unsigned long, int, _XEvent*, int) (dpy=0x8068d58, win=75497740, type=31, event=0xbfffd7e0, timeout=5000) at kernel/qclipboard_x11.cpp:454 #12 0x40b5c52b in QClipboardWatcher::getDataInFormat(unsigned long) const ( this=0x830a0a0, fmtatom=360) at kernel/qclipboard_x11.cpp:1381 #13 0x40b5ba7c in QClipboardWatcher::format(int) const (this=0x830a0a0, n=0) at kernel/qclipboard_x11.cpp:1249 #14 0x40c2be6c in QMimeSource::provides(char const*) const (this=0x830a0a0, mimeType=0x41c4b8f2 "text/plain") at kernel/qmime.cpp:134 #15 0x41c2c649 in KonqMainWindow::slotClipboardDataChanged() (this=0x81255d0) at konq_mainwindow.cc:2967 #16 0x41c2c4ea in KonqMainWindow::eventFilter(QObject*, QEvent*) ( this=0x81255d0, obj=0x81fd260, ev=0xbfffde20) at konq_mainwindow.cc:2908 #17 0x40c3a9da in QObject::activate_filters(QEvent*) (this=0x81fd260, e=0xbfffde20) at kernel/qobject.cpp:902 #18 0x40c3a857 in QObject::event(QEvent*) (this=0x81fd260, e=0xbfffde20) at kernel/qobject.cpp:735 #19 0x40c7f6d3 in QWidget::event(QEvent*) (this=0x81fd260, e=0xbfffde20) at kernel/qwidget.cpp:4408 #20 0x40d28518 in QLineEdit::event(QEvent*) (this=0x81fd260, e=0xbfffde20) at widgets/qlineedit.cpp:1406 #21 0x40bcd1f7 in QApplication::internalNotify(QObject*, QEvent*) ( this=0xbffff040, receiver=0x81fd260, e=0xbfffde20) at kernel/qapplication.cpp:2582 #22 0x40bcce69 in QApplication::notify(QObject*, QEvent*) (this=0xbffff040, receiver=0x81fd260, e=0xbfffde20) at kernel/qapplication.cpp:2470 #23 0x4072565e in KApplication::notify(QObject*, QEvent*) (this=0xbffff040, receiver=0x81fd260, event=0xbffff040) at kapplication.cpp:509 #24 0x40047696 in QApplication::sendEvent(QObject*, QEvent*) (receiver=0x0, event=0x6) at qapplication.h:490 #25 0x40c7cc20 in QWidget::setFocus() (this=0x81fd260) at kernel/qwidget.cpp:3099 #26 0x40bcec07 in QApplication::setActiveWindow(QWidget*) (this=0xbffff040, act=0x81255d0) at kernel/qapplication.cpp:3463 #27 0x40b4c9aa in QApplication::x11ProcessEvent(_XEvent*) (this=0xbffff040, event=0xbfffe1e0) at kernel/qapplication_x11.cpp:3669 #28 0x40b69801 in QEventLoop::processEvents(unsigned) (this=0x80d8f60, flags=15) at kernel/qeventloop_x11.cpp:192 #29 0x40b59507 in qt_xclb_wait_for_event(_XDisplay*, unsigned long, int, _XEvent*, int) (dpy=0x8068d58, win=75497740, type=31, event=0xbfffe300, timeout=5000) at kernel/qclipboard_x11.cpp:479 #30 0x40b5c52b in QClipboardWatcher::getDataInFormat(unsigned long) const ( this=0x830a0a0, fmtatom=360) at kernel/qclipboard_x11.cpp:1381 #31 0x40b5ba7c in QClipboardWatcher::format(int) const (this=0x830a0a0, n=0) at kernel/qclipboard_x11.cpp:1249 #32 0x40c2be6c in QMimeSource::provides(char const*) const (this=0x830a0a0, mimeType=0x41c4b8f2 "text/plain") at kernel/qmime.cpp:134 #33 0x41c2c649 in KonqMainWindow::slotClipboardDataChanged() (this=0x81255d0) at konq_mainwindow.cc:2967 #34 0x41c2c4ea in KonqMainWindow::eventFilter(QObject*, QEvent*) ( this=0x81255d0, obj=0x81fd260, ev=0xbfffe940) at konq_mainwindow.cc:2908 #35 0x40c3a9da in QObject::activate_filters(QEvent*) (this=0x81fd260, e=0xbfffe940) at kernel/qobject.cpp:902 #36 0x40c3a857 in QObject::event(QEvent*) (this=0x81fd260, e=0xbfffe940) at kernel/qobject.cpp:735 #37 0x40c7f6d3 in QWidget::event(QEvent*) (this=0x81fd260, e=0xbfffe940) at kernel/qwidget.cpp:4408 #38 0x40d28518 in QLineEdit::event(QEvent*) (this=0x81fd260, e=0xbfffe940) at widgets/qlineedit.cpp:1406 #39 0x40bcd1f7 in QApplication::internalNotify(QObject*, QEvent*) ( this=0xbffff040, receiver=0x81fd260, e=0xbfffe940) at kernel/qapplication.cpp:2582 #40 0x40bcce69 in QApplication::notify(QObject*, QEvent*) (this=0xbffff040, receiver=0x81fd260, e=0xbfffe940) at kernel/qapplication.cpp:2470 #41 0x4072565e in KApplication::notify(QObject*, QEvent*) (this=0xbffff040, receiver=0x81fd260, event=0xbffff040) at kapplication.cpp:509 #42 0x40047696 in QApplication::sendEvent(QObject*, QEvent*) (receiver=0x0, event=0x6) at qapplication.h:490 #43 0x40c7cc20 in QWidget::setFocus() (this=0x81fd260) at kernel/qwidget.cpp:3099 #44 0x40bcec07 in QApplication::setActiveWindow(QWidget*) (this=0xbffff040, act=0x81255d0) at kernel/qapplication.cpp:3463 #45 0x40b4c9aa in QApplication::x11ProcessEvent(_XEvent*) (this=0xbffff040, event=0xbfffed00) at kernel/qapplication_x11.cpp:3669 #46 0x40b69801 in QEventLoop::processEvents(unsigned) (this=0x80d8f60, flags=4) at kernel/qeventloop_x11.cpp:192 #47 0x40be6651 in QEventLoop::enterLoop() (this=0x80d8f60) at kernel/qeventloop.cpp:198 #48 0x40be656a in QEventLoop::exec() (this=0x80d8f60) at kernel/qeventloop.cpp:145 #49 0x40bcd399 in QApplication::exec() (this=0xbffff040) at kernel/qapplication.cpp:2705 #50 0x41be0043 in kdemain (argc=0, argv=0x0) at konq_main.cc:162 #51 0x408b1916 in kdeinitmain (argc=0, argv=0x0) at konqueror_dummy.cc:2 #52 0x0804e1b2 in launch (argc=2, _name=0x806095c "konqueror", args=0x805fb70 "\\\t\006\b", cwd=0x0, envc=1, envs=0x8060980 "", reset_env=false, tty=0x0, avoid_loops=false, startup_id_str=0x0) at kinit.cpp:597 #53 0x08050326 in handle_launcher_request (sock=7) at kinit.cpp:1094 #54 0x0804f1fb in handle_requests (waitForPid=0) at kinit.cpp:1265 #55 0x0804d537 in main (argc=3, argv=0xbffff704, envp=0x0) at kinit.cpp:1686 This happened while I was running another instance under valgrind, so system load may have something to do with it. |