Bug 438047 - 4.2.9 Segfault in IccColorProfile::operator== on Exherbo
Summary: 4.2.9 Segfault in IccColorProfile::operator== on Exherbo
Status: RESOLVED FIXED
Alias: None
Product: krita
Classification: Applications
Component: Color models (show other bugs)
Version: unspecified
Platform: Exherbo Linux
: NOR crash
Target Milestone: ---
Assignee: Krita Bugs
URL:
Keywords:
Depends on:
Blocks:
 
Reported: 2021-06-03 17:04 UTC by Grissess
Modified: 2021-06-03 18:38 UTC (History)
2 users (show)

See Also:
Latest Commit:
Version Fixed In:
Sentry Crash Report:


Attachments

Note You need to log in before you can comment on or make changes to this bug.
Description Grissess 2021-06-03 17:04:20 UTC
SUMMARY

Krita 4.2.9 segfaults when saving an image, only if another reference file [which presumably has its own color profile information, or causes it to load] is not opened first. More information in the backtrace:

```
Thread 25 "Thread (pooled)" received signal SIGSEGV, Segmentation fault.
[Switching to Thread 0x7fffd2ffd640 (LWP 13926)]
0x00007ffff4849e0d in __dynamic_cast () from /usr/x86_64-pc-linux-gnu/lib/libstdc++.so.6
(gdb) bt
#0  0x00007ffff4849e0d in __dynamic_cast () from /usr/x86_64-pc-linux-gnu/lib/libstdc++.so.6
#1  0x00007fffde3d2c2c in IccColorProfile::operator==(KoColorProfile const&) const () from /usr/x86_64-pc-linux-gnu/lib/kritaplugins/kritalcmsengine.so
#2  0x00007ffff6f1de6c in KisPNGConverter::buildFile(QIODevice*, QRect const&, double, double, KisSharedPtr<KisPaintDevice>, QTypedArrayData<KisSharedPtr<KisAnnotation> >::iterator, QTypedArrayData<KisSharedPtr<KisAnnotation> >::iterator, KisPNGOptions, KisMetaData::Store*) () from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#3  0x00007ffff6f21493 in KisPNGConverter::saveDeviceToStore(QString const&, QRect const&, double, double, KisSharedPtr<KisPaintDevice>, KoStore*, KisMetaData::Store*)
    () from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#4  0x00007fffad48f00c in KisKraSaver::saveBinaryData(KoStore*, KisSharedPtr<KisImage>, QString const&, bool, bool) ()
   from /usr/x86_64-pc-linux-gnu/lib/libkritalibkra.so.18
#5  0x00007fffad1fa523 in KraConverter::buildFile(QIODevice*, QString const&) () from /usr/x86_64-pc-linux-gnu/lib/kritaplugins/kritakraexport.so
#6  0x00007fffad1f510a in KraExport::convert(KisDocument*, QIODevice*, KisPinnedSharedPtr<KisPropertiesConfiguration>) ()
   from /usr/x86_64-pc-linux-gnu/lib/kritaplugins/kritakraexport.so
#7  0x00007ffff70f5a61 in KisImportExportManager::doExportImpl(QString const&, QSharedPointer<KisImportExportFilter>, KisPinnedSharedPtr<KisPropertiesConfiguration>) ()
   from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#8  0x00007ffff70f5e8e in KisImportExportManager::doExport(QString const&, QSharedPointer<KisImportExportFilter>, KisPinnedSharedPtr<KisPropertiesConfiguration>, bool)
    () from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#9  0x00007ffff70f93f6 in QtConcurrent::StoredFunctorCall0<KisImportExportErrorCode, std::_Bind<KisImportExportErrorCode (KisImportExportManager::*(KisImportExportManager*, QString, QSharedPointer<KisImportExportFilter>, KisPinnedSharedPtr<KisPropertiesConfiguration>, bool))(QString const&, QSharedPointer<KisImportExportFilter>, KisPinnedSharedPtr<KisPropertiesConfiguration>, bool)> >::runFunctor() () from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#10 0x00007ffff70f9071 in QtConcurrent::RunFunctionTask<KisImportExportErrorCode>::run() () from /usr/x86_64-pc-linux-gnu/lib/libkritaui.so.18
#11 0x00007ffff4a55512 in QThreadPoolThread::run() () from /usr/x86_64-pc-linux-gnu/lib/libQt5Core.so.5
#12 0x00007ffff4a52490 in QThreadPrivate::start(void*) () from /usr/x86_64-pc-linux-gnu/lib/libQt5Core.so.5
#13 0x00007ffff2c7f396 in start_thread () from /usr/x86_64-pc-linux-gnu/lib/libpthread.so.0
#14 0x00007ffff46cfa63 in clone () from /usr/x86_64-pc-linux-gnu/lib/libc.so.6
```

The other file was likely made with another version of Krita, though I don't know which--one used by a friend. I'd probably have to ask permission to post it here, since it isn't mine. Files then successfully saved by this version of Krita are not sufficient to prevent this segfault when opened in a fresh session.

4.2.9 doesn't look like the latest, but 4.2.9-r1 is the latest Exherbo package in ::kde. I haven't tested newer sources, but I could get around to that.

STEPS TO REPRODUCE
1. Create and modify any new file.
2. Save as a .kra file.

OBSERVED RESULT

Segfault, detailed in the backtrace above.

EXPECTED RESULT

A successfully-saved .kra file and no crash.

SOFTWARE/OS VERSIONS
Windows: -
macOS: -
Linux/KDE Plasma: Linux 5.12.2, no Plasma shell
(available in About System)
KDE Plasma Version: -
KDE Frameworks Version: [nonexhaustively seems to be 5.82.0]
Qt Version: [idem, 5.15.2]

ADDITIONAL INFORMATION
Comment 1 Tiar 2021-06-03 17:09:36 UTC
> 4.2.9 doesn't look like the latest, but 4.2.9-r1 is the latest Exherbo package in ::kde. I haven't tested newer sources, but I could get around to that.

Can you please test the 4.4.3 appimage (available on the website), then? It should open fine on quite a lot of Linux systems.
Comment 2 Grissess 2021-06-03 18:29:37 UTC
> Can you please test the 4.4.3 appimage (available on the website), then? It
> should open fine on quite a lot of Linux systems.

That appears to have saved successfully under the trivial test. I guess someone (me?) should bother the Exherbo packagers for a version bump, then :)

My curiosity isn't quite sated, but I have a locally working version, so I can't complain.
Comment 3 Halla Rempt 2021-06-03 18:38:11 UTC
Basically, some icc profiles are just broken, and in 4.2.9 we didn't catch that always, now we do.