Test Failure: Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll

Test source: git

Log:

Source: <stdin>
-- 1. ModuleToFunctionPassAdaptor
-- 1. PassManager<Function> : Skipping NOP
-- 2. SimplifyCFGPass

----------------------------------------
declare ptr @foo2(ptr, ptr, i64)
declare void @side.effect()

define ptr @test_hoist_int_attrs(i1 %c, ptr %p, ptr %p2, i64 %x) {
#0:
  br i1 %c, label %if, label %else

else:
  %#range_0_%x = !range i64 %x, i64 10000, i64 100000
  %r2 = call ptr @foo2(align(32) dereferenceable_or_null(200) ptr %p, dereferenceable(100) align(32) ptr %p2, i64 %#range_0_%x) memory(write)
  call void @side.effect()
  ret ptr %r2

if:
  %#range_1_%x = !range i64 %x, i64 10, i64 1000
  %r = call ptr @foo2(align(64) dereferenceable_or_null(100) ptr %p, dereferenceable(50) align(64) ptr %p2, i64 %#range_1_%x) nofree memory(read)
  ret ptr %r
}
Transformation seems to be correct! (syntactically equal)

-- 3. SimplifyCFGPass

----------------------------------------
declare ptr @foo2(ptr, ptr, i64)
declare void @side.effect()

define ptr @test_hoist_int_attrs(i1 %c, ptr %p, ptr %p2, i64 %x) {
#0:
  br i1 %c, label %if, label %else

else:
  %#range_0_%x = !range i64 %x, i64 10000, i64 100000
  %r2 = call ptr @foo2(align(32) dereferenceable_or_null(200) ptr %p, dereferenceable(100) align(32) ptr %p2, i64 %#range_0_%x) memory(write)
  call void @side.effect()
  ret ptr %r2

if:
  %#range_1_%x = !range i64 %x, i64 10, i64 1000
  %r = call ptr @foo2(align(64) dereferenceable_or_null(100) ptr %p, dereferenceable(50) align(64) ptr %p2, i64 %#range_1_%x) nofree memory(read)
  ret ptr %r
}
=>
declare ptr @foo2(ptr, ptr, i64)
declare void @side.effect()

define ptr @test_hoist_int_attrs(i1 %c, ptr %p, ptr %p2, i64 %x) {
#0:
  %#range_0_%x = !range i64 %x, i64 10, i64 100000
  %r = call ptr @foo2(align(32) dereferenceable_or_null(100) ptr %p, dereferenceable(50) align(32) ptr %p2, i64 %#range_0_%x)
  br i1 %c, label %common.ret, label %else

else:
  call void @side.effect()
  br label %common.ret

common.ret:
  ret ptr %r
}
Transformation doesn't verify! (unsound)
ERROR: Mismatch in memory

Example:
i1 %c = #x1 (1)
ptr %p = null
ptr %p2 = pointer(non-local, block_id=1, offset=0) / Address=#x040
i64 %x = #x0000000000000000 (0)

Source:
  >> Jump to %if
i64 %#range_1_%x = poison
ptr %r = null

SOURCE MEMORY STATE
===================
NON-LOCAL BLOCKS:
Block 0 >	size: 0	align: 1	alloc type: 0	alive: false	address: #x000
Block 1 >	size: 2	align: 64	alloc type: 4	alive: true	address: #x040
Block 2 >	size: 0	align: 1	alloc type: 0	alive: true	address: #x004
Block 3 >	size: 0	align: 1	alloc type: 4	alive: true	address: #x004
Block 4 >	size: 0	align: 1	alloc type: 4	alive: true	address: #x008

Target:
i64 %#range_0_%x = poison
ptr %r = null
  >> Jump to %common.ret

TARGET MEMORY STATE
===================
NON-LOCAL BLOCKS:
Block 0 >	size: 0	align: 1	alloc type: 0	alive: false	address: #x000
Block 1 >	size: 3	align: 64	alloc type: 4	alive: true	address: #x040
Block 2 >	size: 0	align: 1	alloc type: 0	alive: true	address: #x004
Block 3 >	size: 0	align: 1	alloc type: 4	alive: true	address: #x004
Block 4 >	size: 0	align: 1	alloc type: 4	alive: true	address: #x008

Mismatch in pointer(non-local, block_id=1, offset=0)
Source value: poison
Target value: poison

Pass: SimplifyCFGPass
Command line: '/home/nlopes/llvm/build/bin/opt' '-load=/home/nlopes/alive2/build/tv/tv.so' '-load-pass-plugin=/home/nlopes/alive2/build/tv/tv.so' '-tv-exit-on-error' '-passes=simplifycfg<hoist-common-insts>' '-simplifycfg-require-and-preserve-domtree=1' '-S' '-tv-smt-to=20000' '-tv-report-dir=/home/nlopes/alive2/build/logs' '-tv-smt-stats'

Wrote bitcode to: "/home/nlopes/alive2/build/logs/in_ADlPxKkx_sxnS.bc"

------------------- SMT STATS -------------------
Num queries: 83
Num invalid: 0
Num skips:   0
Num trivial: 7 (7.8%)
Num timeout: 0 (0.0%)
Num errors:  0 (0.0%)
Num SAT:     60 (72.3%)
Num UNSAT:   23 (27.7%)
Alive2: Transform doesn't verify; aborting!

stderr:

Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll' FAILED ********************
Exit Code: 2

Command Output (stdout):
--
# RUN: at line 2
/home/nlopes/alive2/build/opt-alive.sh < /bitbucket/nlopes/llvm/llvm/test/Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll -passes='simplifycfg<hoist-common-insts>' -simplifycfg-require-and-preserve-domtree=1 -S | /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll
# executed command: /home/nlopes/alive2/build/opt-alive.sh '-passes=simplifycfg<hoist-common-insts>' -simplifycfg-require-and-preserve-domtree=1 -S
# .---command stderr------------
# `-----------------------------
# error: command failed with exit status: 1
# executed command: /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll
# .---command stderr------------
# | FileCheck error: '<stdin>' is empty.
# | FileCheck command line:  /bitbucket/nlopes/llvm/build/bin/FileCheck /bitbucket/nlopes/llvm/llvm/test/Transforms/SimplifyCFG/hoist-cb-diff-attrs.ll
# `-----------------------------
# error: command failed with exit status: 2

--

 

<-- Back