Summary: | Kbuildsycoca4 crashes because of mime problems (null KSycocaEntry::offset, KBuildMimeTypeFactory::savePatternLists, KBuildMimeTypeFactory::save) | ||
---|---|---|---|
Product: | [Unmaintained] kdelibs | Reporter: | Andras Fabian <andras.fabian> |
Component: | ksycoca | Assignee: | David Faure <faure> |
Status: | RESOLVED FIXED | ||
Severity: | crash | CC: | andresbajotierra, bjoern, bleamz, eztenia, kde, locketine, lordofalways, mjd, mrl586, nofxgilles, nuclearandy, spam, tburdge222, tryagainprod, vnieto, Wintervenom, zdenek.zikan |
Priority: | NOR | ||
Version: | unspecified | ||
Target Milestone: | --- | ||
Platform: | Unlisted Binaries | ||
OS: | Linux | ||
Latest Commit: | Version Fixed In: | ||
Sentry Crash Report: | |||
Attachments: | mime globs file |
Description
Andras Fabian
2009-08-06 22:15:01 UTC
Created attachment 35937 [details]
mime globs file
This is the globs file which I had in mime folder. But as I told in first bug report, the crash even occurred when I emptied the file.
The backtrace looks related to bug 199300. Thanks *** Bug 203322 has been marked as a duplicate of this bug. *** *** Bug 205120 has been marked as a duplicate of this bug. *** *** Bug 205844 has been marked as a duplicate of this bug. *** Tested against Debian 4.3.1 Sid. Application that crashed: kbuildsycoca4 Version of the application: 1.1 KDE Version: 4.3.1 (KDE 4.3.1) Qt Version: 4.5.2 Operating System: Linux 2.6.30-1-amd64 x86_64 Distribution: Debian GNU/Linux unstable (sid) -- Backtrace: Application: KBuildSycoca (kdeinit4), signal: Segmentation fault [KCrash Handler] #5 KSycocaEntry::offset (this=0x0) at ../../kdecore/sycoca/ksycocaentry.cpp:132 #6 0x00007fb51425094d in KBuildMimeTypeFactory::savePatternLists (this=0x1c75b10, str=...) at ../../kded/kbuildmimetypefactory.cpp:361 #7 0x00007fb514250df3 in KBuildMimeTypeFactory::save (this=0x1c75b10, str=...) at ../../kded/kbuildmimetypefactory.cpp:307 #8 0x00007fb514249d21 in KBuildSycoca::save (this=0x29514f0, str=0x1c03610) at ../../kded/kbuildsycoca.cpp:525 #9 0x00007fb51424bee5 in KBuildSycoca::recreate (this=0x29514f0) at ../../kded/kbuildsycoca.cpp:433 #10 0x00007fb51424dd4b in kdemain (argc=2, argv=0x1b6e9f0) at ../../kded/kbuildsycoca.cpp:829 #11 0x0000000000407264 in launch (argc=2, _name=0x1b6ed28 "/usr/bin/kbuildsycoca4", args=<value optimized out>, cwd=0x0, envc=1, envs=0x1b6ed61 "", reset_env=false, tty=0x0, avoid_loops=false, startup_id_str=0x1b6ed6a "horus;1251932503;200066;8876_TIME0") at ../../kinit/kinit.cpp:677 #12 0x0000000000407a28 in handle_launcher_request (sock=8, who=<value optimized out>) at ../../kinit/kinit.cpp:1169 #13 0x0000000000407fae in handle_requests (waitForPid=8875) at ../../kinit/kinit.cpp:1362 #14 0x00000000004089ff in main (argc=2, argv=0x7fff062f0fb8, envp=0x7fff062f0fd0) at ../../kinit/kinit.cpp:1745 Note: Removed all reference to blob, even move the mime folder to a hidden copy and nothing has prevented this crash report from reappearing as two copies. *** Bug 209701 has been marked as a duplicate of this bug. *** *** Bug 212376 has been marked as a duplicate of this bug. *** *** Bug 199300 has been marked as a duplicate of this bug. *** *** Bug 214419 has been marked as a duplicate of this bug. *** *** Bug 215577 has been marked as a duplicate of this bug. *** *** Bug 199748 has been marked as a duplicate of this bug. *** This bug is no easy to reproduce. Obviously the segfault happens when the mime types are written out to the globs file. Can someone who can reproduce this bug attach an archive containing his whole .local directory? Without it is hardly possible to find out what actually goes wrong. No, the crash is while saving mimetypes to the ksycoca4 file. The globs file is written by update-mime-database and is only read by kbuildsycoca4. Anyway, yes, a zip of ~/.local could help. Of course it could also depend on the contents of /usr/share/mime... SVN commit 1056651 by nlecureuil: Fix crash in kbuildsycoca and add kDebug() to have more infos about this bug CCBUG:202871 M +5 -0 kbuildmimetypefactory.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1056651 please try with latest kdelibs and give here the lines with MIMETYPE NOT FOUND: when doing kbuildsycoca4 SVN commit 1056795 by nlecureuil: Use kFatal instead of kDebug to catch the bug CCBUG:202871 M +1 -1 kbuildmimetypefactory.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1056795 I found the cause for this: missing +x permissions in some subfolders of /usr/share/mime, like /usr/share/mime/interface. What is your version of shared-mime-info? These subdirs are created by update-mime-database. You can find its version with "update-mime-database -v". I'm looking at whether the crash is fixable, but a directory with +r and without +x permission is quite unusual and weird... SVN commit 1057320 by dfaure: Fix crash when a mimetype was detected (during directory listing) but isn't found again by name later on (stat() fails, e.g. because it was removed meanwhile, or because the directory doesn't have +x permissions for some still unknown reason). I believe the real bug is in update-mime-database. Fixed for: 4.4.0-beta2 CCBUG: 202871 M +10 -6 kbuildmimetypefactory.cpp WebSVN link: http://websvn.kde.org/?view=rev&revision=1057320 Also, what's your umask? (just type umask in a terminal). I just checked update-mime-database and it simply says "mkdir(media, 0755)", and always has. So I don't see how one could end up with subdirs without +x... *** Bug 219494 has been marked as a duplicate of this bug. *** *** Bug 219550 has been marked as a duplicate of this bug. *** So, everyone with the savePatternLists/this=0x0 bug, can you type umask in a terminal and see what you get? It should be 022 or 002. Anything else looks very buggy, please find out what sets the umask to a wrong value... /usr/share/mime/ umask reads: 0022 /usr/share/mime/interface/ umask reads: 0022 i get this lain@LainIwakura:~$ umask 0022 Marc: umask is a user setting, doesn't depend on which directory you are in. 0022 looks ok. What are the permissions of /usr/share/mime/interface? Any sub-directory in ~/.local/share/mime that doesn't have 'x' in the 4th column (user permissions)? I know umask is a user setting. I was just being redundant. At any rate chmod for .local/settings/mime are 700 and for the following subdirectories: packages 700 video 755 text 755 model 755 image 755 audio 755 application 755 for overkill, mime.cache is 644 7xx is fine and shouldn't have led to the crash. Maybe it's one of the /usr/share/mime subdirectories that doesn't have +x for your user? There has to be a reason it crashed, and up to now the only reason I found was un-listable directories. There are no subdirectories I've listed sourced below the paths I cited above with 7xx. However, there are now two source globs: -rw-r--r-- 1 mdriftmeyer mdriftmeyer 937 Dec 22 10:10 globs2 -rw-r--r-- 1 mdriftmeyer mdriftmeyer 844 Dec 22 10:10 globs globs2 # This file was automatically generated by the # update-mime-database command. DO NOT EDIT! 50:image/sun-raster:*.rs 50:application/x-skype:*.skype 50:audio/annodex:*.axa 50:application/mathematica:*.nb 50:video/x-mpeg2:*.mp2ve 50:video/x-ms-wax:*.wva 50:application/adrift:*.amf 50:audio/x-amf:*.amf 50:application/mathematica:*.m 50:video/anim:*.anim 50:application/x-squeak-object:*.sqo 50:application/mathematicaplayer:*.nbp 50:application/x-ms-wmp:*.wmp 50:video/x-ms-wmp:*.wmp 50:application/mpeg4-iod:*.mpg4 50:application/mpeg4-muxcodetable:*.mpg4 50:audio/mpeg4:*.mpg4 50:video/mpeg4:*.mpg4 50:application/x-ms-wms:*.wms 50:application/x-squeak-source:*.sts 50:application/x-silverlight:*.scr 50:audio/168sv:*.16sv 50:audio/x-16sv:*.16sv 50:video/annodex:*.axv 50:application/annodex:*.anx 50:audio/3gpp2:*.3gpp2 50:video/3gpp2:*.3gpp2 50:video/x-mpeg2:*.mpv2 50:audio/8svx:*.8svx 50:audio/x-8svx:*.8svx 50:audio/x-mpeg:*.mpega globs # This file was automatically generated by the # update-mime-database command. DO NOT EDIT! image/sun-raster:*.rs application/x-skype:*.skype audio/annodex:*.axa application/mathematica:*.nb video/x-mpeg2:*.mp2ve video/x-ms-wax:*.wva application/adrift:*.amf audio/x-amf:*.amf application/mathematica:*.m video/anim:*.anim application/x-squeak-object:*.sqo application/mathematicaplayer:*.nbp application/x-ms-wmp:*.wmp video/x-ms-wmp:*.wmp application/mpeg4-iod:*.mpg4 application/mpeg4-muxcodetable:*.mpg4 audio/mpeg4:*.mpg4 video/mpeg4:*.mpg4 application/x-ms-wms:*.wms application/x-squeak-source:*.sts application/x-silverlight:*.scr audio/168sv:*.16sv audio/x-16sv:*.16sv video/annodex:*.axv application/annodex:*.anx audio/3gpp2:*.3gpp2 video/3gpp2:*.3gpp2 video/x-mpeg2:*.mpv2 audio/8svx:*.8svx audio/x-8svx:*.8svx audio/x-mpeg:*.mpega I'm clearly in the dark as to how the mime data pool of information gets touched via their xml files and how Debian does it. Current content of .~/.local/share/mime drwx------ 2 mdriftmeyer mdriftmeyer 12K Dec 4 09:09 packages -rw-r--r-- 1 mdriftmeyer mdriftmeyer 0 Dec 22 10:10 XMLnamespaces drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 video -rw-r--r-- 1 mdriftmeyer mdriftmeyer 2.6K Dec 22 10:10 types -rw-r--r-- 1 mdriftmeyer mdriftmeyer 16 Dec 22 10:10 treemagic drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 text -rw-r--r-- 1 mdriftmeyer mdriftmeyer 0 Dec 22 10:10 subclasses drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 model -rw-r--r-- 1 mdriftmeyer mdriftmeyer 2.8K Dec 22 10:10 mime.cache -rw-r--r-- 1 mdriftmeyer mdriftmeyer 12 Dec 22 10:10 magic drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 image -rw-r--r-- 1 mdriftmeyer mdriftmeyer 178 Dec 22 10:10 icons -rw-r--r-- 1 mdriftmeyer mdriftmeyer 937 Dec 22 10:10 globs2 -rw-r--r-- 1 mdriftmeyer mdriftmeyer 844 Dec 22 10:10 globs -rw-r--r-- 1 mdriftmeyer mdriftmeyer 0 Dec 22 10:10 generic-icons drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 audio drwxr-xr-x 2 mdriftmeyer mdriftmeyer 4.0K Dec 22 10:10 application -rw-r--r-- 1 mdriftmeyer mdriftmeyer 0 Dec 22 10:10 aliases every file underneath their respective folders are 644 xml files. *** Bug 221873 has been marked as a duplicate of this bug. *** *** Bug 221874 has been marked as a duplicate of this bug. *** *** Bug 221924 has been marked as a duplicate of this bug. *** *** Bug 222224 has been marked as a duplicate of this bug. *** Fix backported for 4.3.5. I still don't understand why it was crashing for people with a correct umask (user-readable subdirs) though. Maybe a race condition, stuff being regenerated by update-mime-database while kbuildsycoca4 was running. Anyway, please shout if you're still getting the crash with 4.3.5 or later. Or if some mimetypes are suddenly unknown at random points in time... *** Bug 224124 has been marked as a duplicate of this bug. *** *** Bug 224251 has been marked as a duplicate of this bug. *** *** Bug 228379 has been marked as a duplicate of this bug. *** *** Bug 229094 has been marked as a duplicate of this bug. *** Looks fixed, it didn't happen again after 4.4. |