https://bugs.kde.org/show_bug.cgi?id=468663
Bug ID: 468663 Summary: qdbus-qt5 org.kde.baloo occasionally crashed during shutdown Classification: Frameworks and Libraries Product: frameworks-baloo Version: 5.104.0 Platform: Fedora RPMs OS: Linux Status: REPORTED Severity: normal Priority: NOR Component: general Assignee: baloo-bugs-n...@kde.org Reporter: matt.fagn...@bell.net Target Milestone: --- Created attachment 158197 --> https://bugs.kde.org/attachment.cgi?id=158197&action=edit Full trace of all threads of qdbus-qt5 org.kde.baloo crash SUMMARY I've seen qdbus-qt5 org.kde.baloo crash twice during shutdown from Plasma on Wayland. The first such crash was with Plasma 5.26.5 on Wayland, KF 5.101.0, Qt 5.15.8 in Fedora 37. The second crash was with Plasma 5.27.4 on Wayland, KF 5.104.0, Qt 5.15.9 in Fedora 38. Both crashes had the same sort of trace. Frame #0 had ?? instead of the function name and frame #1 had QMetaType::destruct. The following trace was for the second crash. Using host libthread_db library "/lib64/libthread_db.so.1". Core was generated by `qdbus-qt5 org.kde.baloo'. --Type <RET> for more, q to quit, c to continue without paging--c Missing separate debuginfos, use: dnf debuginfo-install qt5-qttools-5.15.9-1.fc38.x86_64 Program terminated with signal SIGSEGV, Segmentation fault. #0 0x0000010700000008 in ?? () [Current thread is 1 (Thread 0x7f0fd25ff6c0 (LWP 9610))] (gdb) bt #0 0x0000010700000008 in ?? () #1 0x00007f0fe2cc85db in QMetaType::destruct (data=0x55a076b87800, this=0x7f0fd25fe900) at kernel/qmetatype.h:2372 #2 QMetaType::destroy (type=<optimized out>, data=0x55a076b87800) at kernel/qmetatype.cpp:1664 #3 0x00007f0fe2cdbb77 in QMetaCallEvent::~QMetaCallEvent (this=0x55a076b876d0, __in_chrg=<optimized out>) at kernel/qobject.cpp:618 #4 0x00007f0fe2cdbbe5 in QMetaCallEvent::~QMetaCallEvent (this=0x55a076b876d0, __in_chrg=<optimized out>) at kernel/qobject.cpp:625 #5 0x00007f0fe2cb71ff in QScopedPointerDeleter<QEvent>::cleanup (pointer=0x55a076b876d0) at ../../include/QtCore/../../src/corelib/tools/qscopedpointer.h:52 #6 QScopedPointer<QEvent, QScopedPointerDeleter<QEvent> >::~QScopedPointer (this=0x7f0fd25fea10, __in_chrg=<optimized out>) at ../../include/QtCore/../../src/corelib/tools/qscopedpointer.h:107 #7 QCoreApplicationPrivate::sendPostedEvents (receiver=0x0, event_type=0, data=0x55a076b87280) at kernel/qcoreapplication.cpp:1826 #8 0x00007f0fe2cb74ad in QCoreApplication::sendPostedEvents (receiver=<optimized out>, event_type=<optimized out>) at kernel/qcoreapplication.cpp:1680 #9 0x00007f0fe2d06e2f in postEventSourceDispatch (s=0x7f0fcc000ee0) at kernel/qeventdispatcher_glib.cpp:277 #10 0x00007f0fe1f0bf58 in g_main_dispatch (context=0x7f0fcc000c30) at ../glib/gmain.c:3460 #11 g_main_context_dispatch (context=0x7f0fcc000c30) at ../glib/gmain.c:4200 #12 0x00007f0fe1f6bcd8 in g_main_context_iterate.isra.0 (context=0x7f0fcc000c30, block=1, dispatch=1, self=<optimized out>) at ../glib/gmain.c:4276 #13 0x00007f0fe1f0d233 in g_main_context_iteration (context=0x7f0fcc000c30, may_block=1) --Type <RET> for more, q to quit, c to continue without paging--c at ../glib/gmain.c:4343 #14 0x00007f0fe2d06919 in QEventDispatcherGlib::processEvents (this=0x7f0fcc000b70, flags=...) at kernel/qeventdispatcher_glib.cpp:423 #15 0x00007f0fe2cb270b in QEventLoop::exec (this=this@entry=0x7f0fd25fed00, flags=..., flags@entry=...) at ../../include/QtCore/../../src/corelib/global/qflags.h:69 #16 0x00007f0fe2af4160 in QThread::exec ( this=this@entry=0x7f0fe311e060 <(anonymous namespace)::Q_QGS__q_manager::innerFunction()::holder>) at ../../include/QtCore/../../src/corelib/global/qflags.h:121 #17 0x00007f0fe30a4b3b in QDBusConnectionManager::run ( this=0x7f0fe311e060 <(anonymous namespace)::Q_QGS__q_manager::innerFunction()::holder>) at qdbusconnection.cpp:179 #18 0x00007f0fe2af556d in operator() (__closure=<optimized out>) at thread/qthread_unix.cpp:350 #19 (anonymous namespace)::terminate_on_exception<QThreadPrivate::start(void*)::<lambda()> > (t=...) at thread/qthread_unix.cpp:287 #20 QThreadPrivate::start ( arg=0x7f0fe311e060 <(anonymous namespace)::Q_QGS__q_manager::innerFunction()::holder>) at thread/qthread_unix.cpp:310 #21 0x00007f0fe24adc57 in start_thread (arg=<optimized out>) at pthread_create.c:444 #22 0x00007f0fe2533a70 in clone3 () at ../sysdeps/unix/sysv/linux/x86_64/clone3.S:81 The process appeared to be being stopped. The invalid address in frame #0 might have been due to corruption of a function pointer destructExtended in QMetaType::destruct. (gdb) frame 1 #1 0x00007f0fe2cc85db in QMetaType::destruct (data=0x55a076b87800, this=0x7f0fd25fe900) at kernel/qmetatype.h:2372 2372 return destructExtended(data); (gdb) p destructExtended $1 = {void (const QMetaType * const, void *)} 0x7f0fe2cc8530 <QMetaType::destructExtended(void*) const> The crash happened infrequently. The problem might involve a race condition in which the function in frame #0 was freed or corrupted before it was used during shutdown or not. I've had file indexing disabled in System Settings when this problem happened, so I'm not sure why qdbus-qt5 org.kde.baloo was run. STEPS TO REPRODUCE 1. Boot a Fedora 38 KDE Plasma installation updated to 2023-4-17 with the updates-testing repo enabled. The check mark for Enable File Indexing was removed in System Settings > Search > File Search > File Search long before the crashes happened. 2. Log in to Plasma 5.27.4 on Wayland 3. Shut down the system from the Application Launcher menu. 4. Repeat 1-3 until the crash happens. This crash was infrequent so this might take many boots to happen. OBSERVED RESULT qdbus-qt5 org.kde.baloo occasionally crashed during shutdown EXPECTED RESULT No crash would happen. SOFTWARE/OS VERSIONS Linux/KDE Plasma: Fedora 38 (available in About System) KDE Plasma Version: 5.27.4 KDE Frameworks Version: 5.104.0 Qt Version: 5.15.9 ADDITIONAL INFORMATION I'm attaching the full trace of all threads of the qdbus-qt5 org.kde.baloo crash. -- You are receiving this mail because: You are watching all bug changes.