https://bugs.kde.org/show_bug.cgi?id=412135

            Bug ID: 412135
           Summary: Asan crash while painting.
           Product: krita
           Version: git master
          Platform: Other
                OS: Linux
            Status: REPORTED
          Severity: crash
          Priority: NOR
         Component: Tile manager
          Assignee: krita-bugs-n...@kde.org
          Reporter: griffinval...@gmail.com
  Target Milestone: ---

I got this when painting, I had just merged master to my branch. Have not tried
to reproduce.

=================================================================
==19028==ERROR: AddressSanitizer: heap-use-after-free on address 0x610000145650
at pc 0x7f55fac41129 bp 0x7f558fe649c0 sp 0x7f558fe649b0
READ of size 8 at 0x610000145650 thread T807 (Thread (pooled))
    #0 0x7f55fac41128 in std::__atomic_base<unsigned long
long>::load(std::memory_order) const /usr/include/c++/7/bits/atomic_base.h:396
    #1 0x7f55fac41128 in Atomic<unsigned long long>::load(MemoryOrder) const
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/atomic.h:91
    #2 0x7f55fac3fe56 in SimpleJobCoordinator::loadConsume() const
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/simple_job_coordinator.h:46
    #3 0x7f55fac6471d in ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*>
>::migrationInProcess()
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/concurrent_map.h:51
    #4 0x7f55fac5a03f in KisTileHashTableTraits2<KisTile>::getTileLazy(int,
int, bool&)
(/home/wolthera/krita/inst/lib/x86_64-linux-gnu/libkritaimage.so.19+0x46403f)
    #5 0x7f55fac58008 in KisTiledDataManager::getTile(int, int, bool)
/home/wolthera/krita/src/libs/image/tiles3/swap/../kis_tiled_data_manager.h:120
    #6 0x7f55fac8e1e0 in KisTiledDataManager::getTilesPair(int, int, bool,
KisSharedPtr<KisTile>*, KisSharedPtr<KisTile>*)
/home/wolthera/krita/src/libs/image/tiles3/kis_tiled_data_manager.h:107
    #7 0x7f55fac99deb in KisRandomAccessor2::fetchTileData(int, int)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:122
    #8 0x7f55fac99a0d in KisRandomAccessor2::moveTo(int, int)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:89
    #9 0x7f55fac98d74 in
KisRandomAccessor2::KisRandomAccessor2(KisTiledDataManager*, int, int, int,
int, bool, KisIteratorCompleteListener*)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:38
    #10 0x7f55fb482bde in
KisPaintDevice::Private::KisPaintDeviceStrategy::createRandomAccessorNG(int,
int) /home/wolthera/krita/src/libs/image/kis_paint_device_strategies.h:111
    #11 0x7f55fb46a840 in KisPaintDevice::createRandomAccessorNG(int, int)
/home/wolthera/krita/src/libs/image/kis_paint_device.cc:1786
    #12 0x7f55fad185bc in KisPainter::bltFixed(QRect const&,
QList<KisRenderedDab>)
/home/wolthera/krita/src/libs/image/kis_painter_blt_multi_fixed.cpp:180
    #13 0x7f55bb2e2d87 in operator()
/home/wolthera/krita/src/plugins/paintops/defaultpaintops/brush/kis_brushop.cpp:318
    #14 0x7f55bb2e81ae in _M_invoke /usr/include/c++/7/bits/std_function.h:316
    #15 0x7f55ff391915 in std::function<void ()>::operator()() const
/usr/include/c++/7/bits/std_function.h:706
    #16 0x7f55fb03cca2 in KisRunnableStrokeJobData::run()
/home/wolthera/krita/src/libs/image/KisRunnableStrokeJobData.cpp:46
    #17 0x7f55fb03ae95 in
KisRunnableBasedStrokeStrategy::doStrokeCallback(KisStrokeJobData*)
/home/wolthera/krita/src/libs/image/KisRunnableBasedStrokeStrategy.cpp:73
    #18 0x7f55ff39848c in
