https://bugs.kde.org/show_bug.cgi?id=489764
Matt Fagnani <matt.fagn...@bell.net> changed: What |Removed |Added ---------------------------------------------------------------------------- Summary|kwin_wayland crashed in |kwin_wayland crashed in |convert_ubyte_rgba_to_bgra |convert_ubyte_rgba_to_bgra | |when clicking on Konsole's | |icon in the task manager | |such that the wallpaper was | |shown --- Comment #1 from Matt Fagnani <matt.fagn...@bell.net> --- I reproduced this problem four times. I started as I described. When I clicked on the Konsole icon in the task manager and Konsole disappeared and the wallpaper was shown, kwin_wayland crashed sometimes with the kind of trace I reported. Clicking on the Konsole icon about 12 times was the most it took for the crash to happen. The following is the trace from coredumpctl gdb with debuginfo packages installed manually. 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 0x00007fd5ec8bee21 in convert_ubyte_rgba_to_bgra (width=<optimized out>, height=<optimized out>, src=<optimized out>, src_stride=5464, dst=<optimized out>, dst_stride=5464) at ../src/mesa/main/format_utils.c:219 219 ((s[i] & 0xff000000ff) << 16) | [Current thread is 1 (Thread 0x7fd6067fbb40 (LWP 1782))] (gdb) bt #0 0x00007fd5ec8bee21 in convert_ubyte_rgba_to_bgra (width=<optimized out>, height=<optimized out>, src=<optimized out>, src_stride=5464, dst=<optimized out>, dst_stride=5464) at ../src/mesa/main/format_utils.c:219 #1 0x00007fd5ec96f144 in get_tex_rgba_uncompressed (ctx=<optimized out>, dimensions=<optimized out>, xoffset=<optimized out>, yoffset=<optimized out>, zoffset=<optimized out>, width=1366, height=608, depth=<optimized out>, format=<optimized out>, type=<optimized out>, pixels=<optimized out>, texImage=<optimized out>, transferOps=<optimized out>) at ../src/mesa/main/texgetimage.c:549 #2 get_tex_rgba (ctx=<optimized out>, dimensions=<optimized out>, xoffset=<optimized out>, yoffset=<optimized out>, zoffset=<optimized out>, width=1366, height=608, depth=<optimized out>, format=<optimized out>, type=<optimized out>, pixels=<optimized out>, texImage=<optimized out>) at ../src/mesa/main/texgetimage.c:605 #3 _mesa_GetTexSubImage_sw (ctx=ctx@entry=0x7fd5e0176010, xoffset=xoffset@entry=0, yoffset=<optimized out>, yoffset@entry=0, zoffset=<optimized out>, zoffset@entry=0, width=width@entry=1366, height=<optimized out>, height@entry=608, depth=<optimized out>, format=<optimized out>, type=<optimized out>, pixels=<optimized out>, texImage=<optimized out>) at ../src/mesa/main/texgetimage.c:760 #4 0x00007fd5ec701a6c in st_GetTexSubImage (ctx=ctx@entry=0x7fd5e0176010, xoffset=xoffset@entry=0, yoffset=yoffset@entry=0, zoffset=zoffset@entry=0, width=width@entry=1366, height=height@entry=608, depth=1, format=32993, type=5121, pixels=0x7fd5b6fc2000, texImage=0x55e77350f920) at ../src/mesa/state_tracker/st_cb_texture.c:2733 #5 0x00007fd5ec96e4e9 in get_texture_image (ctx=0x7fd5e0176010, texObj=0x55e773616b20, target=<optimized out>, level=<optimized out>, xoffset=<optimized out>, yoffset=<optimized out>, zoffset=<optimized out>, width=<optimized out>, height=<optimized out>, depth=<optimized out>, format=<optimized out>, type=<optimized out>, pixels=<optimized out>, caller=<optimized out>) at ../src/mesa/main/texgetimage.c:1441 #6 0x00007fd5ec96e6ba in _get_texture_image (ctx=0x7fd5e0176010, texObj=0x55e773616b20, texObj@entry=0x0, target=3553, level=0, format=32993, type=5121, bufSize=2147483647, pixels=0x7fd5b6fc2000, caller=0x7fd5ede88637 "glGetTexImage") at ../src/mesa/main/texgetimage.c:1479 #7 0x00007fd5ec96fc36 in _mesa_GetTexImage (target=<optimized out>, level=<optimized out>, format=<optimized out>, type=<optimized out>, pixels=<optimized out>) at ../src/mesa/main/texgetimage.c:1514 #8 0x00007fd5e7fc06a0 in KWin::doGrabTexture (texture=texture@entry=0x55e773619fd0, target=target@entry=0x55e7734ef1e8) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/src/plugins/screencast/screencastutils.h:65 #9 0x00007fd5e7fc5a3a in KWin::grabTexture (texture=0x55e773619fd0, target=0x55e7734ef1e8) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/src/plugins/screencast/screencastutils.h:81 #10 0x00007fd5e7fcd681 in KWin::WindowScreenCastSource::render (this=this@entry=0x55e7735fe840, target=0x55e7734ef1e8) at /usr/include/c++/14/bits/unique_ptr.h:193 #11 0x00007fd5e7fcc572 in KWin::ScreenCastStream::recordFrame (this=0x55e7734ddd40, damage=..., contents=...) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/src/plugins/screencast/screencaststream.cpp:523 #12 0x00007fd6043fc7f2 in QtPrivate::QSlotObjectBase::call (this=0x55e7734bb480, r=<optimized out>, a=0x7fff38bc1c10) --Type <RET> for more, q to quit, c to continue without paging--c at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobjectdefs_impl.h:469 #13 doActivate<false> (sender=0x55e7735fe840, signal_index=3, argv=0x7fff38bc1c10) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobject.cpp:4086 #14 0x00007fd6043f2ac7 in QMetaObject::activate (sender=sender@entry=0x55e7735fe840, m=<optimized out>, local_signal_index=local_signal_index@entry=0, argv=argv@entry=0x7fff38bc1c10) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobject.cpp:4146 #15 0x00007fd5e7fcd138 in KWin::ScreenCastSource::frame (this=0x55e7735fe840, _t1=...) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/redhat-linux-build/src/plugins/screencast/screencast_autogen/include/moc_screencastsource.cpp:154 #16 operator() (__closure=<optimized out>) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/src/plugins/screencast/windowscreencastsource.cpp:33 #17 QtPrivate::FunctorCall<QtPrivate::IndexesList<>, QtPrivate::List<>, void, KWin::WindowScreenCastSource::WindowScreenCastSource(KWin::Window*, QObject*)::<lambda()> >::call (f=..., arg=<optimized out>) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:137 #18 QtPrivate::FunctorCallable<KWin::WindowScreenCastSource::WindowScreenCastSource(KWin::Window*, QObject*)::<lambda()> >::call<QtPrivate::List<>, void> (f=..., arg=<optimized out>) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:345 #19 QtPrivate::QCallableObject<KWin::WindowScreenCastSource::WindowScreenCastSource(KWin::Window*, QObject*)::<lambda()>, QtPrivate::List<>, void>::impl(int, QtPrivate::QSlotObjectBase *, QObject *, void **, bool *) (which=<optimized out>, this_=<optimized out>, r=<optimized out>, a=<optimized out>, ret=<optimized out>) at /usr/include/qt6/QtCore/qobjectdefs_impl.h:555 #20 0x00007fd6043fc7f2 in QtPrivate::QSlotObjectBase::call (this=0x55e772cceb00, r=<optimized out>, a=0x7fff38bc1d40) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobjectdefs_impl.h:469 #21 doActivate<false> (sender=0x55e7735fe860, signal_index=3, argv=0x7fff38bc1d40) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobject.cpp:4086 #22 0x00007fd6043f2ac7 in QMetaObject::activate (sender=<optimized out>, m=m@entry=0x7fd60488b080, local_signal_index=local_signal_index@entry=0, argv=argv@entry=0x7fff38bc1d40) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobject.cpp:4146 #23 0x00007fd60440bb3d in QTimer::timeout (this=<optimized out>, _t1=...) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/redhat-linux-build/src/corelib/Core_autogen/include/moc_qtimer.cpp:224 #24 0x00007fd6043edc5f in QObject::event (this=0x55e7735fe860, e=0x7fff38bc1ef0) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qobject.cpp:1482 #25 0x00007fd60598b218 in QApplicationPrivate::notify_helper(QObject*, QEvent*) () from /lib64/libQt6Widgets.so.6 #26 0x00007fd604396d48 in QCoreApplication::notifyInternal2 (receiver=0x55e7735fe860, event=0x7fff38bc1ef0) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qcoreapplication.cpp:1142 #27 0x00007fd604396fad in QCoreApplication::sendEvent (receiver=<optimized out>, event=<optimized out>) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qcoreapplication.cpp:1583 #28 0x00007fd604552947 in QTimerInfoList::activateTimers (this=this@entry=0x55e771e9c4c8) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qtimerinfo_unix.cpp:434 #29 0x00007fd604554cc0 in QEventDispatcherUNIXPrivate::activateTimers (this=this@entry=0x55e771e9c3f0) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qeventdispatcher_unix.cpp:196 #30 0x00007fd604556f1b in QEventDispatcherUNIX::processEvents (this=<optimized out>, flags=...) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/kernel/qeventdispatcher_unix.cpp:472 #31 0x00007fd605163392 in QUnixEventDispatcherQPA::processEvents(QFlags<QEventLoop::ProcessEventsFlag>) () from /lib64/libQt6Gui.so.6 #32 0x00007fd6043a3a83 in QEventLoop::exec (this=this@entry=0x7fff38bc20c0, flags=..., flags@entry=...) at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/global/qflags.h:34 #33 0x00007fd60439f93c in QCoreApplication::exec () at /usr/src/debug/qt6-qtbase-6.7.2-2.fc41.x86_64/src/corelib/global/qflags.h:74 #34 0x000055e74363f3d1 in main (argc=<optimized out>, argv=<optimized out>) at /usr/src/debug/kwin-6.1.1.2-1.fc41.x86_64/src/main_wayland.cpp:641 There might be a race condition. The texture image in the trace might be the wallpaper as the crash seemed to happen when clicking on the Konsole icon when Konsole was shown so that it disappeared and the wallpaper was shown, but not vice versa. -- You are receiving this mail because: You are watching all bug changes.