In some rare cases, the register allocator can spill registers but end up not utilizi...
[llvm/msp430.git] / test / CodeGen / X86 / 2008-09-29-VolatileBug.ll
blob4f6eb59773fb09c6680943f65cf88c23aac1819c
1 ; RUN: llvm-as < %s | llc -march=x86 | not grep movz
2 ; PR2835
4 @g_407 = internal global i32 0          ; <i32*> [#uses=1]
5 @llvm.used = appending global [1 x i8*] [ i8* bitcast (i32 ()* @main to i8*) ], section "llvm.metadata"         ; <[1 x i8*]*> [#uses=0]
7 define i32 @main() nounwind {
8 entry:
9         %0 = volatile load i32* @g_407, align 4         ; <i32> [#uses=1]
10         %1 = trunc i32 %0 to i8         ; <i8> [#uses=1]
11         %2 = tail call i32 @func_45(i8 zeroext %1) nounwind             ; <i32> [#uses=0]
12         ret i32 0
15 declare i32 @func_45(i8 zeroext) nounwind