FreehandStrokeStrategy::doStrokeCallback(KisStrokeJobData*)
/home/wolthera/krita/src/libs/ui/tool/strokes/freehand_stroke.cpp:220
    #19 0x7f55fb033b0d in SimpleStrokeJobStrategy::run(KisStrokeJobData*)
/home/wolthera/krita/src/libs/image/kis_simple_stroke_strategy.cpp:51
    #20 0x7f55fb045aa6 in KisStrokeJob::run()
/home/wolthera/krita/src/libs/image/kis_stroke_job.h:44
    #21 0x7f55fb6bf27e in KisUpdateJobItem::run()
/home/wolthera/krita/build/libs/image/kritaimage_autogen/EWIEGA46WW/../../../../../src/libs/image/kis_update_job_item.h:91
    #22 0x7f55f85063e1  (/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xac3e1)
    #23 0x7f55f8501c71  (/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa7c71)
    #24 0x7f55f74a46da in start_thread
(/lib/x86_64-linux-gnu/libpthread.so.0+0x76da)
    #25 0x7f55f7be988e in __clone (/lib/x86_64-linux-gnu/libc.so.6+0x12188e)

0x610000145650 is located 16 bytes inside of 184-byte region
[0x610000145640,0x6100001456f8)
freed by thread T801 (Thread (pooled)) here:
    #0 0x7f560429b7b8 in __interceptor_free
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0xde7b8)
    #1 0x7f55fac6ac73 in Leapfrog<ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::Table::destroy()
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/leapfrog.h:86
    #2 0x7f55fac702ca in Leapfrog<ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::TableMigration::destroy()
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/leapfrog.h:142
    #3 0x7f55fac70427 in void QSBR::enqueue<Leapfrog<ConcurrentMap<unsigned
int, KisTile*, DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::TableMigration>(void (Leapfrog<ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::TableMigration::*)(), Leapfrog<ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::TableMigration*, bool)::Closure::thunk(void*)
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/qsbr.h:83
    #4 0x7f55fac403f6 in QSBR::Action::operator()()
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/qsbr.h:38
    #5 0x7f55fac405e9 in
QSBR::releasePoolSafely(KisLocklessStack<QSBR::Action>*, bool)
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/qsbr.h:62
    #6 0x7f55fac57d17 in QSBR::update(bool)
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/qsbr.h:101
    #7 0x7f55fac5a04c in KisTileHashTableTraits2<KisTile>::getTileLazy(int,
int, bool&)
(/home/wolthera/krita/inst/lib/x86_64-linux-gnu/libkritaimage.so.19+0x46404c)
    #8 0x7f55fac58008 in KisTiledDataManager::getTile(int, int, bool)
/home/wolthera/krita/src/libs/image/tiles3/swap/../kis_tiled_data_manager.h:120
    #9 0x7f55fac8e1e0 in KisTiledDataManager::getTilesPair(int, int, bool,
KisSharedPtr<KisTile>*, KisSharedPtr<KisTile>*)
/home/wolthera/krita/src/libs/image/tiles3/kis_tiled_data_manager.h:107
    #10 0x7f55fac99deb in KisRandomAccessor2::fetchTileData(int, int)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:122
    #11 0x7f55fac99a0d in KisRandomAccessor2::moveTo(int, int)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:89
    #12 0x7f55fac98d74 in
KisRandomAccessor2::KisRandomAccessor2(KisTiledDataManager*, int, int, int,
int, bool, KisIteratorCompleteListener*)
/home/wolthera/krita/src/libs/image/tiles3/kis_random_accessor.cc:38
    #13 0x7f55fb482bde in
KisPaintDevice::Private::KisPaintDeviceStrategy::createRandomAccessorNG(int,
int) /home/wolthera/krita/src/libs/image/kis_paint_device_strategies.h:111
    #14 0x7f55fb46a840 in KisPaintDevice::createRandomAccessorNG(int, int)
/home/wolthera/krita/src/libs/image/kis_paint_device.cc:1786
    #15 0x7f55fad185bc in KisPainter::bltFixed(QRect const&,
QList<KisRenderedDab>)
/home/wolthera/krita/src/libs/image/kis_painter_blt_multi_fixed.cpp:180
    #16 0x7f55bb2e2d87 in operator()
