forked from OSchip/llvm-project
37 lines
1.2 KiB
LLVM
37 lines
1.2 KiB
LLVM
; RUN: llvm-dis -opaque-pointers=0 < %s.bc | FileCheck %s
|
|
; RUN: llvm-dis -opaque-pointers=1 < %s.bc | FileCheck %s
|
|
|
|
; Check that function-local metadata is dropped correctly when it's not a
|
|
; direct argument to a call instruction.
|
|
;
|
|
; Bitcode assembled by llvm-as v3.5.0.
|
|
|
|
define void @foo(i32 %v) {
|
|
; CHECK: entry:
|
|
entry:
|
|
; CHECK-NEXT: call void @llvm.bar(metadata i32 %v)
|
|
call void @llvm.bar(metadata !{i32 %v})
|
|
|
|
; Note: these supposedly legal instructions fired an assertion in llvm-as:
|
|
;
|
|
; Assertion failed: (I != ValueMap.end() && "Value not in slotcalculator!"), function getValueID, file lib/Bitcode/Writer/ValueEnumerator.cpp, line 138.
|
|
;
|
|
; So, I didn't test them; it looks like bitcode compatability is irrelevant.
|
|
; call void @llvm.bar(metadata !{i32 0, i32 %v})
|
|
; call void @llvm.bar(metadata !{i32 %v, i32 0})
|
|
; call void @llvm.bar(metadata !{metadata !{}, i32 %v})
|
|
; call void @llvm.bar(metadata !{i32 %v, metadata !{}})
|
|
|
|
; CHECK-NEXT: call void @llvm.bar(metadata !0)
|
|
; CHECK-NEXT: call void @llvm.bar(metadata !0)
|
|
call void @llvm.bar(metadata !{i32 %v, i32 %v})
|
|
call void @llvm.bar(metadata !{metadata !{i32 %v}})
|
|
|
|
; CHECK-NEXT: ret void{{$}}
|
|
ret void, !baz !{i32 %v}
|
|
}
|
|
|
|
declare void @llvm.bar(metadata)
|
|
|
|
; CHECK: !0 = !{}
|