Bug 295933 - kactivitymanagerd locks rest of desktop
Summary: kactivitymanagerd locks rest of desktop
Status: RESOLVED FIXED
Alias: None
Product: nepomuk
Classification: Unmaintained
Component: general (show other bugs)
Version: git master
Platform: Gentoo Packages Linux
: NOR critical
Target Milestone: ---
Assignee: Nepomuk Bugs Coordination
URL:
Keywords: regression
Depends on:
Blocks:
 
Reported: 2012-03-13 15:39 UTC by Māris Nartišs
Modified: 2012-11-13 01:55 UTC (History)
12 users (show)

See Also:
Latest Commit:
Version Fixed In: 4.9.4
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Māris Nartišs 2012-03-13 15:39:16 UTC
If kactivitymanagerd get's stuck for some time waiting a reply from DBUS, it locks the rest of desktop till DBUS call fails (?).

Workaround: killall kactivitymanagerd

Here's gdb bt output when desktop has frozen:
#0  0x00007f9daf518b63 in poll () from /lib64/libc.so.6
#1  0x00007f9dabdb47b0 in socket_do_iteration () from /usr/lib64/libdbus-1.so.3
#2  0x00007f9dabdb36ad in _dbus_transport_do_iteration () from /usr/lib64/libdbus-1.so.3
#3  0x00007f9dabda1dd5 in _dbus_connection_do_iteration_unlocked () from /usr/lib64/libdbus-1.so.3
#4  0x00007f9dabda2c4b in _dbus_connection_block_pending_call () from /usr/lib64/libdbus-1.so.3
#5  0x00007f9dadcdce75 in QDBusConnectionPrivate::waitForFinished(QDBusPendingCallPrivate*) ()
   from /usr/lib64/qt4/libQtDBus.so.4
#6  0x00007f9dadd1d209 in QDBusPendingCallPrivate::waitForFinished() () from /usr/lib64/qt4/libQtDBus.so.4
#7  0x00007f9d9f6a5210 in KActivities::Consumer::currentActivity() const () from /usr/lib64/libkactivities.so.6
#8  0x00007f9d984bc311 in TaskManager::TaskManager::currentActivity() const () from /usr/lib64/libtaskmanager.so.4
#9  0x00007f9d984acd8b in TaskManager::Task::isOnCurrentActivity() const () from /usr/lib64/libtaskmanager.so.4
#10 0x00007f9d9849eb91 in TaskManager::GroupManagerPrivate::addTask(TaskManager::Task*) () from /usr/lib64/libtaskmanager.so.4
#11 0x00007f9d9849ee0c in TaskManager::GroupManagerPrivate::actuallyReloadTasks() () from /usr/lib64/libtaskmanager.so.4
#12 0x00007f9d9849f3a7 in TaskManager::GroupManagerPrivate::currentDesktopChanged(int) () from /usr/lib64/libtaskmanager.so.4
#13 0x00007f9d984a173f in TaskManager::GroupManager::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) ()
   from /usr/lib64/libtaskmanager.so.4
#14 0x00007f9db0b3ef83 in QMetaObject::activate(QObject*, QMetaObject const*, int, void**) ()
   from /usr/lib64/qt4/libQtCore.so.4
#15 0x00007f9d984bc451 in TaskManager::TaskManager::desktopChanged(int) () from /usr/lib64/libtaskmanager.so.4
#16 0x00007f9d984bdbd3 in TaskManager::TaskManager::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) ()
   from /usr/lib64/libtaskmanager.so.4
#17 0x00007f9db0b3ef83 in QMetaObject::activate(QObject*, QMetaObject const*, int, void**) ()
   from /usr/lib64/qt4/libQtCore.so.4