/home/wolthera/krita/src/plugins/paintops/defaultpaintops/brush/kis_brushop.cpp:318
    #17 0x7f55bb2e81ae in _M_invoke /usr/include/c++/7/bits/std_function.h:316
    #18 0x7f55ff391915 in std::function<void ()>::operator()() const
/usr/include/c++/7/bits/std_function.h:706
    #19 0x7f55fb03cca2 in KisRunnableStrokeJobData::run()
/home/wolthera/krita/src/libs/image/KisRunnableStrokeJobData.cpp:46
    #20 0x7f55fb03ae95 in
KisRunnableBasedStrokeStrategy::doStrokeCallback(KisStrokeJobData*)
/home/wolthera/krita/src/libs/image/KisRunnableBasedStrokeStrategy.cpp:73
    #21 0x7f55ff39848c in
FreehandStrokeStrategy::doStrokeCallback(KisStrokeJobData*)
/home/wolthera/krita/src/libs/ui/tool/strokes/freehand_stroke.cpp:220
    #22 0x7f55fb033b0d in SimpleStrokeJobStrategy::run(KisStrokeJobData*)
/home/wolthera/krita/src/libs/image/kis_simple_stroke_strategy.cpp:51
    #23 0x7f55fb045aa6 in KisStrokeJob::run()
/home/wolthera/krita/src/libs/image/kis_stroke_job.h:44
    #24 0x7f55fb6bf27e in KisUpdateJobItem::run()
/home/wolthera/krita/build/libs/image/kritaimage_autogen/EWIEGA46WW/../../../../../src/libs/image/kis_update_job_item.h:91
    #25 0x7f55f85063e1  (/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xac3e1)

previously allocated by thread T802 (Thread (pooled)) here:
    #0 0x7f560429bb50 in __interceptor_malloc
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0xdeb50)
    #1 0x7f55fac6aaba in Leapfrog<ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*> >
>::Table::create(unsigned long long)
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/leapfrog.h:67
    #2 0x7f55fac668c8 in ConcurrentMap<unsigned int, KisTile*,
DefaultKeyTraits<unsigned int>, DefaultValueTraits<KisTile*>
>::ConcurrentMap(unsigned long long)
/home/wolthera/krita/src/libs/image/3rdparty/lock_free_map/concurrent_map.h:33
    #3 0x7f55fac5b4a1 in
KisTileHashTableTraits2<KisTile>::KisTileHashTableTraits2(KisMementoManager*)
(/home/wolthera/krita/inst/lib/x86_64-linux-gnu/libkritaimage.so.19+0x4654a1)
    #4 0x7f55fac4e906 in KisTiledDataManager::KisTiledDataManager(unsigned int,
unsigned char const*)
/home/wolthera/krita/src/libs/image/tiles3/kis_tiled_data_manager.cc:50
    #5 0x7f55fb472725 in KisDataManager::KisDataManager(unsigned int, unsigned
char const*) /home/wolthera/krita/src/libs/image/kis_datamanager.h:57
    #6 0x7f55fb45f818 in KisPaintDevice::Private::init(KoColorSpace const*,
unsigned char const*)
/home/wolthera/krita/src/libs/image/kis_paint_device.cc:983
    #7 0x7f55fb4607f8 in KisPaintDevice::init(KoColorSpace const*,
KisSharedPtr<KisDefaultBoundsBase>, KisWeakSharedPtr<KisNode>, QString const&)
/home/wolthera/krita/src/libs/image/kis_paint_device.cc:1020
    #8 0x7f55fb45fd07 in KisPaintDevice::KisPaintDevice(KoColorSpace const*,
QString const&) /home/wolthera/krita/src/libs/image/kis_paint_device.cc:992
    #9 0x7f55fb46ee71 in KisPaintDevice::createCompositionSourceDevice() const
/home/wolthera/krita/src/libs/image/kis_paint_device.cc:1987
    #10 0x7f55ff3aa2ed in KisPainterBasedStrokeStrategy::initStrokeCallback()
