Summary: | segfault(s) in nepomukfilewatcher.so at each login | ||
---|---|---|---|
Product: | [Unmaintained] nepomuk | Reporter: | Andreas Sturmlechner <asturm> |
Component: | filewatch | Assignee: | Nepomuk Bugs Coordination <nepomuk-bugs> |
Status: | RESOLVED DUPLICATE | ||
Severity: | crash | CC: | ht990332, johu, kde180133, l33tmmx, me, stupor_scurvy343 |
Priority: | NOR | ||
Version: | 4.9 | ||
Target Milestone: | --- | ||
Platform: | Gentoo Packages | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: |
nepomuk-backtrace.log
nepomuk-backtrace.log |
Description
Andreas Sturmlechner
2012-09-10 21:53:34 UTC
OK, logoff and then logon to a different user profile triggers this: [ 8856.459257] nepomukserver[2840]: segfault at 50 ip 00007f092f69e634 sp 00007fff9fd55550 error 4 in libkdeinit4_nepomukserver.so[7f092f696000+15000] However, login just to the other user profile right after start does not trigger it. So it seems to be some nepomuk storage corruption again after all, solution - delete some files? Interesting. I have never heard of this before. Could you please manually run the filewatch service in a debugger, and then provide a backtrace $ gdb --args nepomukservicestub nepomukfilewatch .. .. bt should do the trick I'm expecting the same messages in dmesg and want to provide a backtrace: $ gdb --args nepomukservicestub nepomukfilewatch GNU gdb (GDB) 7.3.1 Copyright (C) 2011 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Type "show copying" and "show warranty" for details. This GDB was configured as "x86_64-unknown-linux-gnu". For bug reporting instructions, please see: <http://www.gnu.org/software/gdb/bugs/>... Reading symbols from /usr/bin/nepomukservicestub...Reading symbols from /usr/lib/debug/usr/bin/nepomukservicestub.debug...done. done. (gdb) run Starting program: /usr/bin/nepomukservicestub nepomukfilewatch [Thread debugging using libthread_db enabled] [New Thread 0x7fffeba0f700 (LWP 3228)] "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" [New Thread 0x7fffeb20e700 (LWP 3229)] [New Thread 0x7fffeaa0d700 (LWP 3230)] QObject: Cannot create children for a parent that is in a different thread. (Parent is Soprano::Client::LocalSocketClient(0x83fd00), parent's thread is QThread(0x609320), current thread is Nepomuk2::InvalidFileResourceCleaner(0x8b6b00) "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" "/usr/bin/nepomukservicestub(3225)" Soprano: "Could not connect to server at /tmp/ksocket-jo/nepomuk-socket (No such file or directory)" "/usr/bin/nepomukservicestub(3225)" Soprano: "Unsupported operation (2)": "Invalid model" "/usr/bin/nepomukservicestub(3225)" Soprano: "Unsupported operation (2)": "Invalid model" "/usr/bin/nepomukservicestub(3225)" Soprano: "Invalid iterator." [Thread 0x7fffeaa0d700 (LWP 3230) exited] Program received signal SIGSEGV, Segmentation fault. 0x00007fffebc314a4 in isEmpty (this=0x841948) at /usr/include/QtCore/qlist.h:99 99 inline bool isEmpty() const { return d->end == d->begin; } (gdb) bt #0 0x00007fffebc314a4 in isEmpty (this=0x841948) at /usr/include/QtCore/qlist.h:99 #1 isEmpty (this=0x841948) at /usr/include/QtCore/qlist.h:152 #2 KInotify::Private::_k_addWatches (this=0x841930) at /chakra/desktop-testing/nepomuk-core/src/nepomuk-core-4.9.1/services/filewatch/kinotify.cpp:147 #3 0x00007fffebc2fa79 in qt_static_metacall (_a=<optimized out>, _id=<optimized out>, _o=<optimized out>, _c=<optimized out>) at /chakra/desktop-testing/nepomuk-core/src/nepomuk-core-4.9.1/build/services/filewatch/kinotify.moc:96 #4 KInotify::qt_static_metacall (_o=0x1, _c=11242288, _id=-170752511, _a=0xab5510) at /chakra/desktop-testing/nepomuk-core/src/nepomuk-core-4.9.1/build/services/filewatch/kinotify.moc:72 #5 0x00007ffff7a986ae in QObject::event(QEvent*) () from /usr/lib/libQtCore.so.4 #6 0x00007ffff61f6b4c in QApplicationPrivate::notify_helper(QObject*, QEvent*) () from /usr/lib/libQtGui.so.4 #7 0x00007ffff61fafca in QApplication::notify(QObject*, QEvent*) () from /usr/lib/libQtGui.so.4 #8 0x00007ffff7a83dce in QCoreApplication::notifyInternal(QObject*, QEvent*) () from /usr/lib/libQtCore.so.4 #9 0x00007ffff7a87731 in QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) () from /usr/lib/libQtCore.so.4 #10 0x00007ffff7ab1d43 in ?? () from /usr/lib/libQtCore.so.4 #11 0x00007ffff5094655 in g_main_context_dispatch () from /usr/lib/libglib-2.0.so.0 #12 0x00007ffff5094988 in ?? () from /usr/lib/libglib-2.0.so.0 #13 0x00007ffff5094a44 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0 #14 0x00007ffff7ab1ed6 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4 #15 0x00007ffff629666e in ?? () from /usr/lib/libQtGui.so.4 #16 0x00007ffff7a82b1f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4 #17 0x00007ffff7a82da8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4 #18 0x00007ffff7a87a48 in QCoreApplication::exec() () from /usr/lib/libQtCore.so.4 #19 0x0000000000403c50 in main (argc=2, argv=<optimized out>) at /chakra/desktop-testing/nepomuk-core/src/nepomuk-core-4.9.1/servicestub/main.cpp:170 (gdb) *** Bug 306796 has been marked as a duplicate of this bug. *** Happens to me on Archlinux's 4.9.1 packages. this seems to be a regression from 4.9.0 Created attachment 73947 [details]
nepomuk-backtrace.log
I've rebuilt nepomuk{-core} with minimum optimisations and debug symbols and now here is my backtrace. I can rebuild more packages with debug symbols if really needed, but this is a laptop with several years on its shoulders. ;)
Created attachment 73952 [details]
nepomuk-backtrace.log
more info with added soprano debug symbols
I'm getting this nepomukfilewatcher segfault too: nepomukservices[3021]: segfault at c ip 00007f83405c3cf8 sp 00007fff048151c0 error 4 in nepomukfilewatch.so[7f83405ad000+1e000] It always segfauts within 2 minutes after login. I first noticed this on 4.9.0; I'm using Gentoo packages, too - will try to produce a backtrace later. Here's gdb output of my system (Gentoo 64-bit), hopefully it proves to be useful: madmax@wintermute ~ $ gdb --args nepomukservicestub nepomukfilewatch GNU gdb (Gentoo 7.5 p1) 7.5 Copyright (C) 2012 Free Software Foundation, Inc. License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html> This is free software: you are free to change and redistribute it. There is NO WARRANTY, to the extent permitted by law. Type "show copying" and "show warranty" for details. This GDB was configured as "x86_64-pc-linux-gnu". For bug reporting instructions, please see: <http://bugs.gentoo.org/>... Reading symbols from /usr/bin/nepomukservicestub...Reading symbols from /usr/lib64/debug/usr/bin/nepomukservicestub.debug...done. done. (gdb) run Starting program: /usr/bin/nepomukservicestub nepomukfilewatch warning: Could not load shared library symbols for linux-vdso.so.1. Do you need "set solib-search-path" or "set sysroot"? [Thread debugging using libthread_db enabled] Using host libthread_db library "/lib64/libthread_db.so.1". [New Thread 0x7fffe7f2c700 (LWP 30523)] [New Thread 0x7fffe772b700 (LWP 30525)] [New Thread 0x7fffe6f2a700 (LWP 30526)] [New Thread 0x7fffe6729700 (LWP 30527)] [Thread 0x7fffe6f2a700 (LWP 30526) exited] Program received signal SIGSEGV, Segmentation fault. 0x00007fffe8198cf8 in isEmpty (this=0x7e8438) at /usr/include/qt4/QtCore/qlist.h:99 99 inline bool isEmpty() const { return d->end == d->begin; } (gdb) bt #0 0x00007fffe8198cf8 in isEmpty (this=0x7e8438) at /usr/include/qt4/QtCore/qlist.h:99 #1 isEmpty (this=0x7e8438) at /usr/include/qt4/QtCore/qlist.h:152 #2 KInotify::Private::_k_addWatches (this=0x7e8420) at /var/tmp/portage/kde-base/nepomuk-core-4.9.1/work/nepomuk-core-4.9.1/services/filewatch/kinotify.cpp:147 #3 0x00007fffe8197bd8 in KInotify::qt_static_metacall (_o=<optimized out>, _c=<optimized out>, _id=<optimized out>, _a=0xafb740) at /var/tmp/portage/kde-base/nepomuk-core-4.9.1/work/nepomuk-core-4.9.1_build/services/filewatch/kinotify.moc:96 #4 0x00007ffff7a929ad in QObject::event(QEvent*) () from /usr/lib64/qt4/libQtCore.so.4 #5 0x00007ffff61ef59c in QApplicationPrivate::notify_helper(QObject*, QEvent*) () from /usr/lib64/qt4/libQtGui.so.4 #6 0x00007ffff61f3bc1 in QApplication::notify(QObject*, QEvent*) () from /usr/lib64/qt4/libQtGui.so.4 #7 0x00007ffff7a7fdc8 in QCoreApplication::notifyInternal(QObject*, QEvent*) () from /usr/lib64/qt4/libQtCore.so.4 #8 0x00007ffff7a82c75 in QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) () from /usr/lib64/qt4/libQtCore.so.4 #9 0x00007ffff7aaaa48 in ?? () from /usr/lib64/qt4/libQtCore.so.4 #10 0x00007ffff549caae in g_main_context_dispatch () from /usr/lib64/libglib-2.0.so.0 ---Type <return> to continue, or q <return> to quit--- #11 0x00007ffff549cd83 in ?? () from /usr/lib64/libglib-2.0.so.0 #12 0x00007ffff549ce45 in g_main_context_iteration () from /usr/lib64/libglib-2.0.so.0 #13 0x00007ffff7aaab6e in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib64/qt4/libQtCore.so.4 #14 0x00007ffff628698a in ?? () from /usr/lib64/qt4/libQtGui.so.4 #15 0x00007ffff7a7ed38 in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib64/qt4/libQtCore.so.4 #16 0x00007ffff7a7ef99 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib64/qt4/libQtCore.so.4 #17 0x00007ffff7a82fc1 in QCoreApplication::exec() () from /usr/lib64/qt4/libQtCore.so.4 #18 0x00000000004046a9 in main (argc=2, argv=0x7fffffffd8a8) at /var/tmp/portage/kde-base/nepomuk-core-4.9.1/work/nepomuk-core-4.9.1/servicestub/main.cpp:170 (gdb) Okay. Confirmed. I'll fix it when I get some time. It's very clear what the problem is. It would be nice if this was taken care of before 4.9.2 *** This bug has been marked as a duplicate of bug 307388 *** Still segfaults in 4.9.2... :( The fix in bug 307388 didn't make it into 4.9.2, yes, but is easily backported. |