https://bugs.kde.org/show_bug.cgi?id=467913
Bug ID: 467913 Summary: kwin_wayland crashed in KWin::GLVertexBufferPrivate::interleaveArrays when the cursor was moved to the top-left of the splash screen Classification: Plasma Product: kwin Version: 5.27.3 Platform: Fedora RPMs OS: Linux Status: REPORTED Severity: normal Priority: NOR Component: wayland-generic Assignee: kwin-bugs-n...@kde.org Reporter: matt.fagn...@bell.net Target Milestone: --- Created attachment 157678 --> https://bugs.kde.org/attachment.cgi?id=157678&action=edit Full trace of all threads of kwin_wayland crash SUMMARY I logged in to Plasma 5.27.3 on Wayland in a Fedora 38 KDE Plasma installation. I moved the mouse cursor to the top-left of the screen when the splash screen was shown. The screen went black for a couple seconds with just a text cursor at the top-left. The effect where the splash screen shrinks and a grey blurred border is shown around it wasn't displayed. Plasma started after a few seconds. coredumpctl showed that kwin_wayland crashed in KWin::GLVertexBufferPrivate::interleaveArrays. Core was generated by `/usr/bin/kwin_wayland --wayland-fd 7 --socket wayland-0 --xwayland-fd 8 --xwayl'. Program terminated with signal SIGSEGV, Segmentation fault. #0 0x00007efe4c52e870 in KWin::GLVertexBufferPrivate::interleaveArrays (this=0x5651eaf62390, count=4, texcoords=0x7ffdefec3e30, vertices=0x7ffdefec3e58, dim=<optimized out>, dst=0x4) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/libkwineffects/kwinglutils.cpp:1674 1674 *(dst++) = *(vertices++); (gdb) bt #0 0x00007efe4c52e870 in KWin::GLVertexBufferPrivate::interleaveArrays(float*, int, float const*, float const*, int) (this=0x5651eaf62390, count=4, texcoords=0x7ffdefec3e30, vertices=0x7ffdefec3e58, dim=<optimized out>, dst=0x4) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/libkwineffects/kwinglutils.cpp:1674 #1 KWin::GLVertexBuffer::setData(int, int, float const*, float const*) (this=0x5651eb028160, vertexCount=<optimized out>, dim=<optimized out>, vertices=<optimized out>, texcoords=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/libkwineffects/kwinglutils.cpp:1894 #2 0x00007efe4c52987a in KWin::GLTexture::render(QRegion const&, QRect const&, double, bool) (this=0x5651eaf59520, region=..., rect=<optimized out>, scale=<optimized out>, hardwareClipping=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/libkwineffects/kwingltexture.cpp:546 #3 0x00007efe4c529aae in KWin::GLTexture::render(QRect const&, double) (this=this@entry=0x5651eaf59520, rect=..., scale=scale@entry=1) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/libkwineffects/kwingltexture.cpp:511 #4 0x00007efe4c040f32 in KWin::EffectsHandlerImpl::renderOffscreenQuickView(KWin::OffscreenQuickView*) const (this=0x5651e98374b0, w=0x5651eabce980) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:1793 #5 0x00007efe4c0347a9 in KWin::EffectsHandlerImpl::paintScreen(int, QRegion const&, KWin::ScreenPaintData&) (this=0x5651e98374b0, mask=<optimized out>, region=<optimized out>, data=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:396 #6 0x00007efe4c0347a9 in KWin::EffectsHandlerImpl::paintScreen(int, QRegion const&, KWin::ScreenPaintData&) (this=0x5651e98374b0, mask=<optimized out>, region=<optimized out>, data=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:396 --Type <RET> for more, q to quit, c to continue without paging--c #7 0x00007efe4c0347a9 in KWin::EffectsHandlerImpl::paintScreen(int, QRegion const&, KWin::ScreenPaintData&) (this=0x5651e98374b0, mask=<optimized out>, region=<optimized out>, data=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:396 #8 0x00005651e87b4286 in KWin::ScreenEdgeEffect::paintScreen(int, QRegion const&, KWin::ScreenPaintData&) (this=0x5651ea7bd8d0, mask=<optimized out>, region=<optimized out>, data=...) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects/screenedge/screenedgeeffect.cpp:72 #9 0x00007efe4c0347a9 in KWin::EffectsHandlerImpl::paintScreen(int, QRegion const&, KWin::ScreenPaintData&) (this=0x5651e98374b0, mask=<optimized out>, region=<optimized out>, data=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:396 #10 0x00007efe4c0b6c0a in KWin::WorkspaceScene::paint(KWin::RenderTarget*, QRegion const&) (this=this@entry=0x5651e9b1f2a0, renderTarget=renderTarget@entry=0x7ffdefec42a0, region=...) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/scene/workspacescene.cpp:357 #11 0x00007efe4c0416f8 in KWin::EffectsHandlerImpl::renderScreen(KWin::EffectScreen*) (this=0x5651e98374b0, screen=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects.cpp:1868 #12 0x00005651e87ad999 in operator() (__closure=0x5651ea81f480) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/effects/screentransform/screentransform.cpp:90 #13 QtPrivate::FunctorCall<QtPrivate::IndexesList<>, QtPrivate::List<>, void, KWin::ScreenTransformEffect::addScreen(KWin::EffectScreen*)::<lambda()> >::call (arg=<optimized out>, f=...) at /usr/include/qt5/QtCore/qobjectdefs_impl.h:146 #14 QtPrivate::Functor<KWin::ScreenTransformEffect::addScreen(KWin::EffectScreen*)::<lambda()>, 0>::call<QtPrivate::List<>, void> (arg=<optimized out>, f=...) at /usr/include/qt5/QtCore/qobjectdefs_impl.h:256 #15 QtPrivate::QFunctorSlotObject<KWin::ScreenTransformEffect::addScreen(KWin::EffectScreen*)::<lambda()>, 0, QtPrivate::List<>, void>::impl(int, QtPrivate::QSlotObjectBase *, QObject *, void **, bool *) (which=<optimized out>, this_=0x5651ea81f470, r=<optimized out>, a=<optimized out>, ret=<optimized out>) at /usr/include/qt5/QtCore/qobjectdefs_impl.h:443 #16 0x00007efe4a6e84f1 in QtPrivate::QSlotObjectBase::call(QObject*, void**) (a=0x7ffdefec4480, r=<optimized out>, this=0x5651ea81f470) at ../../include/QtCore/../../src/corelib/kernel/qobjectdefs_impl.h:398 #17 doActivate<false>(QObject*, int, void**) (sender=0x5651e9d668b0, signal_index=7, argv=0x7ffdefec4480) at kernel/qobject.cpp:3923 #18 0x00007efe4a6e84f1 in QtPrivate::QSlotObjectBase::call(QObject*, void**) (a=0x7ffdefec4550, r=<optimized out>, this=0x5651ea730ea0) at ../../include/QtCore/../../src/corelib/kernel/qobjectdefs_impl.h:398 #19 doActivate<false>(QObject*, int, void**) (sender=0x5651e9c901b0, signal_index=8, argv=0x7ffdefec4550) at kernel/qobject.cpp:3923 #20 0x00007efe4c1bd5f3 in KWin::DrmOutput::applyQueuedChanges(KWin::OutputConfiguration const&) (config=..., this=0x5651e9c901b0) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/backends/drm/drm_output.cpp:426 #21 KWin::DrmOutput::applyQueuedChanges(KWin::OutputConfiguration const&) (this=0x5651e9c901b0, config=...) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/backends/drm/drm_output.cpp:421 #22 0x00007efe4c1962c0 in KWin::DrmBackend::applyOutputChanges(KWin::OutputConfiguration const&) (this=<optimized out>, config=...) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/backends/drm/drm_backend.cpp:496 #23 0x00007efe4c13ff5e in KWin::Workspace::applyOutputConfiguration(KWin::OutputConfiguration const&, QVector<KWin::Output*> const&) (this=0x5651e9cbfdc0, config=<optimized out>, outputOrder=...) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/workspace.cpp:520 #24 0x00007efe4c21870d in KWaylandServer::OutputConfigurationV2Interface::kde_output_configuration_v2_apply(QtWaylandServer::kde_output_configuration_v2::Resource*) (this=0x7efe0c0042e0, resource=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/wayland/outputmanagement_v2_interface.cpp:308 #25 0x00007efe4777abe6 in ffi_call_unix64 () at ../src/x86/unix64.S:104 #26 0x00007efe477774bf in ffi_call_int (cif=cif@entry=0x7ffdefec4990, fn=<optimized out>, rvalue=<optimized out>, avalue=<optimized out>, closure=closure@entry=0x0) at ../src/x86/ffi64.c:673 #27 0x00007efe4777a18e in ffi_call (cif=cif@entry=0x7ffdefec4990, fn=<optimized out>, rvalue=rvalue@entry=0x0, avalue=avalue@entry=0x7ffdefec4a60) at ../src/x86/ffi64.c:710 #28 0x00007efe48dfc863 in wl_closure_invoke (closure=closure@entry=0x5651eadac080, target=<optimized out>, target@entry=0x5651eadabda0, opcode=opcode@entry=5, data=<optimized out>, data@entry=0x5651ea9cc7b0, flags=2) at ../src/connection.c:1025 #29 0x00007efe48e00fa4 in wl_client_connection_data (fd=<optimized out>, mask=<optimized out>, data=0x5651ea9cc7b0) at ../src/wayland-server.c:437 #30 0x00007efe48dff812 in wl_event_loop_dispatch (loop=0x5651e97bd840, timeout=<optimized out>) at ../src/event-loop.c:1027 #31 0x00007efe4c1f8279 in KWaylandServer::Display::dispatchEvents() (this=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/wayland/display.cpp:114 #32 0x00007efe4a6e84f1 in QtPrivate::QSlotObjectBase::call(QObject*, void**) (a=0x7ffdefec5090, r=<optimized out>, this=0x5651e9ef1270) at ../../include/QtCore/../../src/corelib/kernel/qobjectdefs_impl.h:398 #33 doActivate<false>(QObject*, int, void**) (sender=0x5651e9ebd8f0, signal_index=3, argv=0x7ffdefec5090) at kernel/qobject.cpp:3923 #34 0x00007efe4a6e3377 in QMetaObject::activate(QObject*, QMetaObject const*, int, void**) (sender=sender@entry=0x5651e9ebd8f0, m=m@entry=0x7efe4a967420 <QSocketNotifier::staticMetaObject>, local_signal_index=local_signal_index@entry=0, argv=argv@entry=0x7ffdefec5090) at kernel/qobject.cpp:3983 #35 0x00007efe4a6eaefd in QSocketNotifier::activated(QSocketDescriptor, QSocketNotifier::Type, QSocketNotifier::QPrivateSignal) (this=this@entry=0x5651e9ebd8f0, _t1=..., _t2=<optimized out>, _t3=...) at .moc/moc_qsocketnotifier.cpp:178 #36 0x00007efe4a6eb76b in QSocketNotifier::event(QEvent*) (this=0x5651e9ebd8f0, e=<optimized out>) at kernel/qsocketnotifier.cpp:302 #37 0x00007efe49daeca5 in QApplicationPrivate::notify_helper(QObject*, QEvent*) (this=<optimized out>, receiver=0x5651e9ebd8f0, e=0x7ffdefec51a0) at kernel/qapplication.cpp:3640 #38 0x00007efe4a6b3bd8 in QCoreApplication::notifyInternal2(QObject*, QEvent*) (receiver=0x5651e9ebd8f0, event=0x7ffdefec51a0) at kernel/qcoreapplication.cpp:1064 #39 0x00007efe4a6b3df2 in QCoreApplication::sendEvent(QObject*, QEvent*) (receiver=<optimized out>, event=<optimized out>) at kernel/qcoreapplication.cpp:1462 #40 0x00007efe4a70385f in QEventDispatcherUNIXPrivate::activateSocketNotifiers() (this=this@entry=0x5651e97891b0) at kernel/qeventdispatcher_unix.cpp:304 #41 0x00007efe4a703be0 in QEventDispatcherUNIX::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) (this=<optimized out>, flags=...) at kernel/qeventdispatcher_unix.cpp:511 #42 0x00005651e88501e2 in QUnixEventDispatcherQPA::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () #43 0x00007efe4a6b25ab in QEventLoop::exec(QFlags<QEventLoop::ProcessEventsFlag>) (this=this@entry=0x7ffdefec5340, flags=..., flags@entry=...) at ../../include/QtCore/../../src/corelib/global/qflags.h:69 #44 0x00007efe4a6ba82b in QCoreApplication::exec() () at ../../include/QtCore/../../src/corelib/global/qflags.h:121 #45 0x00007efe4ab5f61d in QGuiApplication::exec() () at kernel/qguiapplication.cpp:1863 #46 0x00007efe49daec19 in QApplication::exec() () at kernel/qapplication.cpp:2832 #47 0x00005651e876ad44 in main(int, char**) (argc=<optimized out>, argv=<optimized out>) at /usr/src/debug/kwin-5.27.3-2.fc38.x86_64/src/main_wayland.cpp:628 dst=0x4 was incremented and used as a pointer. vertices pointed to an address that had a null value and was incremented and used as a pointer. (gdb) p vertices $1 = (const float *) 0x7ffdefec3e58 (gdb) p *vertices $2 = 0 (gdb) x 0x7ffdefec3e58 0x7ffdefec3e58: 0x00000000 (gdb) p dst $3 = (float *) 0x4 (gdb) p *dst Cannot access memory at address 0x4 I'm attaching the full trace of all threads. The problem happened 1/5 times when I moved the cursor to the top-left of the splash screen and might involve a race condition. The journal showed that other KDE programs failed after the kwin_wayland crash and Plasma was automatically restarted. STEPS TO REPRODUCE 1. Boot a Fedora 38 KDE Plasma installation updated to 2023-3-28 with updates-testing repo enabled 2. Log in to Plasma 5.27.3 on Wayland from sddm on Wayland 3. Move the cursor to the top-left of the screen when the splash screen is shown 4. If the problem didn't happen, log out of Plasma and repeated 2-3 until it does OBSERVED RESULT kwin_wayland crashed in KWin::GLVertexBufferPrivate::interleaveArrays when the cursor was moved to the top-left of the splash screen EXPECTED RESULT No crash would happen. SOFTWARE/OS VERSIONS Linux/KDE Plasma: Fedora 38 (available in About System) KDE Plasma Version: 5.27.3 KDE Frameworks Version: 5.104.0 Qt Version: 5.15.8 ADDITIONAL INFORMATION -- You are receiving this mail because: You are watching all bug changes.