mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	[InlineFunction] Don't add lifetime markers for zero-sized allocas.
This commit fixes the code which adds lifetime markers in InlineFunction to skip zero-sized allocas instead of asserting on them. rdar://problem/20531155 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@235312 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
		| @@ -1167,7 +1167,11 @@ bool llvm::InlineFunction(CallSite CS, InlineFunctionInfo &IFI, | ||||
|         Type *AllocaType = AI->getAllocatedType(); | ||||
|         uint64_t AllocaTypeSize = DL.getTypeAllocSize(AllocaType); | ||||
|         uint64_t AllocaArraySize = AIArraySize->getLimitedValue(); | ||||
|         assert(AllocaArraySize > 0 && "array size of AllocaInst is zero"); | ||||
|  | ||||
|         // Don't add markers for zero-sized allocas. | ||||
|         if (AllocaArraySize == 0) | ||||
|           continue; | ||||
|  | ||||
|         // Check that array size doesn't saturate uint64_t and doesn't | ||||
|         // overflow when it's multiplied by type size. | ||||
|         if (AllocaArraySize != ~0ULL && | ||||
|   | ||||
							
								
								
									
										24
									
								
								test/Transforms/Inline/crash-lifetime-marker.ll
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										24
									
								
								test/Transforms/Inline/crash-lifetime-marker.ll
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,24 @@ | ||||
| ; RUN: opt < %s -inline -S | FileCheck %s | ||||
|  | ||||
| ; InlineFunction would assert inside the loop that leaves lifetime markers if | ||||
| ; there was an zero-sized AllocaInst. Check that it doesn't assert and doesn't | ||||
| ; leave lifetime markers in that case. | ||||
|  | ||||
| declare i32 @callee2(i8*) | ||||
|  | ||||
| define i32 @callee1(i32 %count) { | ||||
|   %a0 = alloca i8, i32 %count, align 4 | ||||
|   %call0 = call i32 @callee2(i8* %a0) | ||||
|   ret i32 %call0 | ||||
| } | ||||
|  | ||||
| ; CHECK-LABEL: define i32 @caller1( | ||||
| ; CHECK: [[ALLOCA:%[a-z0-9\.]+]] = alloca i8 | ||||
| ; CHECK-NOT: call void @llvm.lifetime.start( | ||||
| ; CHECK: call i32 @callee2(i8* [[ALLOCA]]) | ||||
| ; CHECK-NOT: call void @llvm.lifetime.end( | ||||
|  | ||||
| define i32 @caller1(i32 %count) { | ||||
|   %call0 = call i32 @callee1(i32 0) | ||||
|   ret i32 %call0 | ||||
| } | ||||
		Reference in New Issue
	
	Block a user