Summary: | Desktop Grid unusable - Only shows the +/- buttons and then becomes unresponsive | ||
---|---|---|---|
Product: | [Plasma] kwin | Reporter: | Vishesh Handa <me> |
Component: | effects-window-management | Assignee: | KWin default assignee <kwin-bugs-null> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | gforce, kde |
Priority: | NOR | ||
Version: | git master | ||
Target Milestone: | --- | ||
Platform: | Compiled Sources | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | 4.8.0 | |
Sentry Crash Report: | |||
Attachments: |
Kwin backtrace
Backtract after calling refresh New crash information added by DrKonqi |
Description
Vishesh Handa
2011-09-21 08:58:20 UTC
sounds like kwin is in some live-lock (eg. the animation does never end?) can you ctrl+alt+f1 (-> VT1); "gdb --pid `pidof kwin`"; "bt" to check where it's hanging around? also: do you use present windows alongside the desktop grid (ie. are the windows arranged on each desktop)? I think this was a problem on my end. Even plasma was crashing occasionally. I did a complete reinstall of KDE - Removed my ~/kde directory (apart from the src), and all the build directories. That seems to have fixed it. Sorry for the noise. If it happens again, I'll reopen the bug, and provide a backtrace. ( Yes, I do use present windows. ) Created attachment 63814 [details]
Kwin backtrace
It seems as though I spoke to soon. It happened again. Seems stuck in Qt's event dispatcher. - Is it Qt 4.8? - How recent is the git master checkout? ("up-to-date"?, is this commit in: https://projects.kde.org/projects/kde/kde-workspace/repository/revisions/562cabc9e76c8af356a68e91147934e80ae4e78b ) - if you "continue" gdb and "bt" again - is it still in the same function? (In reply to comment #5) > Seems stuck in Qt's event dispatcher. > > - Is it Qt 4.8? Nope. Qt 4.7.4-3 from the Arch repositories. If you want I could run Qt trunk. I do have the code. I just find it easier to stick with my distro packages. > - How recent is the git master checkout? ("up-to-date"?, is this commit in: > https://projects.kde.org/projects/kde/kde-workspace/repository/revisions/562cabc9e76c8af356a68e91147934e80ae4e78b > ) It has that commit. My checkout is about 8 hours old. Current head - 0a993565e89b90c621f26c3202d765ccb1f65733 > - if you "continue" gdb and "bt" again - is it still in the same function? It seems to be working again. The moment it occurs, I'll try getting multiple backtraces. Maybe I could even call some dbus methods to check if kwin is responsive. Created attachment 63824 [details]
Backtract after calling refresh
It happened again. I get the same backtrace each time.
I called 'qdbus org.kde.kwin /KWin refresh', and that didn't return for about 30 seconds, until I closed it forcibly ( Ctrl-C ). After that I took another backtrace, which I've attached.
Let me know, I can do anything else to better diagnose this bug.
#0 0x00007f6cfb645563 in poll () from /lib/libc.so.6 #1 0x00007f6cf6bfaba2 in ?? () from /usr/lib/libxcb.so.1 #2 0x00007f6cf6bfc14f in xcb_wait_for_reply () from /usr/lib/libxcb.so.1 #3 0x00007f6d00c89c2d in _XReply () from /usr/lib/libX11.so.6 #4 0x00007f6d00c6da95 in XGetImage () from /usr/lib/libX11.so.6 Seems like the Qt eventloop is open, but the XServer is completely blocked. Trying Qt4.8 is no good idea - probably adds more bugs ;-) What hardware/driver (mesa/nvidia) do you use and also can you check whether this occurs only with the OpenGL or the XRender backend? Anything else (other process, sth. special - please don't ask me ;-) that could perform an XGrabServer on this occasion? Last: in utils.cpp you'll find grabXServer() and ungrabXServer() (or similar) if you'd add qWarning("grabbing x server"); and qWarning("ungrabbing x server"); and start KWin from VT1 ("export DISPLAY=:0; kwin --replace &") you could see whether kwin keeps the server grabbed or not (the last line should always start "unrgabbing"...) Created attachment 64325 [details]
New crash information added by DrKonqi
kwin (4.7.41 (4.7.41 (KDE 4.8 >= 20110807)) on KDE Platform 4.7.41 (4.7.41 (KDE 4.8 >= 20110807) using Qt 4.8.0
Same experience as original poster; Ctrl+F8 to bring up desktop grid with present windows enabled. The mouse pointer changes and +/- icons appear, but the desktop grid does not. The kwin effect keeps focus, forcing an ALT+F1 and kwin --replace which produces the attached backtrace.
Desktop grid used to work fine until very recently. Perhaps a week or two... initially the bug was intermittent. Does not work with "present windows" disabled either. I partly ruled out kwin commit 57f631497d18086db7de6bc4a8331721c53f53e8.
Qt 4.8 repository git://gitorious.org/qt/qt.git at commit: 55ea900361418aed0c23c0f0023a88b022c2b55d
Kwin repository git://anongit.kde.org/kde-workspace at the commit: d17dc35f704e4a7379ac618fb0de8547737eca3b
Have tried various nvidia blobs which I know used to work. Happens both with xorg-server 1.11.1 and 1.10.4. All other kwin opengl effects work fine (present all windows, cube, etc).
-- Backtrace (Reduced):
#11 0x00007f8ec3eec184 in KWin::GLShader::setUniform (this=<optimized out>, location=5, value=<optimized out>) at /usr/src/debug/kde-base/kwin-9999/kwin-9999/kwin/libkwineffects/kwinglutils.cpp:516
#12 0x00007f8ec7439175 in KWin::SceneOpenGL::Window::restoreShaderRenderStates (this=<optimized out>, type=KWin::SceneOpenGL::Window::Content, opacity=<optimized out>, brightness=<optimized out>, saturation=<optimized out>, shader=<optimized out>) at /usr/src/debug/kde-base/kwin-9999/kwin-9999/kwin/scene_opengl.cpp:1046
#13 0x00007f8ec7440b25 in KWin::SceneOpenGL::Window::performPaint (this=0x17adae0, mask=545, region=..., data=<optimized out>) at /usr/src/debug/kde-base/kwin-9999/kwin-9999/kwin/scene_opengl.cpp:595
#14 0x00007f8ec7428cdb in KWin::Scene::finalDrawWindow (this=<optimized out>, w=<optimized out>, mask=545, region=<optimized out>, data=...) at /usr/src/debug/kde-base/kwin-9999/kwin-9999/kwin/scene.cpp:391
#15 0x00007f8ec744ed78 in KWin::EffectsHandlerImpl::drawWindow (this=<optimized out>, w=0x17c45a0, mask=545, region=<optimized out>, data=<optimized out>) at /usr/src/debug/kde-base/kwin-9999/kwin-9999/kwin/effects.cpp:282
After some testing I've narrowed it down to the commit which introduced the issue: bb6d4873259691b189a8b706f9dfc2e858f54609. Desktop Grid works with at commit 5e8be6288cc34702bfabcc730bb1168e1c4e9eee. So the issue lies somewhere in 'git diff bb6d4873259691b189a8b706f9dfc2e858f54609 5e8be6288cc34702bfabcc730bb1168e1c4e9eee'. A closer look at the changes between those two revisions should lead to a fix. Thanks for doing the bisecting and yeah that makes sense. Could you please provide a list of the effects you have activated, so that I can compare with mine as it works for me (I guess there is some sideffect that another effect makes desktop grid work). Hi Martin, The list of effects kwin loads are: "kwin4_effect_zoom" "kwin4_effect_flipswitch" "kwin4_effect_slidingpopups" "kwin4_effect_logout" "kwin4_effect_login" "kwin4_effect_presentwindows" "kwin4_effect_desktopgrid" "kwin4_effect_minimizeanimation" "kwin4_effect_translucency" "kwin4_effect_screenshot" "kwin4_effect_scalein" "kwin4_effect_dashboard" "kwin4_effect_boxswitch" "kwin4_effect_cube" "kwin4_effect_coverswitch" "kwin4_effect_slide" "kwin4_effect_outline" "kwin4_effect_dialogparent" "kwin4_effect_startupfeedback" Hopefully you manage to recreate the issue. I can provide more logs/details, and test any patches. Thanks, Alex. Desktop grid now works again with my configuration. I don't know if it was a commit which resolved the issue or the latest nvidia driver 290.06. This was tested as working with kde-workspace commit f6a3166cf614fffaa95d4fbd1e2bd7fd18491045. *** Bug 286023 has been marked as a duplicate of this bug. *** Git commit a710c2f721fbde954085bc677d3e7babef1b77aa by Martin Gräßlin. Committed on 12/11/2011 at 16:17. Pushed by graesslin into branch 'master'. Fix desktop grid without present windows mode Effect was not marked as active. BUG: 282461 FIXED-IN: 4.8.0 M +1 -1 kwin/effects/desktopgrid/desktopgrid.cpp http://commits.kde.org/kde-workspace/a710c2f721fbde954085bc677d3e7babef1b77aa |