Merge branch 'master' into msp430
[llvm/msp430.git] / test / CodeGen / CBackend / 2004-02-15-PreexistingExternals.ll
blob1629debc58fb6c8296c82f20df5ff6cdd114a2ad
1 ; The intrinsic lowering pass was lowering intrinsics like llvm.memcpy to 
2 ; explicitly specified prototypes, inserting a new function if the old one
3 ; didn't exist.  This caused there to be two external memcpy functions in 
4 ; this testcase for example, which caused the CBE to mangle one, screwing
5 ; everything up.  :(  Test that this does not happen anymore.
7 ; RUN: llvm-as < %s | llc -march=c | not grep _memcpy
9 declare void @llvm.memcpy.i32(i8*, i8*, i32, i32)
11 declare float* @memcpy(i32*, i32, i32)
13 define i32 @test(i8* %A, i8* %B, i32* %C) {
14         call float* @memcpy( i32* %C, i32 4, i32 17 )           ; <float*>:1 [#uses=0]
15         call void @llvm.memcpy.i32( i8* %A, i8* %B, i32 123, i32 14 )
16         ret i32 7