#18 0x00007f9db16fe13e in KWindowSystem::currentDesktopChanged(int) () from /usr/lib64/libkdeui.so.5
#19 0x00007f9db17009bb in KWindowSystemPrivate::x11Event(_XEvent*) () from /usr/lib64/libkdeui.so.5
#20 0x00007f9db15f1a50 in KSystemEventFilterPrivate::filterEvent(void*) () from /usr/lib64/libkdeui.so.5
#21 0x00007f9dafd4ec62 in x11EventSourceDispatch(_GSource*, int (*)(void*), void*) () from /usr/lib64/qt4/libQtGui.so.4
#22 0x00007f9dacd17092 in g_main_context_dispatch () from /usr/lib64/libglib-2.0.so.0
#23 0x00007f9dacd17888 in g_main_context_iterate.clone.6 () from /usr/lib64/libglib-2.0.so.0
#24 0x00007f9dacd17a61 in g_main_context_iteration () from /usr/lib64/libglib-2.0.so.0
#25 0x00007f9db0b588ef in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()

.xsession-errors in the meantime is filling with:

"/usr/bin/kactivitymanagerd(5738)" Soprano: "org.freedesktop.DBus.Error.ServiceUnknown - The name org.kde.nepomuk.services.nepo
mukstorage was not provided by any .service files"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "QLocalSocket::connectToServer: Invalid name"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "org.freedesktop.DBus.Error.ServiceUnknown - The name org.kde.nepomuk.services.nepo
mukstorage was not provided by any .service files"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "Unsupported operation (2)": "Invalid model"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "org.freedesktop.DBus.Error.ServiceUnknown - The name org.kde.nepomuk.services.nepo
mukstorage was not provided by any .service files"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "Unsupported operation (2)": "Invalid model"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "Invalid iterator."
kactivitymanagerd(5738)/nepomuk (library) Nepomuk::ResourceData::store: "The name org.kde.nepomuk.DataManagement was not provid
ed by any .service files" 
"/usr/bin/kactivitymanagerd(5738)" Soprano: "org.freedesktop.DBus.Error.ServiceUnknown - The name org.kde.nepomuk.services.nepo
mukstorage was not provided by any .service files"
"/usr/bin/kactivitymanagerd(5738)" Soprano: "QLocalSocket::connectToServer: Invalid name"
Comment 1 Lukas Polacek 2012-03-19 14:15:55 UTC
I had the same problem and "killall kactivitymanagerd" solved it for me. However, it didn't happen since then which was 2 days ago. It seems like a rare event.
Comment 2 Ivan Čukić 2012-03-21 17:23:31 UTC
The cause for this is a broken Nepomuk setup.

Make sure you have the compatible versions of all needed packages to run Nepomuk properly.

