1*e37d736dSNashe Mncube; NOTE: Assertions have been autogenerated by utils/update_test_checks.py UTC_ARGS: --version 5 2*e37d736dSNashe Mncube; RUN: opt < %s -mtriple=arm-none-eabi -passes=globalopt -S | FileCheck %s 3*e37d736dSNashe Mncube 4*e37d736dSNashe Mncube; CHECK: [65 x i8] 5*e37d736dSNashe Mncube; CHECK-NOT: [68 x i8] 6*e37d736dSNashe Mncube@.str = private unnamed_addr constant [65 x i8] c"aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaazzz\00", align 1 7*e37d736dSNashe Mncube 8*e37d736dSNashe Mncube; Function Attrs: nounwind 9*e37d736dSNashe Mncubedefine void @foo() { 10*e37d736dSNashe Mncube; CHECK-LABEL: define void @foo() local_unnamed_addr { 11*e37d736dSNashe Mncube; CHECK-NEXT: [[ENTRY:.*:]] 12*e37d736dSNashe Mncube; CHECK-NEXT: [[SOMETHING:%.*]] = alloca [65 x i8], align 1 13*e37d736dSNashe Mncube; CHECK-NEXT: call void @llvm.lifetime.start.p0(i64 65, ptr nonnull [[SOMETHING]]) 14*e37d736dSNashe Mncube; CHECK-NEXT: call void @llvm.memcpy.p0.p0.i32(ptr nonnull align 1 [[SOMETHING]], ptr align 1 @.str, i32 65, i1 false) 15*e37d736dSNashe Mncube; CHECK-NEXT: [[CALL2:%.*]] = call i32 @bar(ptr nonnull [[SOMETHING]]) 16*e37d736dSNashe Mncube; CHECK-NEXT: call void @llvm.lifetime.end.p0(i64 65, ptr nonnull [[SOMETHING]]) 17*e37d736dSNashe Mncube; CHECK-NEXT: ret void 18*e37d736dSNashe Mncube; 19*e37d736dSNashe Mncubeentry: 20*e37d736dSNashe Mncube %something = alloca [65 x i8], align 1 21*e37d736dSNashe Mncube call void @llvm.lifetime.start(i64 65, ptr nonnull %something) #3 22*e37d736dSNashe Mncube call void @llvm.memcpy.p0i8.p0i8.i32(ptr align 1 nonnull %something, ptr align 1 @.str, i32 65, i1 false) 23*e37d736dSNashe Mncube %call2 = call i32 @bar(ptr nonnull %something) #3 24*e37d736dSNashe Mncube call void @llvm.lifetime.end(i64 65, ptr nonnull %something) #3 25*e37d736dSNashe Mncube ret void 26*e37d736dSNashe Mncube} 27*e37d736dSNashe Mncube 28*e37d736dSNashe Mncubedeclare i32 @bar(...) #2 29