/home/wolthera/krita/src/libs/ui/tool/strokes/kis_painter_based_stroke_strategy.cpp:243
    #11 0x7f55ff39756f in FreehandStrokeStrategy::initStrokeCallback()
/home/wolthera/krita/src/libs/ui/tool/strokes/freehand_stroke.cpp:135
    #12 0x7f55fb03395f in SimpleStrokeJobStrategy::run(KisStrokeJobData*)
/home/wolthera/krita/src/libs/image/kis_simple_stroke_strategy.cpp:40
    #13 0x7f55fb045aa6 in KisStrokeJob::run()
/home/wolthera/krita/src/libs/image/kis_stroke_job.h:44
    #14 0x7f55fb6bf27e in KisUpdateJobItem::run()
/home/wolthera/krita/build/libs/image/kritaimage_autogen/EWIEGA46WW/../../../../../src/libs/image/kis_update_job_item.h:91
    #15 0x7f55f85063e1  (/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xac3e1)

Thread T807 (Thread (pooled)) created by T805 (Thread (pooled)) here:
    #0 0x7f56041f4d2f in __interceptor_pthread_create
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0x37d2f)
    #1 0x7f55f85012ed in QThread::start(QThread::Priority)
(/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa72ed)

Thread T805 (Thread (pooled)) created by T803 (Thread (pooled)) here:
    #0 0x7f56041f4d2f in __interceptor_pthread_create
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0x37d2f)
    #1 0x7f55f85012ed in QThread::start(QThread::Priority)
(/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa72ed)

Thread T803 (Thread (pooled)) created by T802 (Thread (pooled)) here:
    #0 0x7f56041f4d2f in __interceptor_pthread_create
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0x37d2f)
    #1 0x7f55f85012ed in QThread::start(QThread::Priority)
(/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa72ed)

Thread T802 (Thread (pooled)) created by T0 here:
    #0 0x7f56041f4d2f in __interceptor_pthread_create
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0x37d2f)
    #1 0x7f55f85012ed in QThread::start(QThread::Priority)
(/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa72ed)

Thread T801 (Thread (pooled)) created by T0 here:
    #0 0x7f56041f4d2f in __interceptor_pthread_create
(/usr/lib/x86_64-linux-gnu/libasan.so.4+0x37d2f)
    #1 0x7f55f85012ed in QThread::start(QThread::Priority)
(/usr/lib/x86_64-linux-gnu/libQt5Core.so.5+0xa72ed)

SUMMARY: AddressSanitizer: heap-use-after-free
/usr/include/c++/7/bits/atomic_base.h:396 in std::__atomic_base<unsigned long
long>::load(std::memory_order) const
Shadow bytes around the buggy address:
  0x0c2080020a70: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
  0x0c2080020a80: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
  0x0c2080020a90: fd fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa
  0x0c2080020aa0: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
  0x0c2080020ab0: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fa
=>0x0c2080020ac0: fa fa fa fa fa fa fa fa fd fd[fd]fd fd fd fd fd
  0x0c2080020ad0: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fa
  0x0c2080020ae0: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
  0x0c2080020af0: fd fd fd fd fd fd fd fd fa fa fa fa fa fa fa fa
  0x0c2080020b00: fa fa fa fa fa fa fa fa fd fd fd fd fd fd fd fd
  0x0c2080020b10: fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd fd
Shadow byte legend (one shadow byte represents 8 application bytes):
  Addressable:           00
  Partially addressable: 01 02 03 04 05 06 07 
  Heap left redzone:       fa
  Freed heap region:       fd
  Stack left redzone:      f1
  Stack mid redzone:       f2
  Stack right redzone:     f3
  Stack after return:      f5
  Stack use after scope:   f8
  Global redzone:          f9
  Global init order:       f6
  Poisoned by user:        f7
  Container overflow:      fc
  Array cookie:            ac
  Intra object redzone:    bb
  ASan internal:           fe
  Left alloca redzone:     ca
  Right alloca redzone:    cb
==19028==ABORTING
wolthera@Euthenia:~/krita/build$

-- 
You are receiving this mail because:
You are watching all bug changes.

Reply via email to