Summary: | Plasma keeps crashing upon login | ||
---|---|---|---|
Product: | [Unmaintained] kdelibs | Reporter: | Javier Conti <javier.conti> |
Component: | kshareddatacache | Assignee: | kdelibs bugs <kdelibs-bugs> |
Status: | RESOLVED FIXED | ||
Severity: | crash | CC: | abenson, alpha_one_x86, andreiamenta, asraniel, biasquez, blazevanderpool, consigliog, eduard.czimbalmos, geraldoav, harry_m, i.semenov.kde, jcnengel, jineshkj.projects, jorma.hytonen, kilem86, mpyne, mvasilchuk, naether.markus, nitro89, sfoerster42, strzol |
Priority: | NOR | ||
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | openSUSE | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: |
New crash information added by DrKonqi
Add checking of indicated page index to removeEntry New crash information added by DrKonqi New crash information added by DrKonqi New crash information added by DrKonqi |
Description
Javier Conti
2010-10-10 23:44:26 UTC
Created attachment 52411 [details]
New crash information added by DrKonqi
plasma-desktop (0.3) on KDE Platform 4.5.2 (KDE 4.5.2) using Qt 4.6.3
- What I was doing when the application crashed:
I increased the system date with two hours while the desktop was running.
-- Backtrace (Reduced):
#6 0x00007f562b4796b2 in SharedMemory::removeEntry (this=0x7f56131ad000, index=<value optimized out>) at /var/tmp/portage/kde-base/kdelibs-4.5.2/work/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1160
#7 0x00007f562b47a549 in KSharedDataCache::insert (this=0x7a0550, key=<value optimized out>, data=<value optimized out>) at /var/tmp/portage/kde-base/kdelibs-4.5.2/work/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1269
#8 0x00007f562bccdd3a in KImageCache::insertImage (this=0x7a0550, key=..., image=...) at /var/tmp/portage/kde-base/kdelibs-4.5.2/work/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:86
#9 0x00007f562bcce0c6 in KImageCache::insertPixmap (this=0x7a0550, key=..., pixmap=...) at /var/tmp/portage/kde-base/kdelibs-4.5.2/work/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:105
#10 0x00007f5622a69956 in Plasma::ThemePrivate::scheduledCacheUpdate (this=0x798db0) at /var/tmp/portage/kde-base/kdelibs-4.5.2/work/kdelibs-4.5.2/plasma/theme.cpp:272
The last comment reminded me that I rebooted in Windows, which has the hardware clock in local time, then back to Linux. Probably the clock has been set back to the correct time via NTP when the system was running... so maybe time changes may be the trigger of the problem... Yes, I also have this issue after Windows changes the time. I was wrong in my comment, instead of increasing the time I _decreased_ the time with two hours. (In reply to comment #2) > The last comment reminded me that I rebooted in Windows, which has the hardware > clock in local time, then back to Linux. Probably the clock has been set back > to the correct time via NTP when the system was running... so maybe time > changes may be the trigger of the problem... Michael, we get bug reports about crashes when setting the system time back (such as bug 254082). Could it be related to the shared data cache handling of "last use time"? *** Bug 254111 has been marked as a duplicate of this bug. *** *** Bug 254082 has been marked as a duplicate of this bug. *** It's possible, I would imagine that the "free up in-use items" code doesn't typically have to make it all the way to the end of the list of used entries before finding enough room. I'll take a look into it. Created attachment 52526 [details]
Add checking of indicated page index to removeEntry
So, I've tried taking a look:
I /think/ that the crash in removeEntry is an indication of prior corruption, and not the actual root cause. This is because when removeEntry is called by insert at line 1269, the entry that is being removed has been verified in-use by its useCount having been greater than 0. So, firstPage should be valid at this point in execution. Apparently it is not by the time that removeEntry is called.
This patch fixes that *symptom* by checking the return value (or, it should).
I have been testing on trunk, including various combinations of time resets, and forcing the removeEntry call in question to be performed no matter how lightly loaded the cache is and I cannot reproduce. It might be due to the extra care taken when checking whether locks are acquired, which I will investigate. (However I have heard bug reports for this from a Fedora user even on trunk, although that was SIGFPE and not SIGSEGV).
could you submit this patch to reviewboard.kde.org? here it will just get lost. thank you Created attachment 52614 [details]
New crash information added by DrKonqi
kmix (3.7) on KDE Platform 4.5.2 (KDE 4.5.2) "release 10" using Qt 4.6.3
Why you don't ask for English knowledge in the FIRST Screen of Bugtracker?!
You really beleve, only English speaking People have Problems?
My Problem: last Update from OpenSuSE repo was installed. Now plasma crashed every time.
-- Backtrace (Reduced):
#6 0x00007f45e69e4674 in SharedMemory::removeEntry (this=0x7f45cbd0a000, index=7048) at /usr/src/debug/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1160
#7 0x00007f45e6a7a50f in KSharedDataCache::insert (this=<value optimized out>, key=..., data=...) at /usr/src/debug/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1269
#8 0x00007f45e720c14d in KImageCache::insertImage (this=0x7508c0, key=..., image=...) at /usr/src/debug/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:86
#9 0x00007f45e7320906 in KImageCache::insertPixmap (this=0x7508c0, key=..., pixmap=...) at /usr/src/debug/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:105
#10 0x00007f45ddb94ff5 in Plasma::ThemePrivate::scheduledCacheUpdate (this=0x720930) at /usr/src/debug/kdelibs-4.5.2/plasma/theme.cpp:275
*** Bug 253464 has been marked as a duplicate of this bug. *** Created attachment 52666 [details]
New crash information added by DrKonqi
plasma-desktop (0.3) on KDE Platform 4.5.2 (KDE 4.5.2) using Qt 4.7.0
- What I was doing when the application crashed:
Logged on using KDE. I adjusted the timezone in the previous session from London to Berlin after having done the same under Windows before.
-- Backtrace (Reduced):
#6 0x00007f498e069bb4 in SharedMemory::removeEntry (this=0x7f4974037000, index=2449) at /usr/src/debug/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1160
#7 0x00007f498e0ff92f in KSharedDataCache::insert (this=<value optimized out>, key=..., data=...) at /usr/src/debug/kdelibs-4.5.2/kdecore/util/kshareddatacache.cpp:1269
#8 0x00007f498e8981dd in KImageCache::insertImage (this=0x771f50, key=..., image=...) at /usr/src/debug/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:86
#9 0x00007f498e9a8236 in KImageCache::insertPixmap (this=0x771f50, key=..., pixmap=...) at /usr/src/debug/kdelibs-4.5.2/kdeui/util/kimagecache.cpp:105
#10 0x00007f49853b1f35 in Plasma::ThemePrivate::scheduledCacheUpdate (this=0x76c740) at /usr/src/debug/kdelibs-4.5.2/plasma/theme.cpp:275
*** Bug 254625 has been marked as a duplicate of this bug. *** *** Bug 254176 has been marked as a duplicate of this bug. *** This patch solved the problem for me. Thanks. When it will be in SVN? (In reply to comment #8) > Created an attachment (id=52526) [details] > Add checking of indicated page index to removeEntry > > So, I've tried taking a look: > > I /think/ that the crash in removeEntry is an indication of prior corruption, > and not the actual root cause. This is because when removeEntry is called by > insert at line 1269, the entry that is being removed has been verified in-use > by its useCount having been greater than 0. So, firstPage should be valid at > this point in execution. Apparently it is not by the time that removeEntry is > called. > > This patch fixes that *symptom* by checking the return value (or, it should). > > I have been testing on trunk, including various combinations of time resets, > and forcing the removeEntry call in question to be performed no matter how > lightly loaded the cache is and I cannot reproduce. It might be due to the > extra care taken when checking whether locks are acquired, which I will > investigate. (However I have heard bug reports for this from a Fedora user even > on trunk, although that was SIGFPE and not SIGSEGV). i don't think the patch was ever submitted. i hope this will be done, or else it will get lost. SVN commit 1187997 by mpyne: Add a "valid page" check to KSharedDataCache, which seems to prevent crashing when changing the system time. Adding the check is a good idea anyways, but only solves the symptom of some underlying logic error that I can't reproduce (or understand how it occurs either :P). This applies to trunk (Platform 4.6), I will backport to 4.5.3. CCBUG:253795 M +8 -2 kshareddatacache.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1187997 SVN commit 1187999 by mpyne: Backport a "valid page" check for KSharedDataCache to KDE 4.5.3. This adds additional checks that seem to prevent crashes when changing the system time. This only masks the symptom though, it should be a logic error to be removing a page that is already marked as free in the code paths that could reach the affected function. Either way, it's one less crash. I'll leave the bug open until I feel I've figured out why the underlying cause of the bug when changing system time. As an aside to Beat Wolf, I am just as likely (if not more) to lose patches on ReviewBoard as I am on bugs.kde.org. Adding BugZilla attachments to ReviewBoard isn't necessary for that reason, ReviewBoard should be for things that require actual code review. ;) CCBUG:253795 M +8 -2 kshareddatacache.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1187999 Sorry, i forgot to read your name so i didn't see that you are a actual developer, i thought you where a regular user, and in that case reviewboard is really handy. Thanks for fixing anyway :) *** Bug 255551 has been marked as a duplicate of this bug. *** From bug 255551: "I do not think this is the same bug [...] because this problem happens if and only if I [reboot after using] dual displays." The same here. The plasma desktop crashes in loops when starting KDE 4.5.2 on my Gentoo machine. In Germany (and other European countries) the daylight savings time has been changed back to winter time today at 03:00. When I started my computer this morning, the time on my machine had not been changed. ntp-client was not running and was not configured correctly. Thus I changed my ntp-client settings, started "ntp-client" and restarted "ntpd" while KDE was running. The clock changed back 1 hour. A few seconds later I had the first segmentation fault. I restarted KDE and I even rebooted, but KDE keeps crashing in a loop. Probably a huge number of people had been affected - the patch is urgently needed. Created attachment 53010 [details]
New crash information added by DrKonqi
krunner (0.1) on KDE Platform 4.5.2 (KDE 4.5.2) using Qt 4.7.0
I've the same problem. All kde application (krunner, kwin, plasma etc...) crashes at login.
-- Backtrace (Reduced):
#6 0x00007f8d534933e2 in SharedMemory::removeEntry (this=0x7f8d38f7b000, index=<value optimized out>) at ../../kdecore/util/kshareddatacache.cpp:1160
#7 0x00007f8d534945e3 in KSharedDataCache::insert (this=0x1e99a80, key=<value optimized out>, data=<value optimized out>) at ../../kdecore/util/kshareddatacache.cpp:1269
#8 0x00007f8d5547ef4d in KImageCache::insertImage (this=0x1e99a80, key=..., image=...) at ../../kdeui/util/kimagecache.cpp:86
#9 0x00007f8d5547f336 in KImageCache::insertPixmap (this=0x1e99a80, key=..., pixmap=...) at ../../kdeui/util/kimagecache.cpp:105
#10 0x00007f8d559c5292 in Plasma::ThemePrivate::scheduledCacheUpdate (this=0x1e753c0) at ../../plasma/theme.cpp:272
*** Bug 255717 has been marked as a duplicate of this bug. *** *** Bug 255743 has been marked as a duplicate of this bug. *** *** Bug 255709 has been marked as a duplicate of this bug. *** *** Bug 255719 has been marked as a duplicate of this bug. *** *** Bug 253469 has been marked as a duplicate of this bug. *** *** Bug 256072 has been marked as a duplicate of this bug. *** *** Bug 258740 has been marked as a duplicate of this bug. *** *** Bug 261278 has been marked as a duplicate of this bug. *** SVN commit 1214946 by mpyne: Backport "Fully clear cache metadata in clearInternal()" to 4.6. KSharedDataCache uses the clearInternal() method to reset the cache, which is used if corruption is detected, and when directed through KSharedDataCache::clear(). For whatever reason I thought that simply setting the "first page" pointer for each possible index entry would be sufficient, but that is not the case at all, as various methods which go through the cache entries also check things such as the use count, last access time, etc. Assuming no other errors (:-/) this should be the cause of bug 260309. (The exact sequence would be a KSharedDataCache user runs ::clear(), later adds some entries that invoke removeUsedPages(), and removeUsedPages() goes through *all* index entries, including ones that appear to be in use since their use count is >0, but their first page is still invalid). Easiest way to invoke this bug I've found is to simply run "plasmoidviewer clock" at a konsole. This should fix the annoying bug 260309 just in time for KDE Platform 4.6. I'm CC-ing release team so that there are no surprises, but I have hopefully demonstrated enough of the issue to prove that this patch is at least "more correct" than previous behavior. It is possible that this was also the proximate cause of the Plasma crashes when changing the system time for Daylight Savings (which I worked around with the error message you've been seeing for months), bug 253795. FIXED-IN:4.6 BUG:260309 CCBUG:253795 CCMAIL:release-team@kde.org M +5 -0 kshareddatacache.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1214946 *** Bug 270917 has been marked as a duplicate of this bug. *** Seems like there's no further issues with this particular bug given how quiet it has been -> closing. |