Situations can arise when you have a function called that returns a 'void', but
[oota-llvm.git] / test / Transforms / InstCombine / fp-ret-bitcast.ll
1 ; RUN: llvm-as < %s | opt -instcombine | llvm-dis | \
2 ; RUN:    grep {call float bitcast} | count 1
3         %struct.NSObject = type { %struct.objc_class* }
4         %struct.NSArray = type { %struct.NSObject }
5         %struct.objc_class = type opaque
6         %struct.objc_selector = type opaque
7
8 @"\01L_OBJC_METH_VAR_NAME_112" = internal global [15 x i8] c"whiteComponent\00", section "__TEXT,__cstring,cstring_literals"
9 @"\01L_OBJC_SELECTOR_REFERENCES_81" = internal global %struct.objc_selector* bitcast ([15 x i8]* @"\01L_OBJC_METH_VAR_NAME_112" to %struct.objc_selector*), section "__OBJC,__message_refs,literal_pointers,no_dead_strip"
10
11 define void @bork() nounwind  {
12 entry:
13         %color = alloca %struct.NSArray*
14         %color.466 = alloca %struct.NSObject*
15         %tmp103 = load %struct.NSArray** %color, align 4
16         %tmp103104 = getelementptr %struct.NSArray* %tmp103, i32 0, i32 0
17         store %struct.NSObject* %tmp103104, %struct.NSObject** %color.466, align 4
18         %tmp105 = load %struct.objc_selector** @"\01L_OBJC_SELECTOR_REFERENCES_81", align 4
19         %tmp106 = load %struct.NSObject** %color.466, align 4
20         %tmp107 = call float bitcast (void (%struct.NSObject*, ...)* @objc_msgSend_fpret to float (%struct.NSObject*, %struct.objc_selector*)*)( %struct.NSObject* %tmp106, %struct.objc_selector* %tmp105 ) nounwind
21         br label %exit
22
23 exit:
24         ret void
25 }
26
27 declare void @objc_msgSend_fpret(%struct.NSObject*, ...)