https://bugs.kde.org/show_bug.cgi?id=495160
Bug ID: 495160 Summary: Crash when selecting virtual output Classification: Plasma Product: xdg-desktop-portal-kde Version: unspecified Platform: Other OS: Linux Status: REPORTED Severity: normal Priority: NOR Component: general Assignee: plasma-b...@kde.org Reporter: nicolas.fe...@gmx.de CC: aleix...@kde.org Target Milestone: --- STEPS TO REPRODUCE 1. Start OBS studio 2. Add source > Screen Capture (Pipewire) 3. Click "New virtual output" 4. In the source properties, click "Open Selector" 5. Click "Virtual-Virtual0" OBSERVED RESULT ================================================================= ==59860==ERROR: AddressSanitizer: heap-use-after-free on address 0x5020001e0858 at pc 0x7efcf4161aa1 bp 0x7ffd35a46690 sp 0x7ffd35a46688 READ of size 8 at 0x5020001e0858 thread T0 #0 0x7efcf4161aa0 in QScopedPointer<QObjectData, QScopedPointerDeleter<QObjectData> >::get() const /home/nico/workspace/qt6-dev/qtbase/src/corelib/tools/qscopedpointer.h:112 #1 0x7efcf4161aa0 in decltype (({parm#1}.get)()) qGetPtrHelper<QScopedPointer<QObjectData, QScopedPointerDeleter<QObjectData> > const>(QScopedPointer<QObjectData, QScopedPointerDeleter<QObjectData> > const&) /home/nico/workspace/qt6-dev/qtbase/src/corelib/global/qtclasshelpermacros.h:112 #2 0x7efcf4161aa0 in QScreen::d_func() const /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qscreen.h:34 #3 0x7efcf4161aa0 in QScreen::name() const /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qscreen.cpp:103 #4 0x62efcc in Screencasting::createOutputStream(QScreen*, Screencasting::CursorMode) /home/nico/kde-qtdev/src/xdg-desktop-portal-kde/src/screencasting.cpp:113 #5 0x6c41ea in WaylandIntegration::WaylandIntegrationPrivate::startStreamingOutput(QScreen*, Screencasting::CursorMode) /home/nico/kde-qtdev/src/xdg-desktop-portal-kde/src/waylandintegration.cpp:278 #6 0x6c2db0 in WaylandIntegration::startStreamingOutput(QScreen*, Screencasting::CursorMode) /home/nico/kde-qtdev/src/xdg-desktop-portal-kde/src/waylandintegration.cpp:127 #7 0x624cce in ScreenCastPortal::Start(QDBusObjectPath const&, QDBusObjectPath const&, QString const&, QString const&, QMap<QString, QVariant> const&, QMap<QString, QVariant>&) /home/nico/kde-qtdev/src/xdg-desktop-portal-kde/src/screencast.cpp:225 #8 0x444533 in ScreenCastPortal::qt_static_metacall(QObject*, QMetaObject::Call, int, void**) /home/nico/kde-qtdev/build/xdg-desktop-portal-kde/src/xdg-desktop-portal-kde_autogen/EWIEGA46WW/moc_screencast.cpp:251 #9 0x444f44 in ScreenCastPortal::qt_metacall(QMetaObject::Call, int, void**) /home/nico/kde-qtdev/build/xdg-desktop-portal-kde/src/xdg-desktop-portal-kde_autogen/EWIEGA46WW/moc_screencast.cpp:316 #10 0x7efcf38be3e5 in QDBusConnectionPrivate::deliverCall(QObject*, QDBusMessage const&, QList<QMetaType> const&, int) /home/nico/workspace/qt6-dev/qtbase/src/dbus/qdbusintegrator.cpp:1007 #11 0x7efcf38c66ce in QDBusConnectionPrivate::activateCall(QObject*, QFlags<QDBusConnection::RegisterOption>, QDBusMessage const&) /home/nico/workspace/qt6-dev/qtbase/src/dbus/qdbusintegrator.cpp:916 #12 0x7efcf38c7cc2 in QDBusConnectionPrivate::activateObject(QDBusConnectionPrivate::ObjectTreeNode&, QDBusMessage const&, int) /home/nico/workspace/qt6-dev/qtbase/src/dbus/qdbusintegrator.cpp:1484 #13 0x7efcf38d0923 in QDBusActivateObjectEvent::placeMetaCall(QObject*) /home/nico/workspace/qt6-dev/qtbase/src/dbus/qdbusintegrator.cpp:1604 #14 0x7efcf2aa38ed in QObject::event(QEvent*) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qobject.cpp:1420 #15 0x7efcf5a7aaad in QApplicationPrivate::notify_helper(QObject*, QEvent*) /home/nico/workspace/qt6-dev/qtbase/src/widgets/kernel/qapplication.cpp:3294 #16 0x7efcf5a96958 in QApplication::notify(QObject*, QEvent*) /home/nico/workspace/qt6-dev/qtbase/src/widgets/kernel/qapplication.cpp:3245 #17 0x7efcf29a3a09 in QCoreApplication::notifyInternal2(QObject*, QEvent*) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qcoreapplication.cpp:1124 #18 0x7efcf29a3b7c in QCoreApplication::sendEvent(QObject*, QEvent*) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qcoreapplication.cpp:1568 #19 0x7efcf29a6bf6 in QCoreApplicationPrivate::sendPostedEvents(QObject*, int, QThreadData*) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qcoreapplication.cpp:1923 #20 0x7efcf29a7314 in QCoreApplication::sendPostedEvents(QObject*, int) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qcoreapplication.cpp:1755 #21 0x7efcf32076f9 in postEventSourceDispatch /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qeventdispatcher_glib.cpp:246 #22 0x7efcf2510eb7 in g_main_dispatch ../glib/gmain.c:3357 #23 0x7efcf2510eb7 in g_main_context_dispatch_unlocked ../glib/gmain.c:4208 #24 0x7efcf2512ca7 in g_main_context_iterate_unlocked ../glib/gmain.c:4273 #25 0x7efcf25134bb in g_main_context_iteration ../glib/gmain.c:4338 #26 0x7efcf32059b6 in QEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qeventdispatcher_glib.cpp:399 #27 0x7efcf4f817db in QPAEventDispatcherGlib::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) /home/nico/workspace/qt6-dev/qtbase/src/gui/platform/unix/qeventdispatcher_glib.cpp:89 #28 0x7efcf29c4fc1 in QEventLoop::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qeventloop.cpp:103 #29 0x7efcf29c7208 in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qeventloop.cpp:194 #30 0x7efcf29ae891 in QCoreApplication::exec() /home/nico/workspace/qt6-dev/qtbase/src/corelib/kernel/qcoreapplication.cpp:1469 #31 0x7efcf40266c5 in QGuiApplication::exec() /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qguiapplication.cpp:1975 #32 0x7efcf5a7795e in QApplication::exec() /home/nico/workspace/qt6-dev/qtbase/src/widgets/kernel/qapplication.cpp:2562 #33 0x6d2199 in main /home/nico/kde-qtdev/src/xdg-desktop-portal-kde/src/xdg-desktop-portal-kde.cpp:50 #34 0x7efcf1e2a2ad in __libc_start_call_main ../sysdeps/nptl/libc_start_call_main.h:58 #35 0x7efcf1e2a378 in __libc_start_main_impl ../csu/libc-start.c:360 #36 0x42daf4 in _start ../sysdeps/x86_64/start.S:115 0x5020001e0858 is located 8 bytes inside of 16-byte region [0x5020001e0850,0x5020001e0860) freed by thread T0 here: #0 0x7efd002fe198 in operator delete(void*, unsigned long) ../../../../libsanitizer/asan/asan_new_delete.cpp:164 #1 0x7efcf41671d9 in QScreen::~QScreen() /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qscreen.cpp:77 #2 0x7efcf41b6ecf in QWindowSystemInterface::handleScreenRemoved(QPlatformScreen*) /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qwindowsysteminterface.cpp:781 #3 0x7efcfe2c105f in QtWaylandClient::QWaylandDisplay::registry_global_remove(unsigned int) /home/nico/workspace/qt6-dev/qtwayland/src/client/qwaylanddisplay.cpp:814 #4 0x7efcfe3ab217 in QtWayland::wl_registry::handle_global_remove(void*, wl_registry*, unsigned int) /home/nico/workspace/qt6-dev/qtwayland/src/client/qwayland-wayland.cpp:112 #5 0x7efcffee1971 in ffi_call_unix64 ../src/x86/unix64.S:104 previously allocated by thread T0 here: #0 0x7efd002fd298 in operator new(unsigned long) ../../../../libsanitizer/asan/asan_new_delete.cpp:95 #1 0x7efcf41ba5e2 in QWindowSystemInterface::handleScreenAdded(QPlatformScreen*, bool) /home/nico/workspace/qt6-dev/qtbase/src/gui/kernel/qwindowsysteminterface.cpp:716 #2 0x7efcfe2c586d in QtWaylandClient::QWaylandDisplay::handleScreenInitialized(QtWaylandClient::QWaylandScreen*) /home/nico/workspace/qt6-dev/qtwayland/src/client/qwaylanddisplay.cpp:603 #3 0x7efcfe35466c in QtWaylandClient::QWaylandScreen::maybeInitialize() /home/nico/workspace/qt6-dev/qtwayland/src/client/qwaylandscreen.cpp:81 #4 0x7efcfe354737 in QtWaylandClient::QWaylandScreen::output_done() /home/nico/workspace/qt6-dev/qtwayland/src/client/qwaylandscreen.cpp:321 #5 0x7efcfe3ac3d7 in QtWayland::wl_output::handle_done(void*, wl_output*) /home/nico/workspace/qt6-dev/qtwayland/src/client/qwayland-wayland.cpp:2413 #6 0x7efcffee1971 in ffi_call_unix64 ../src/x86/unix64.S:104 SUMMARY: AddressSanitizer: heap-use-after-free /home/nico/workspace/qt6-dev/qtbase/src/corelib/tools/qscopedpointer.h:112 in QScopedPointer<QObjectData, QScopedPointerDeleter<QObjectData> >::get() const Shadow bytes around the buggy address: 0x5020001e0580: fa fa fd fd fa fa fd fd fa fa fd fa fa fa fd fd 0x5020001e0600: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0680: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0700: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0780: fa fa fd fa fa fa fd fd fa fa fd fa fa fa fd fa =>0x5020001e0800: fa fa fd fd fa fa fd fd fa fa fd[fd]fa fa 00 00 0x5020001e0880: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0900: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0980: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fa 0x5020001e0a00: fa fa fd fa fa fa fd fa fa fa fd fa fa fa fd fd 0x5020001e0a80: fa fa fd fd fa fa fd fd fa fa fd fd fa fa fd fd Shadow byte legend (one shadow byte represents 8 application bytes): Addressable: 00 Partially addressable: 01 02 03 04 05 06 07 Heap left redzone: fa Freed heap region: fd Stack left redzone: f1 Stack mid redzone: f2 Stack right redzone: f3 Stack after return: f5 Stack use after scope: f8 Global redzone: f9 Global init order: f6 Poisoned by user: f7 Container overflow: fc Array cookie: ac Intra object redzone: bb ASan internal: fe Left alloca redzone: ca Right alloca redzone: cb ==59860==ABORTING SOFTWARE/OS VERSIONS KDE Plasma Version: master KDE Frameworks Version: master Qt Version: dev ADDITIONAL INFORMATION -- You are receiving this mail because: You are watching all bug changes.