Summary: | plasmashell crashes in KAStatsFavoritesModel::Private::Private | ||
---|---|---|---|
Product: | [Plasma] plasmashell | Reporter: | medin <med.medin.2014> |
Component: | generic-crash | Assignee: | Plasma Bugs List <plasma-bugs> |
Status: | RESOLVED FIXED | ||
Severity: | crash | CC: | akselmo, bugseforuns, crap-dennis, dashonwwIII, dcalvino, eliteamdgaming, justin, kde.smashthebugs, kde.webservice, michael, nate, nicolas.fella, notmart, plasma-bugs, polluxau, postix, qydwhotmail, sam, sitter, waynenail |
Priority: | VHI | Keywords: | qt6 |
Version: | 6.0.1 | ||
Target Milestone: | 1.0 | ||
Platform: | Manjaro | ||
OS: | Linux | ||
See Also: |
https://bugs.kde.org/show_bug.cgi?id=487385 https://bugs.kde.org/show_bug.cgi?id=490624 |
||
Latest Commit: | https://invent.kde.org/plasma/plasma-workspace/-/commit/65c5bc469d53dc70921b10b8c4527536883a8bb0 | Version Fixed In: | 6.1.3 |
Sentry Crash Report: |
Description
medin
2024-03-08 15:26:23 UTC
Possibly caused by https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/3982 *** Bug 484458 has been marked as a duplicate of this bug. *** *** Bug 484614 has been marked as a duplicate of this bug. *** Git commit 2942dcf06c9661cf61a0255eeaa750c34b43e62d by Fushan Wen. Committed on 28/03/2024 at 16:12. Pushed by fusionfuture into branch 'master'. applets/kicker: avoid calling reload() recursively KSycoca::ensureCacheValid might emit databaseChanged signal again, which will cause a crash SENTRY: PLASMA-WORKSPACE-5HC SENTRY: PLASMA-WORKSPACE-6P5 SENTRY: PLASMA-WORKSPACE-2KD M +0 -1 applets/kicker/plugin/appentry.h M +17 -12 applets/kicker/plugin/kastatsfavoritesmodel.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/2942dcf06c9661cf61a0255eeaa750c34b43e62d Git commit 9b6a8aaf7968c4ac82613f114ee6c1223a2d03b8 by Fushan Wen. Committed on 28/03/2024 at 16:42. Pushed by fusionfuture into branch 'Plasma/6.0'. applets/kicker: avoid calling reload() recursively KSycoca::ensureCacheValid might emit databaseChanged signal again, which will cause a crash SENTRY: PLASMA-WORKSPACE-5HC SENTRY: PLASMA-WORKSPACE-6P5 SENTRY: PLASMA-WORKSPACE-2KD (cherry picked from commit 2942dcf06c9661cf61a0255eeaa750c34b43e62d) M +0 -1 applets/kicker/plugin/appentry.h M +17 -12 applets/kicker/plugin/kastatsfavoritesmodel.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/9b6a8aaf7968c4ac82613f114ee6c1223a2d03b8 *** Bug 485331 has been marked as a duplicate of this bug. *** *** Bug 485471 has been marked as a duplicate of this bug. *** *** Bug 488316 has been marked as a duplicate of this bug. *** *** Bug 488417 has been marked as a duplicate of this bug. *** Unfortunately we're continuing to get bug reports about this (with the same backtrace) from people using Plasma 6.0.5; re-opening. *** Bug 485519 has been marked as a duplicate of this bug. *** *** Bug 484792 has been marked as a duplicate of this bug. *** *** Bug 484930 has been marked as a duplicate of this bug. *** *** Bug 486980 has been marked as a duplicate of this bug. *** *** Bug 487908 has been marked as a duplicate of this bug. *** *** Bug 489381 has been marked as a duplicate of this bug. *** *** Bug 489559 has been marked as a duplicate of this bug. *** I am unable to repro this so far, but some things that may cause this happen: - The activity you're using has to have "Tracking file and app use" checkbox on - Same app installed as distro package and flatpak, then modifying one of them (removing, installing) In KAStatsFavoritesModel::Private for some reason the iterator can report it.value() that is null, which then causes it.value()->reload() to segfault. One possible solution is to add a simple guard like `if (it.value()) {...}`, but I am not sure if that is the exact solution. To add, it could have something to do with having a desktop file for flatpak and distro installed package that have both same name. A possibly relevant merge request was started @ https://invent.kde.org/plasma/plasma-workspace/-/merge_requests/4510 Git commit 29e38fdfecaeb77d77f0c71aa66d7cc4c3f54b2c by Akseli Lahtinen. Committed on 10/07/2024 at 08:33. Pushed by akselmo into branch 'master'. kastatsfavoritesmodel.cpp: prefer .value() over operator[] - In `removeResult`, use `resource` directly so we are not comparing to a possible `nullptr` which can cause crashing - Prefer `.value` over `operator[]` to avoid leaving behind `nullptr` entries when reading items M +7 -6 applets/kicker/plugin/kastatsfavoritesmodel.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/29e38fdfecaeb77d77f0c71aa66d7cc4c3f54b2c Git commit 65c5bc469d53dc70921b10b8c4527536883a8bb0 by Akseli Lahtinen. Committed on 10/07/2024 at 08:47. Pushed by akselmo into branch 'Plasma/6.1'. kastatsfavoritesmodel.cpp: prefer .value() over operator[] - In `removeResult`, use `resource` directly so we are not comparing to a possible `nullptr` which can cause crashing - Prefer `.value` over `operator[]` to avoid leaving behind `nullptr` entries when reading items (cherry picked from commit 29e38fdfecaeb77d77f0c71aa66d7cc4c3f54b2c) 050c8cc6 kastatsfavoritesmodel.cpp: make sure it.value exists before trying to reload faf522c7 Compare value-id directly to resource in removeResult 81ad3a75 Use .value instead of operator[] 737178d2 Remove guards f0bce1fc Add a comment about the entry value Co-authored-by: Akseli Lahtinen <akselmo@akselmo.dev> M +7 -6 applets/kicker/plugin/kastatsfavoritesmodel.cpp https://invent.kde.org/plasma/plasma-workspace/-/commit/65c5bc469d53dc70921b10b8c4527536883a8bb0 *** Bug 490138 has been marked as a duplicate of this bug. *** I am on 6.1.3 and just got the crash again on Operating System: openSUSE Tumbleweed 20240724 KDE Plasma Version: 6.1.3 KDE Frameworks Version: 6.4.0 Qt Version: 6.7.2 when installing a package in Konsole with `zypper install $xyz`. ``` #5 0x00007f73bd4d1ccf in KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}::operator()() const (__closure=0x555ea8fb8970) at /usr/src/debug/plasma-workspace-6.1.3/applets/kicker/plugin/kastatsfavoritesmodel.cpp:196 #6 QtPrivate::FunctorCall<QtPrivate::IndexesList<>, QtPrivate::List<>, void, KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}>::call(KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}&, void**) (arg=<optimized out>, f=...) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:137 #7 QtPrivate::FunctorCallable<KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}>::call<QtPrivate::List<>, void>(KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}&, void*, void**) (arg=<optimized out>, f=...) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:345 #8 QtPrivate::QCallableObject<KAStatsFavoritesModel::Private::Private(KAStatsFavoritesModel*, QString const&)::{lambda()#1}, QtPrivate::List<>, void>::impl(int, QtPrivate::QSlotObjectBase*, QObject*, void**, bool*) (which=<optimized out>, this_=0x555ea8fb8960, r=<optimized out>, a=<optimized out>, ret=<optimized out>) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:555 #9 0x00007f74223d1e1b in QObject::event (this=0x555ea91182d0, e=0x555eac43bc60) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qobject.cpp:1452 #10 0x00007f74245c2f6e in QApplicationPrivate::notify_helper (this=<optimized out>, receiver=0x555ea91182d0, e=0x555eac43bc60) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/widgets/kernel/qapplication.cpp:3287 #11 0x00007f742238ec30 in QCoreApplication::notifyInternal2 (receiver=0x555ea91182d0, event=0x555eac43bc60) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qcoreapplication.cpp:1142 #12 0x00007f742238ec69 in QCoreApplication::sendEvent (receiver=<optimized out>, event=<optimized out>) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qcoreapplication.cpp:1583 #13 0x00007f742238ef90 in QCoreApplicationPrivate::sendPostedEvents (receiver=0x0, event_type=0, data=0x555ea71db680) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qcoreapplication.cpp:1940 #14 0x00007f74225c2fe3 in postEventSourceDispatch (s=0x555ea720d770) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qeventdispatcher_glib.cpp:244 #15 0x00007f7421034760 in g_main_dispatch (context=0x7f7418000f00) at ../glib/gmain.c:3344 #16 g_main_context_dispatch_unlocked (context=context@entry=0x7f7418000f00) at ../glib/gmain.c:4152 #17 0x00007f74210363a8 in g_main_context_iterate_unlocked (context=context@entry=0x7f7418000f00, block=block@entry=1, dispatch=dispatch@entry=1, self=<optimized out>) at ../glib/gmain.c:4217 #18 0x00007f7421036a5c in g_main_context_iteration (context=0x7f7418000f00, may_block=1) at ../glib/gmain.c:4282 #19 0x00007f74225c1adc in QEventDispatcherGlib::processEvents (this=0x555ea72234b0, flags=...) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/kernel/qeventdispatcher_glib.cpp:394 #20 0x00007f74223993db in QEventLoop::exec (this=0x7fff76188010, flags=...) at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/global/qflags.h:34 #21 0x00007f7422392bb6 in QCoreApplication::exec () at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/corelib/global/qflags.h:74 #22 0x00007f7422be7e2c in QGuiApplication::exec () at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/gui/kernel/qguiapplication.cpp:1926 #23 0x00007f74245bfff5 in QApplication::exec () at /usr/src/debug/qtbase-everywhere-src-6.7.2/src/widgets/kernel/qapplication.cpp:2555 #24 0x0000555ea02ddb8f in main (argc=<optimized out>, argv=<optimized out>) at /usr/src/debug/plasma-workspace-6.1.3/shell/main.cpp:188 ``` Fixed by https://invent.kde.org/plasma/plasma-workspace/-/commit/fa57f929efb6307103e7d74bcb3c3737decb8a2c *** Bug 490624 has been marked as a duplicate of this bug. *** *** Bug 491086 has been marked as a duplicate of this bug. *** This was supposed to be fixed in Plasma 6.1.4, but https://crash-reports.kde.org/organizations/kde/issues/23450/ hows that we still have crashes in 6.1.3 and 6.1.4. Re-opening. I dont see that. All the .4 crashes are amd driver reset crashes that somehow merged into that issue. I'm on 6.1.4 using Nvidia and I'm still seeing something similar as recently as yesterday. Operating System: openSUSE Tumbleweed 20240829 KDE Plasma Version: 6.1.4 KDE Frameworks Version: 6.5.0 Qt Version: 6.7.2 Kernel Version: 6.9.9-1-default (64-bit) Graphics Platform: X11 Processors: 12 × AMD Ryzen 5 5600 6-Core Processor Memory: 31.3 GiB of RAM Graphics Processor: NVIDIA GeForce GTX 1650 SUPER/PCIe/SSE2 Manufacturer: ASUS #0 0x00007fe243a94c5c in __pthread_kill_implementation () at /lib64/libc.so.6 #1 0x00007fe243a411c6 in raise () at /lib64/libc.so.6 #2 0x00007fe246f36c54 in KCrash::defaultCrashHandler(int) () at /lib64/libKF6Crash.so.6 #3 0x00007fe243a41290 in <signal handler called> () at /lib64/libc.so.6 #4 __gnu_cxx::__atomic_add (__val=1, __mem=0x454545454545454d) at /usr/include/c++/13/ext/atomicity.h:71 #5 __gnu_cxx::__atomic_add_dispatch (__val=1, __mem=0x454545454545454d) at /usr/include/c++/13/ext/atomicity.h:111 #6 std::_Sp_counted_base<(__gnu_cxx::_Lock_policy)2>::_M_add_ref_copy (this=0x4545454545454545) at /usr/include/c++/13/bits/shared_ptr_base.h:152 #7 std::__shared_count<(__gnu_cxx::_Lock_policy)2>::operator= (__r=<optimized out>, this=0x5597f058cd40) at /usr/include/c++/13/bits/shared_ptr_base.h:1088 #8 std::__shared_ptr<AbstractEntry, (__gnu_cxx::_Lock_policy)2>::operator= (this=0x5597f058cd38) at /usr/include/c++/13/bits/shared_ptr_base.h:1523 #9 std::shared_ptr<AbstractEntry>::operator= (this=0x5597f058cd38) at /usr/include/c++/13/bits/shared_ptr.h:414 #10 KAStatsFavoritesModel::Private::addResult (this=this@entry=0x5597eff2b000, _resource=..., index=21, index@entry=-1, notifyModel=notifyModel@entry=false, mimeType=...) at /usr/src/debug/plasma-workspace-6.1.4/applets/kicker/plugin/kastatsfavoritesmodel.cpp:353 #11 0x00007fe1ea9ba3b0 in KAStatsFavoritesModel::Private::Private (this=0x5597eff2b000, parent=<optimized out>, clientId=<optimized out>, this=<optimized out>, parent=<optimized out>, clientId=<optimized out>) at /usr/src/debug/plasma-workspace-6.1.4/applets/kicker/plugin/kastatsfavoritesmodel.cpp:237 #12 0x00007fe1ea9bb455 in KAStatsFavoritesModel::initForClient (this=0x5597f0458f40, clientId=...) at /usr/src/debug/plasma-workspace-6.1.4/applets/kicker/plugin/kastatsfavoritesmodel.cpp:550 #13 0x00007fe1ea99f0f0 in KAStatsFavoritesModel::qt_metacall (this=0x5597f0458f40, _c=QMetaObject::InvokeMetaMethod, _id=16, _a=0x7fffd9a79f28) at /usr/src/debug/plasma-workspace-6.1.4/build/applets/kicker/kickerplugin_autogen/7RBZBFH7CH/moc_kastatsfavoritesmodel.cpp:325 #14 0x00007fe24571da93 in ??? () at /lib64/libQt6Qml.so.6 #15 0x00007fe2456084fb in ??? () at /lib64/libQt6Qml.so.6 #16 0x00007fe24560b271 in QV4::QObjectMethod::callInternal(QV4::Value const*, QV4::Value const*, int) const () at /lib64/libQt6Qml.so.6 #17 0x00007fe24565291f in ??? () at /lib64/libQt6Qml.so.6 #18 0x00007fe24565860a in ??? () at /lib64/libQt6Qml.so.6 #19 0x00007fe2455c33ae in ??? () at /lib64/libQt6Qml.so.6 #20 0x00007fe2455c8d6d in QV4::Function::call(QObject*, void**, QMetaType const*, int, QV4::ExecutionContext*) () at /lib64/libQt6Qml.so.6 #21 0x00007fe2456ebbf5 in QQmlJavaScriptExpression::evaluate(void**, QMetaType const*, int) () at /lib64/libQt6Qml.so.6 #22 0x00007fe24569b02b in QQmlBoundSignalExpression::evaluate(void**) () at /lib64/libQt6Qml.so.6 #23 0x00007fe24569f05b in ??? () at /lib64/libQt6Qml.so.6 #24 0x00007fe245709b28 in QQmlNotifier::emitNotify(QQmlNotifierEndpoint*, void**) () at /lib64/libQt6Qml.so.6 #25 0x00007fe2443e79d8 in ??? () at /lib64/libQt6Core.so.6 #26 0x00007fe245713f26 in QQmlObjectCreator::finalize(QQmlInstantiationInterrupt&) () at /lib64/libQt6Qml.so.6 #27 0x00007fe2456ae5c9 in QQmlComponentPrivate::complete(QQmlEnginePrivate*, QQmlComponentPrivate::ConstructionState*) () at /lib64/libQt6Qml.so.6 #28 0x00007fe2456ae8cc in QQmlComponentPrivate::completeCreate() () at /lib64/libQt6Qml.so.6 #29 0x00007fe24705b713 in PlasmaQuick::SharedQmlEngine::completeInitialization(QHash<QString, QVariant> const&) () at /lib64/libPlasmaQuick.so.6 #30 0x00007fe24703ffd4 in PlasmaQuick::AppletQuickItem::itemForApplet(Plasma::Applet*) () at /lib64/libPlasmaQuick.so.6 #31 0x00007fe24706c9e9 in ??? () at /lib64/libPlasmaQuick.so.6 #32 0x00007fe245713a74 in QQmlObjectCreator::finalize(QQmlInstantiationInterrupt&) () at /lib64/libQt6Qml.so.6 #33 0x00007fe2456ae5c9 in QQmlComponentPrivate::complete(QQmlEnginePrivate*, QQmlComponentPrivate::ConstructionState*) () at /lib64/libQt6Qml.so.6 #34 0x00007fe2456ae8cc in QQmlComponentPrivate::completeCreate() () at /lib64/libQt6Qml.so.6 #35 0x00007fe24705b713 in PlasmaQuick::SharedQmlEngine::completeInitialization(QHash<QString, QVariant> const&) () at /lib64/libPlasmaQuick.so.6 #36 0x00007fe24703ffd4 in PlasmaQuick::AppletQuickItem::itemForApplet(Plasma::Applet*) () at /lib64/libPlasmaQuick.so.6 #37 0x00007fe24705489c in ??? () at /lib64/libPlasmaQuick.so.6 #38 0x00005597d93762af in ShellCorona::createWaitingPanels (this=<optimized out>) at /usr/src/debug/plasma-workspace-6.1.4/shell/shellcorona.cpp:1544 #39 0x00007fe2443e7f90 in ??? () at /lib64/libQt6Core.so.6 #40 0x00007fe2443ec65a in QTimer::timeout(QTimer::QPrivateSignal) () at /lib64/libQt6Core.so.6 #41 0x00007fe2443d1dd6 in QObject::event(QEvent*) () at /lib64/libQt6Core.so.6 #42 0x00007fe2465c2f6e in QApplicationPrivate::notify_helper(QObject*, QEvent*) () at /lib64/libQt6Widgets.so.6 #43 0x00007fe24438ec30 in QCoreApplication::notifyInternal2(QObject*, QEvent*) () at /lib64/libQt6Core.so.6 #44 0x00007fe2444eca5a in QTimerInfoList::activateTimers() () at /lib64/libQt6Core.so.6 --Type <RET> for more, q to quit, c to continue without paging--c #45 0x00007fe2445c2e3c in ??? () at /lib64/libQt6Core.so.6 #46 0x00007fe243033fb8 in ??? () at /lib64/libglib-2.0.so.0 #47 0x00007fe243035d38 in ??? () at /lib64/libglib-2.0.so.0 #48 0x00007fe2430363ec in g_main_context_iteration () at /lib64/libglib-2.0.so.0 #49 0x00007fe2445c1adc in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () at /lib64/libQt6Core.so.6 #50 0x00007fe2443993db in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) () at /lib64/libQt6Core.so.6 #51 0x00007fe244392bb6 in QCoreApplication::exec() () at /lib64/libQt6Core.so.6 #52 0x00005597d9337b8f in main (argc=<optimized out>, argv=<optimized out>) at /usr/src/debug/plasma-workspace-6.1.4/shell/main.cpp:188 Michael thanks for the added report, it is however missing debug symbols, please see https://community.kde.org/Guidelines_and_HOWTOs/Debugging/How_to_create_useful_crash_reports#Retrieving_a_backtrace_using_coredumpctl for info on how to ensure the symbols are installed, thanks. (In reply to Justin Zobel from comment #31) > Michael thanks for the added report, it is however missing debug symbols, > please see > https://community.kde.org/Guidelines_and_HOWTOs/Debugging/ > How_to_create_useful_crash_reports#Retrieving_a_backtrace_using_coredumpctl > for info on how to ensure the symbols are installed, thanks. I got this dump as result of following the coredumpctl instructions and answering use debuginfod in the affirmative. I noted the line numbers such as at /usr/src/debug/plasma-workspace/plasma-workspace-6.0.1/applets/kicker/plugin/kastatsfavoritesmodel.cpp:189 and figured this was what you needed. I am on OpenSUSE TW, so I inferred from the instructions, that using debuginfod was the right way to go. Happy to try something else. Interesting as it should download all required debug symbols, might be worth bringing up with Fedora if they are missing symbols in their debuginfod server. Looks useful enough. It's a different trace though. Best file a new bug report. Thanks. (In reply to Justin Zobel from comment #33) > Interesting as it should download all required debug symbols, might be worth > bringing up with Fedora if they are missing symbols in their debuginfod > server. It was Tumbleweed. I suspect the missing symbols may be because TW has rolled on and debuginfod can no longer find matching downloads for the obsolete packages (total guess however). (In reply to Harald Sitter from comment #34) > Looks useful enough. It's a different trace though. Best file a new bug > report. Thanks. https://bugs.kde.org/show_bug.cgi?id=492560 *** Bug 492560 has been marked as a duplicate of this bug. *** |