Summary: | Color depths other than 8-bit cause artifacts | ||
---|---|---|---|
Product: | [Applications] krita | Reporter: | rkolbaskin |
Component: | Color models | Assignee: | amyspark <amy> |
Status: | RESOLVED FIXED | ||
Severity: | normal | CC: | halla |
Priority: | NOR | ||
Version: | 5.1.4 | ||
Target Milestone: | --- | ||
Platform: | Arch Linux | ||
OS: | Linux | ||
Latest Commit: | https://invent.kde.org/graphics/krita/commit/61cf80d57a103aa8ec8ffe2b7c369c5f61def890 | Version Fixed In: | |
Sentry Crash Report: | |||
Attachments: | Artifacts in 16-bit integer and 32-bit float modes |
Amyspark, could this have to do with the lcms2 update? Following suggestion on krita-artists forum to someone with similar looking issue, I installed Flatpak version of Krita 5. Indeed, it doesn't have artifacts. I will try compiling from sources next. Bug appears only if I compile with "find-xsimd.patch" patch that is applied to Arch Linux repo version. https://github.com/archlinux/svntogit-packages/blob/packages/krita/trunk/find-xsimd.patch Can you also reproduce with the appimage? (In reply to Halla Rempt from comment #4) > Can you also reproduce with the appimage? Appimage version doesn't have this bug as well. It seems to be some kind of incompatibility with xsimd 10.0 or maybe a bug in xsimd since it only surfaces because Arch repo version forces it to use this version. Source accepts xsimd only up to 9.0. Git commit 61cf80d57a103aa8ec8ffe2b7c369c5f61def890 by L. E. Segovia. Committed on 23/12/2022 at 16:40. Pushed by lsegovia into branch 'master'. xsimd: Avoid using zip_* in xsimd >= 10 xsimd 10 introduces an undocumented, breaking change in the batch zipping semantics. These are relied on in the RGBA interleavers, when they replaced the old gather/scatter implementation. To work around them, the old implementation was brought back, surrounded with suitable guards, and the corresponding error pragma was added to KoRgbaInterleavers.h. M +4 -0 libs/pigment/compositeops/KoRgbaInterleavers.h M +52 -0 libs/pigment/compositeops/KoStreamedMath.h https://invent.kde.org/graphics/krita/commit/61cf80d57a103aa8ec8ffe2b7c369c5f61def890 Git commit b388330bdb8915af0fa1b1bac1bf473507a8c045 by L. E. Segovia. Committed on 23/12/2022 at 16:44. Pushed by lsegovia into branch 'krita/5.1'. xsimd: Avoid using zip_* in xsimd >= 10 xsimd 10 introduces an undocumented, breaking change in the batch zipping semantics. These are relied on in the RGBA interleavers, when they replaced the old gather/scatter implementation. To work around them, the old implementation was brought back, surrounded with suitable guards, and the corresponding error pragma was added to KoRgbaInterleavers.h. (cherry picked from commit 61cf80d57a103aa8ec8ffe2b7c369c5f61def890) M +4 -0 libs/pigment/compositeops/KoRgbaInterleavers.h M +52 -0 libs/pigment/compositeops/KoStreamedMath.h https://invent.kde.org/graphics/krita/commit/b388330bdb8915af0fa1b1bac1bf473507a8c045 |
Created attachment 154686 [details] Artifacts in 16-bit integer and 32-bit float modes SUMMARY When color depth is anything other than 8-bit it causes graphical artifacts. 16-bit integer color will have some vertical lines swapped, float modes break completely. Artifacts in newly drawn patches will persist when reopened in 5.1.3. Switching to software rendering doesn't help. This doesn't happen in 5.1.3. STEPS TO REPRODUCE 1. Create a new image with color depth other than 8-bit. 2. Try to draw anything. OBSERVED RESULT See attachment. First three is 16-bit integer mode where I first noticed it. Last one is what happens in float modes. EXPECTED RESULT No artifacts. SOFTWARE/OS VERSIONS Linux: 6.0.12 KDE Plasma Version: 2.26.4 KDE Frameworks Version: 5.101.0 Qt Version: 5.15.7