https://bugs.kde.org/show_bug.cgi?id=430321
Bug ID: 430321 Summary: drd/tests/bar_bad and drd/tests/bar_bad_xml are non-deterministic Product: valgrind Version: unspecified Platform: Other OS: Linux Status: REPORTED Severity: normal Priority: NOR Component: drd Assignee: bvanass...@acm.org Reporter: alex.kana...@gmail.com Target Milestone: --- When I run the tests under qemu they pass or fail non-deterministically. Note the difference in "destroy a barrier that has waiting threads" section. Run 1: root@qemux86-64:/usr/lib/valgrind/ptest# valgrind --tool=drd --fair-sched=yes ./helgrind/tests/bar_bad ==31394== drd, a thread error detector ==31394== Copyright (C) 2006-2017, and GNU GPL'd, by Bart Van Assche. ==31394== Using Valgrind-3.16.1 and LibVEX; rerun with -h for copyright info ==31394== Command: ./helgrind/tests/bar_bad ==31394== initialise a barrier with zero count ==31394== pthread_barrier_init: 'count' argument is zero: barrier 0x4852030 ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x401273: main (bar_bad.c:43) ==31394== initialise a barrier twice ==31394== Barrier reinitialization: barrier 0x4852070 ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x4012CB: main (bar_bad.c:49) ==31394== barrier 0x4852070 was first observed at: ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x4012B5: main (bar_bad.c:48) ==31394== initialise a barrier which has threads waiting on it ==31394== Barrier reinitialization: barrier 0x48520b0 ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x401367: main (bar_bad.c:64) ==31394== barrier 0x48520b0 was first observed at: ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x40130D: main (bar_bad.c:55) ==31394== destroy a barrier that has waiting threads ==31394== Destruction of a barrier with active waiters: barrier 0x4852350 ==31394== at 0x4826C71: pthread_barrier_destroy_intercept (drd_pthread_intercepts.c:1323) ==31394== by 0x4826C71: pthread_barrier_destroy (drd_pthread_intercepts.c:1328) ==31394== by 0x4013F9: main (bar_bad.c:82) ==31394== barrier 0x4852350 was first observed at: ==31394== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31394== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31394== by 0x4013A9: main (bar_bad.c:70) ==31394== destroy a barrier that was never initialised ==31394== Not a barrier ==31394== at 0x4826C71: pthread_barrier_destroy_intercept (drd_pthread_intercepts.c:1323) ==31394== by 0x4826C71: pthread_barrier_destroy (drd_pthread_intercepts.c:1328) ==31394== by 0x40148E: main (bar_bad.c:98) ==31394== ==31394== ==31394== For lists of detected and suppressed errors, rerun with: -s ==31394== ERROR SUMMARY: 6 errors from 5 contexts (suppressed: 138 from 15) Run 2: root@qemux86-64:/usr/lib/valgrind/ptest# valgrind --tool=drd --fair-sched=yes ./helgrind/tests/bar_bad ==31400== drd, a thread error detector ==31400== Copyright (C) 2006-2017, and GNU GPL'd, by Bart Van Assche. ==31400== Using Valgrind-3.16.1 and LibVEX; rerun with -h for copyright info ==31400== Command: ./helgrind/tests/bar_bad ==31400== initialise a barrier with zero count ==31400== pthread_barrier_init: 'count' argument is zero: barrier 0x4852030 ==31400== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31400== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31400== by 0x401273: main (bar_bad.c:43) ==31400== initialise a barrier twice ==31400== Barrier reinitialization: barrier 0x4852070 ==31400== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31400== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31400== by 0x4012CB: main (bar_bad.c:49) ==31400== barrier 0x4852070 was first observed at: ==31400== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31400== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31400== by 0x4012B5: main (bar_bad.c:48) ==31400== initialise a barrier which has threads waiting on it ==31400== Barrier reinitialization: barrier 0x48520b0 ==31400== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31400== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31400== by 0x401367: main (bar_bad.c:64) ==31400== barrier 0x48520b0 was first observed at: ==31400== at 0x48262D2: pthread_barrier_init_intercept (drd_pthread_intercepts.c:1302) ==31400== by 0x48262D2: pthread_barrier_init (drd_pthread_intercepts.c:1310) ==31400== by 0x40130D: main (bar_bad.c:55) ==31400== destroy a barrier that has waiting threads destroy a barrier that was never initialised ==31400== Not a barrier ==31400== at 0x4826C71: pthread_barrier_destroy_intercept (drd_pthread_intercepts.c:1323) ==31400== by 0x4826C71: pthread_barrier_destroy (drd_pthread_intercepts.c:1328) ==31400== by 0x40148E: main (bar_bad.c:98) ==31400== ==31400== ==31400== For lists of detected and suppressed errors, rerun with: -s ==31400== ERROR SUMMARY: 4 errors from 4 contexts (suppressed: 138 from 15) This is observed with valgrind 3.16.1 under qemu x86_64. I believe this has been also previously reported in https://bugs.kde.org/show_bug.cgi?id=358213 but seemingly never fixed properly. -- You are receiving this mail because: You are watching all bug changes.