I'm leaving this open so that I remember to make it work even on broken setups :)
Comment 3 Franz Trischberger 2012-04-18 16:04:49 UTC
(In reply to comment #2)
> The cause for this is a broken Nepomuk setup.
> 
> Make sure you have the compatible versions of all needed packages to run
> Nepomuk properly.
What does that mean?
I am running a complete kde-4.8.2-setup, soprano-2.7.5, dbus-1.4.20, qt-4.8.1, virtuoso-6.1.4 (anything more, that could be interesting?), and I also get these freezes (plasma-desktop). I use IconTasks (the one shipped with kde since 4.8.0 (?)), and clicking left/middle mouse on an icon freezes the desktop.
Comment 4 Frédéric COIFFIER 2012-07-18 09:44:39 UTC
I confirm the problem with KDE 4.9 rc2 with Gentoo too.

I cannot find anywhere the list of the required packages/versions for Nepomuk. 
If a dev knows what can be the problem, could he explain it to allow us to correct this bug ?

[IP-] [  ] dev-db/virtuoso-odbc-6.1.5:0
[IP-] [  ] dev-db/virtuoso-server-6.1.5:0
[IP-] [  ] app-misc/strigi-0.7.7-r1:0
[I-O] [  ] dev-libs/soprano-2.8.0:0
[I-O] [  ] kde-base/kdegraphics-strigi-analyzer-4.8.97:4
[I-O] [  ] kde-base/kdepim-strigi-analyzer-4.8.97:4
[I-O] [  ] kde-base/kdesdk-strigi-analyzer-4.8.97:4
[I-O] [  ] kde-base/nepomuk-4.8.97:4
[I-O] [  ] kde-base/nepomuk-core-4.8.97:4
Comment 5 Janek Bevendorff 2012-07-19 20:18:40 UTC
I can reproduce this in 4.9RC2 as well.

When I go to the system settings, disable and then re-enable Nepomuk, it causes kactivitymanagerd to go all the way up to about 100% CPU which then causes Dolphin to freeze when I right click inside the file view bringing this kind dbus timeout messages to .xsession-errors:

dolphin(9568) KActivities::Consumer::listActivities: d-bus reply was invalid () QDBusError("org.freedesktop.DBus.Error.NoReply", "Did not receive a reply. Possible causes include: the remote application did not send a reply, the message bus security policy blocked the reply, the reply timeout expired, or the network connection was broken.")
dolphin(9568) KBookmarkManager::notifyChanged: KBookmarkManager::notifyChanged (  "" )

After a minute or so also Plasma freezes.

When debugging for kactivitymanagerd is on, my .xsession-errors also fills with messages like:

"/usr/bin/kactivitymanagerd(8912)" Soprano: "Failed to write to fd 11 (Broken pipe)"
"/usr/bin/kactivitymanagerd(8912)" Soprano: "Failed to write unsigned int32."

Killing frozen Plasma works, but I can't restart it until I have killed and restarted kactivitymanagerd (restarting that alone without killing plasma first also works around the problem).

I cannot reproduce the behavior in my Project Neon VM, though.
Comment 6 Janek Bevendorff 2012-08-05 15:38:46 UTC
Still reproducible in 4.9.0 as described in my comment above.
Comment 7 Ivan Čukić 2012-08-05 16:23:42 UTC
"/usr/bin/kactivitymanagerd(8912)" Soprano: "Failed to write to fd 11 (Broken pipe)" "/usr/bin/kactivitymanagerd(8912)" Soprano: "Failed to write unsigned int32."

This implies broken nepomuk/soprano setup. You should contact nepomuk guys (IRC #kde-nepomuk) to debug.
Comment 8 Janek Bevendorff 2012-08-05 17:05:52 UTC
It's actually #nepomuk-kde, but I'll do that.
Comment 9 Vishesh Handa 2012-08-05 17:18:47 UTC
I know about this problem - Trying to fix it.
Comment 10 Vishesh Handa 2012-08-08 14:20:45 UTC
I decided to tackle this bug today, and despite my best efforts I could not reproduce it.

If someone can reproduce is, could they please provide me with the full backtrace? The backtrace that has been attached only has information about one thread.

This should do the trick -

> attach <pid>
> thread apply all backtrace
> detach <pid>

Thanks
Comment 11 Janek Bevendorff 2012-08-08 14:46:05 UTC
Backtrace of what?
BTW you won't probably notice anything after restarting Nepomuk until you open a Dolphin window and right click somewhere in the file view.

I can reproduce this here reliably 100% of the time.
Comment 12 Vishesh Handa 2012-08-08 14:56:02 UTC
(In reply to comment #11)
> Backtrace of what?
In your case dolphin.

> BTW you won't probably notice anything after restarting Nepomuk until you
> open a Dolphin window and right click somewhere in the file view.
> 
> I can reproduce this here reliably 100% of the time.

This is what I've been doing -
1. Start Nepomuk
2. Start dolphin/krunner/kactivitymangaerd
3. Switch of Nepomuk
4. Use th specified application, and wait for it to go mad.

How are you going about it?
Comment 13 Janek Bevendorff 2012-08-08 16:10:22 UTC
Stupid question: how do I get a backtrace of a program that is not crashing?
I started it with gdb, but I only get some debug messages (when turning them one using kdebugdialog).

When I start Dolphin I get:

Starting program: /usr/bin/dolphin 
[Thread debugging using libthread_db enabled]
Using host libthread_db library "/lib64/libthread_db.so.1".
[New Thread 0x7fffd78e3700 (LWP 13534)]
QPixmap::scaled: Pixmap is a null pixmap
QPixmap::scaled: Pixmap is a null pixmap
QPixmap::scaled: Pixmap is a null pixmap
[New Thread 0x7fffd6a63700 (LWP 13540)]
dolphin(13518) KSambaSharePrivate::testparmParamValue: Running testparm ("-d0", "-s", "--parameter-name", "usershare path")
[New Thread 0x7fffd5081700 (LWP 13547)]
[Thread 0x7fffd5081700 (LWP 13547) exited]
[New Thread 0x7fffd5081700 (LWP 13548)]
[Thread 0x7fffd5081700 (LWP 13548) exited]
[New Thread 0x7fffd5081700 (LWP 13549)]
[Thread 0x7fffd5081700 (LWP 13549) exited]
dolphin(13518) KDirListerCache::listDir: Listing 59 cached items soon
dolphin(13518)/kdecore (services) KServicePrivate::init: The desktop entry file  "/home/janek/.directory"  has Type= "Application"  but no Exec line

And some time later:

dolphin(13518) KActivities::Consumer::isResourceLinkedToActivity: d-bus reply was invalid false QDBusError("org.freedesktop.DBus.Error.NoReply", "Did not receive a reply. Possible causes include: the remote application did not send a reply, the message bus security policy blocked the reply, the reply timeout expired, or the network connection was broken.")
dolphin(13518) KActivities::Consumer::listActivities: d-bus reply was invalid () QDBusError("org.freedesktop.DBus.Error.NoReply", "Did not receive a reply. Possible causes include: the remote application did not send a reply, the message bus security policy blocked the reply, the reply timeout expired, or the network connection was broken.")
dolphin(13518) KBookmarkManager::notifyChanged: KBookmarkManager::notifyChanged (  "" )

while my .xsession-errors fills with the "broken pipe" messages I posted above.
Comment 14 Vishesh Handa 2012-08-08 16:17:04 UTC
You get the pid of the process by `pidof dolphin`. Or you can use ps aux | grep dolphin.

Once you have that you run 
$gdb
attach <pid>
thread apply all backtrace
detach <pid>

That should give you the backtrace.
Comment 15 Janek Bevendorff 2012-08-08 16:25:24 UTC
This is what I get:

0x00007f91b8267573 in poll () from /lib64/libc.so.6

Thread 3 (Thread 0x7f919a545700 (LWP 14058)):
#0  0x00007f91b8267573 in poll () from /lib64/libc.so.6
#1  0x00007f91b51df796 in g_main_context_iterate.isra.23 () from /usr/lib64/libglib-2.0.so.0
#2  0x00007f91b51df8c4 in g_main_context_iteration () from /usr/lib64/libglib-2.0.so.0
#3  0x00007f91b98bb1ff in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#4  0x00007f91b988adf2 in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#5  0x00007f91b988b047 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#6  0x00007f91b978afd7 in QThread::exec() () from /usr/lib64/qt4/libQtCore.so.4
#7  0x00007f91b986ac0f in QInotifyFileSystemWatcherEngine::run() () from /usr/lib64/qt4/libQtCore.so.4
#8  0x00007f91b978dffb in QThreadPrivate::start(void*) () from /usr/lib64/qt4/libQtCore.so.4
#9  0x00007f91b94f7e2c in start_thread () from /lib64/libpthread.so.0
#10 0x00007f91b82701dd in clone () from /lib64/libc.so.6

Thread 2 (Thread 0x7f91996c5700 (LWP 14064)):
#0  0x00007f91b8269bb3 in select () from /lib64/libc.so.6
#1  0x00007f91b986a281 in QProcessManager::run() () from /usr/lib64/qt4/libQtCore.so.4
#2  0x00007f91b978dffb in QThreadPrivate::start(void*) () from /usr/lib64/qt4/libQtCore.so.4
#3  0x00007f91b94f7e2c in start_thread () from /lib64/libpthread.so.0
#4  0x00007f91b82701dd in clone () from /lib64/libc.so.6

Thread 1 (Thread 0x7f91bac78780 (LWP 14054)):
#0  0x00007f91b8267573 in poll () from /lib64/libc.so.6
#1  0x00007f91b51df796 in g_main_context_iterate.isra.23 () from /usr/lib64/libglib-2.0.so.0
#2  0x00007f91b51df8c4 in g_main_context_iteration () from /usr/lib64/libglib-2.0.so.0
#3  0x00007f91b98bb1ff in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#4  0x00007f91b8abd5fe in QGuiEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtGui.so.4
#5  0x00007f91b988adf2 in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#6  0x00007f91b988b047 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) ()
   from /usr/lib64/qt4/libQtCore.so.4
#7  0x00007f91b988fe65 in QCoreApplication::exec() () from /usr/lib64/qt4/libQtCore.so.4
#8  0x00007f91a02ec6d7 in kdemain (argc=5, argv=0x16b9cc0)
    at /var/tmp/portage/kde-base/dolphin-4.9.0/work/dolphin-4.9.0/dolphin/src/main.cpp:89
#9  0x0000000000408a24 in launch (argc=5, _name=0x1683dd8 "/usr/bin/dolphin", args=<optimized out>, 
    cwd=0x0, envc=<optimized out>, envs=<optimized out>, reset_env=false, tty=0x0, avoid_loops=false, 
    startup_id_str=0x1683e30 "janek-pc-sabayon;1344442880;65406;12959_TIME799476433")
    at /var/tmp/portage/kde-base/kdelibs-4.9.0/work/kdelibs-4.9.0/kinit/kinit.cpp:734
#10 0x0000000000409b06 in handle_launcher_request (sock=7, who=<optimized out>)
    at /var/tmp/portage/kde-base/kdelibs-4.9.0/work/kdelibs-4.9.0/kinit/kinit.cpp:1226
#11 0x000000000040a02f in handle_requests (waitForPid=0)
    at /var/tmp/portage/kde-base/kdelibs-4.9.0/work/kdelibs-4.9.0/kinit/kinit.cpp:1419
#12 0x0000000000405a2e in main (argc=2, argv=0x7fff7a1958c0, envp=0x7fff7a195b90)
    at /var/tmp/portage/kde-base/kdelibs-4.9.0/work/kdelibs-4.9.0/kinit/kinit.cpp:1907
Comment 16 Blackpaw 2012-10-01 11:53:15 UTC
Seeing this occasionally in 4.9.1
Comment 17 Simeon Bird 2012-10-27 22:55:48 UTC
I can reproduce this pretty reliably. 
What you must do: 

1. Turn nepomuk off in system settings
2. Open dolphin and right click on an indexed folder.
3. Turn nepomuk on again
2. Right click again on an indexed folder.

I got this backtrace: 

hread 5 (Thread 0x7f19e25ec700 (LWP 17987)):
#0  0x00007f19ef4fe073 in select () from /usr/lib/libc.so.6
#1  0x00007f19ecaad430 in ?? () from /usr/lib/libsopranoclient.so.1
#2  0x00007f19ecaaf76a in ?? () from /usr/lib/libsopranoclient.so.1
#3  0x00007f19ecab01b6 in ?? () from /usr/lib/libsopranoclient.so.1
#4  0x00007f19ecab2880 in ?? () from /usr/lib/libsopranoclient.so.1
#5  0x00007f19ecab54d3 in ?? () from /usr/lib/libsopranoclient.so.1
#6  0x00007f19f2109846 in Nepomuk2::MainModel::executeQuery(QString const&, Soprano::Query::QueryLanguage, QString const&) const ()
   from /usr/lib/libnepomukcore.so.4
#7  0x00007f19f20fc710 in Nepomuk2::ResourceData::determineUri() () from /usr/lib/libnepomukcore.so.4
#8  0x00007f19f210fd59 in Nepomuk2::Resource::determineFinalResourceData() const () from /usr/lib/libnepomukcore.so.4
#9  0x00007f19f2110404 in Nepomuk2::Resource::property(QUrl const&) const () from /usr/lib/libnepomukcore.so.4
#10 0x00007f19f211056c in Nepomuk2::Resource::isRelateds() const () from /usr/lib/libnepomukcore.so.4
#11 0x000000000041dd0f in NepomukActivityManager::resourcesLinkedToActivity(QString const&) const ()
#12 0x000000000041df08 in NepomukActivityManager::isResourceLinkedToActivity(KUrl const&, QString const&) const ()
#13 0x0000000000416a93 in Resources::IsResourceLinkedToActivity(QString const&, QString const&) const ()
#14 0x0000000000429ac2 in ResourcesAdaptor::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) ()
#15 0x0000000000429ceb in ResourcesAdaptor::qt_metacall(QMetaObject::Call, int, void**) ()
#16 0x00007f19f15dfef3 in ?? () from /usr/lib/libQtDBus.so.4
#17 0x00007f19f15e0ff5 in ?? () from /usr/lib/libQtDBus.so.4
#18 0x00007f19f15e1966 in ?? () from /usr/lib/libQtDBus.so.4
#19 0x00007f19f15e1a5b in ?? () from /usr/lib/libQtDBus.so.4
#20 0x00007f19f1279fae in QObject::event(QEvent*) () from /usr/lib/libQtCore.so.4
#21 0x00007f19f03f908c in QApplicationPrivate::notify_helper(QObject*, QEvent*) () from /usr/lib/libQtGui.so.4
#22 0x00007f19f03fd50a in QApplication::notify(QObject*, QEvent*) () from /usr/lib/libQtGui.so.4
#23 0x00007f19f2aa1df6 in KApplication::notify(QObject*, QEvent*) () from /usr/lib/libkdeui.so.5
#24 0x00007f19f12655ee in QCoreApplication::notifyInternal(QObject*, QEvent*) () from /usr/lib/libQtCore.so.4
#25 0x00007f19f1268f51 in QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) () from /usr/lib/libQtCore.so.4
#26 0x00007f19f12935b3 in ?? () from /usr/lib/libQtCore.so.4
#27 0x00007f19ebb28475 in g_main_context_dispatch () from /usr/lib/libglib-2.0.so.0
#28 0x00007f19ebb287a8 in ?? () from /usr/lib/libglib-2.0.so.0
#29 0x00007f19ebb28864 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#30 0x00007f19f1293746 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#31 0x00007f19f126433f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#32 0x00007f19f12645c8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#33 0x00007f19f11657c0 in QThread::exec() () from /usr/lib/libQtCore.so.4
#34 0x000000000040ebea in Resources* runInQThread<Resources>()::Thread::run() ()
#35 0x00007f19f116879c in ?? () from /usr/lib/libQtCore.so.4
#36 0x00007f19f0ed8e0f in start_thread () from /usr/lib/libpthread.so.0
#37 0x00007f19ef50445d in clone () from /usr/lib/libc.so.6

Thread 4 (Thread 0x7f19e1be5700 (LWP 17988)):
#0  0x00007f19ef4fc2cd in poll () from /usr/lib/libc.so.6
#1  0x00007f19ebb28744 in ?? () from /usr/lib/libglib-2.0.so.0
#2  0x00007f19ebb28864 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#3  0x00007f19f1293746 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#4  0x00007f19f126433f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#5  0x00007f19f12645c8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#6  0x00007f19f11657c0 in QThread::exec() () from /usr/lib/libQtCore.so.4
#7  0x000000000040ebba in Activities* runInQThread<Activities>()::Thread::run() ()
#8  0x00007f19f116879c in ?? () from /usr/lib/libQtCore.so.4
#9  0x00007f19f0ed8e0f in start_thread () from /usr/lib/libpthread.so.0
#10 0x00007f19ef50445d in clone () from /usr/lib/libc.so.6

Thread 3 (Thread 0x7f19e13e4700 (LWP 17989)):
#0  0x00007f19ef4fc2cd in poll () from /usr/lib/libc.so.6
#1  0x00007f19ebb28744 in ?? () from /usr/lib/libglib-2.0.so.0
#2  0x00007f19ebb28864 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#3  0x00007f19f1293766 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#4  0x00007f19f126433f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#5  0x00007f19f12645c8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#6  0x00007f19f11657c0 in QThread::exec() () from /usr/lib/libQtCore.so.4
#7  0x000000000040eb8a in Features* runInQThread<Features>()::Thread::run() ()
#8  0x00007f19f116879c in ?? () from /usr/lib/libQtCore.so.4
#9  0x00007f19f0ed8e0f in start_thread () from /usr/lib/libpthread.so.0
---Type <return> to continue, or q <return> to quit---
#10 0x00007f19ef50445d in clone () from /usr/lib/libc.so.6

Thread 2 (Thread 0x7f19d3908700 (LWP 17990)):
#0  0x00007f19ef4fc2cd in poll () from /usr/lib/libc.so.6
#1  0x00007f19ebb28744 in ?? () from /usr/lib/libglib-2.0.so.0
#2  0x00007f19ebb28864 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#3  0x00007f19f1293766 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#4  0x00007f19f126433f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#5  0x00007f19f12645c8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#6  0x00007f19f11657c0 in QThread::exec() () from /usr/lib/libQtCore.so.4
#7  0x00007f19f1244aff in ?? () from /usr/lib/libQtCore.so.4
#8  0x00007f19f116879c in ?? () from /usr/lib/libQtCore.so.4
#9  0x00007f19f0ed8e0f in start_thread () from /usr/lib/libpthread.so.0
#10 0x00007f19ef50445d in clone () from /usr/lib/libc.so.6

Thread 1 (Thread 0x7f19f3568780 (LWP 17986)):
#0  0x00007f19ef4fc2cd in poll () from /usr/lib/libc.so.6
#1  0x00007f19ebb28744 in ?? () from /usr/lib/libglib-2.0.so.0
#2  0x00007f19ebb28864 in g_main_context_iteration () from /usr/lib/libglib-2.0.so.0
#3  0x00007f19f1293766 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#4  0x00007f19f049950e in ?? () from /usr/lib/libQtGui.so.4
#5  0x00007f19f126433f in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#6  0x00007f19f12645c8 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () from /usr/lib/libQtCore.so.4
#7  0x00007f19f1269268 in QCoreApplication::exec() () from /usr/lib/libQtCore.so.4
#8  0x000000000040a725 in main ()
Comment 18 Simeon Bird 2012-10-27 23:34:29 UTC
and again with symbols for soprano:

Program received signal SIGPIPE, Broken pipe.
[Switching to Thread 0x7f8893820700 (LWP 26686)]
0x00007f88a211331d in write () from /usr/lib/libpthread.so.0
(gdb) bt
#0  0x00007f88a211331d in write () from /usr/lib/libpthread.so.0
#1  0x00007f889dce1b36 in Soprano::Socket::write(char const*, long long) () from /usr/lib/libsopranoclient.so.1
#2  0x00007f889dce23a6 in Soprano::SocketStream::writeUnsignedInt16(unsigned short) () from /usr/lib/libsopranoclient.so.1
#3  0x00007f889dce6830 in Soprano::Client::ClientConnection::executeQuery(int, QString const&, Soprano::Query::QueryLanguage, QString const&) () from /usr/lib/libsopranoclient.so.1
#4  0x00007f889dce94e3 in Soprano::Client::ClientModel::executeQuery(QString const&, Soprano::Query::QueryLanguage, QString const&) const
    () from /usr/lib/libsopranoclient.so.1
#5  0x00007f88a333d846 in Nepomuk2::MainModel::executeQuery(QString const&, Soprano::Query::QueryLanguage, QString const&) const ()
   from /usr/lib/libnepomukcore.so.4
#6  0x00007f88a3330710 in Nepomuk2::ResourceData::determineUri() () from /usr/lib/libnepomukcore.so.4
#7  0x00007f88a3343d59 in Nepomuk2::Resource::determineFinalResourceData() const () from /usr/lib/libnepomukcore.so.4
#8  0x00007f88a3344404 in Nepomuk2::Resource::property(QUrl const&) const () from /usr/lib/libnepomukcore.so.4
#9  0x00007f88a334456c in Nepomuk2::Resource::isRelateds() const () from /usr/lib/libnepomukcore.so.4
#10 0x000000000041dd0f in NepomukActivityManager::resourcesLinkedToActivity(QString const&) const ()
#11 0x000000000041df08 in NepomukActivityManager::isResourceLinkedToActivity(KUrl const&, QString const&) const ()
#12 0x0000000000416a93 in Resources::IsResourceLinkedToActivity(QString const&, QString const&) const ()
#13 0x0000000000429ac2 in ResourcesAdaptor::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) ()
#14 0x0000000000429ceb in ResourcesAdaptor::qt_metacall(QMetaObject::Call, int, void**) ()
Comment 19 Simeon Bird 2012-11-11 04:25:32 UTC
There were two overlapping problems here:

1. Soprano::ClientConnection::isConnected() does not, in fact, check whether a socket is connected, merely whether is has been successfully connected in the past. So when nepomuk is shut down, the resource manager still (falsely) claims it has a valid connection to the server and if anyone tries to write to it, will crash, which is what is happening. 

Reviews https://git.reviewboard.kde.org/r/107283/ and https://git.reviewboard.kde.org/r/107285/ fix this problem by explicitly marking the socket as disconnected when the resourcemanager gets the nepomukstopped signal. One patch is to nepomuk-core and one to kdelibs. 

2. kactivities was testing for the presence of nepomuk by watching for ownership changes to its dbus service. The resourcemanager listens to a specific dbus signal before configuring itself, so the dbus service ownership change will always occur before resourcemanager reconnects to the new nepomuk socket and declares itself ready. This means that kactivities will try to write to the old socket, which no longer exists. 

https://git.reviewboard.kde.org/r/107290/ changes kactivities to listen to the "ready" signal from resourcemanager, avoiding this problem.

Although any one of these patches will fix this specific bug, unless all three are applied, specific corner cases will still fail. Particularly both the kdelibs and nepomuk-core patches are needed, even in 4.10, because of the new kFileMetaDataWidget, which depends on nepomuk from kdelibs, thus making dolphin link to kdelibs' nepomuk.
Comment 20 Simeon Bird 2012-11-13 01:55:50 UTC
Git commit 436b31deabd46f3ccd8fa0b7d6ac03e1bcac2948 by Simeon Bird.
Committed on 10/11/2012 at 04:47.
Pushed by sbird into branch 'KDE/4.9'.

Manually disconnect the socket connection to nepomuk in the resourcemanager when
the socket is remote disconnected.

This is needed because the Soprano method isConnected() does not
actually check whether the socket is connected or not.

REVIEW: 107285
FIXED-IN: 4.9.4

M  +5    -0    libnepomukcore/resource/nepomukmainmodel.cpp
M  +10   -0    libnepomukcore/resource/nepomukmainmodel.h
M  +3    -0    libnepomukcore/resource/resourcemanager.cpp

http://commits.kde.org/nepomuk-core/436b31deabd46f3ccd8fa0b7d6ac03e1bcac2948