[ 0:01] | load /var/obj/divine-nightly/semidbg/test/_expand/sym/ret-b.pkg.cpp/v.O0.cpp v.O0.cpp [ 0:01] | expect --result error --location v.O0.cpp:30 [ 0:01] | expect --trace FAULT: --trace-count 1 [ 0:01] | cc -o testcase.bc -std=c++14 -O0 v.O0.cpp [ 0:01] | verify --max-memory 4GiB --max-time 600 --threads 2 --report-filename verify.out --solver z3 --symbolic testcase.bc [ 0:01] compiling v.O0.cpp [ 0:01] loading bitcode … DiOS … LART … RR … constants … done [ 0:13] booting … done [ 0:13] states per second: 1.53022 [ 0:14] state count: 2 [ 0:14] mips: 0.2 [ 0:14] symbolic: 1 [ 0:16] [ 0:16] error found: yes [ 0:16] error trace: | [ 0:16] ASSUME (not (= (concat #x00000000 #x0000002a) #x0000000000000000)) [ 0:16] ASSUME (not (= (concat #x00000000 #x00000002) #x0000000000000000)) [ 0:16] ASSUME (bvslt (bvsrem var_1 #x0000002a) #x0000002a) [ 0:16] ASSUME (not (= (concat #x00000000 #x0000002a) #x0000000000000000)) [ 0:16] ASSUME (not (= (concat #x00000000 #x00000002) #x0000000000000000)) [ 0:16] ASSUME (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002a)) [ 0:16] ASSUME (and (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002a)) (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002b))) [ 0:16] ASSUME (and (and (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002a)) (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002b))) (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x00000029)) [ 0:16] ASSUME (and (and (and (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002a)) (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002b))) (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x00000029)) (not (= (bvadd (bvsrem var_4 #x00000002) #x0000002a) #x0000002a))) [ 0:16] FAULT: v.O0.cpp:30: int main(): assertion 'x == 42' failed [ 0:16] [0] FATAL: assertion failure in userspace [ 0:16] [ 0:16] active stack: [ 0:17] - symbol: void __dios::FaultBase::handler<__dios::Context>(_VM_Fault, _VM_Frame*, void (*)()) [ 0:17] location: /dios/sys/fault.hpp:118 [ 0:17] - symbol: __dios_fault [ 0:17] location: /dios/arch/divm/fault.c:12 [ 0:17] - symbol: lart.__assert_fail [ 0:17] location: /dios/libc/_PDCLIB/assert.c:24 [ 0:17] - symbol: main [ 0:17] location: v.O0.cpp:30 [ 0:17] - symbol: __dios_start [ 0:17] location: /dios/libc/sys/start.cpp:94 [ 0:17] + divine sim --batch --skip-init --load-report verify.out [ 0:17] [ 0:28] ^ —————. —.— . . —.— . . .————— . . [ 0:28] ——— | | | | | | |\ | | | | [ 0:28] —(o)— | | | | | | | \ | |———— '————| [ 0:28] ——————— | | | \ / | | \| | | [ 0:28] ————————— —————' —'— ' —'— ' ' '————— ' [ 0:28] [ 0:28] Welcome to 'divine sim', an interactive debugger. Type 'help' to get started. [ 0:28] traced states: [ 0:28] ▶ state #1 [new] -- active threads: [0:0] -- [ 0:28] T: FAULT: v.O0.cpp:30: int main(): assertion 'x == 42' failed [ 0:29] # executing void __dios::FaultBase::handler<{Context}>(_VM_Fault, _VM_Frame*, void (*)()) at /dios/sys/fault.hpp:118 [ 0:29] # NOTE: $frame in __dios_fault [ 0:29] > backtrace [ 0:29] void __dios::FaultBase::handler<{Context}>(_VM_Fault, _VM_Frame*, void (*)()) at /dios/sys/fault.hpp:118 [ 0:29] __dios_fault at /dios/arch/divm/fault.c:12 [ 0:29] lart.__assert_fail at /dios/libc/_PDCLIB/assert.c:24 [ 0:29] main at v.O0.cpp:30 [ 0:29] __dios_start at /dios/libc/sys/start.cpp:94 [ 0:29] # executing void __dios::FaultBase::handler<{Context}>(_VM_Fault, _VM_Frame*, void (*)()) at /dios/sys/fault.hpp:118 [ 0:29] # NOTE: $frame in __dios_fault