1 ; RUN: llc -verify-machineinstrs -mtriple=powerpc-unknown-linux < %s | FileCheck -check-prefix=LINUX32 %s
2 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64-unknown-linux < %s | FileCheck -check-prefix=LINUX64 %s
3 ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le-unknown-linux < %s | FileCheck -check-prefix=LINUX64 %s
5 ; LINUX32: lwz {{[0-9]+}}, -28680(2)
6 ; LINUX64: ld {{[0-9]+}}, -28688(13)
8 ; LINUX32: __stack_chk_fail
9 ; LINUX64: __stack_chk_fail
11 @"\01LC" = internal constant [11 x i8] c"buf == %s\0A\00" ; <[11 x i8]*> [#uses=1]
13 define void @test(i8* %a) nounwind ssp {
15 %a_addr = alloca i8* ; <i8**> [#uses=2]
16 %buf = alloca [8 x i8] ; <[8 x i8]*> [#uses=2]
17 %"alloca point" = bitcast i32 0 to i32 ; <i32> [#uses=0]
18 store i8* %a, i8** %a_addr
19 %buf1 = bitcast [8 x i8]* %buf to i8* ; <i8*> [#uses=1]
20 %0 = load i8*, i8** %a_addr, align 4 ; <i8*> [#uses=1]
21 %1 = call i8* @strcpy(i8* %buf1, i8* %0) nounwind ; <i8*> [#uses=0]
22 %buf2 = bitcast [8 x i8]* %buf to i8* ; <i8*> [#uses=1]
23 %2 = call i32 (i8*, ...) @printf(i8* getelementptr ([11 x i8], [11 x i8]* @"\01LC", i32 0, i32 0), i8* %buf2) nounwind ; <i32> [#uses=0]
26 return: ; preds = %entry
30 declare i8* @strcpy(i8*, i8*) nounwind
32 declare i32 @printf(i8*, ...) nounwind