mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-25 10:27:04 +00:00 
			
		
		
		
	Change `llc` and `opt` to run `verifyModule()`.  This ensures that we
check the full module before `FunctionPass::doInitialization()` ever
gets called (I was getting crashes in `DwarfDebug` instead of verifier
failures when testing a WIP patch that checks operands of compile
units).  In `opt`, also move up debug-info-stripping so that it still
runs before verification.
There was a fair bit of broken code that was sitting in tree.
Interestingly, some were cases of a `select` that referred to itself in
`-instcombine` tests (apparently an intermediate result).  I split them
off to `*-noverify.ll` tests with RUN lines like this:
    opt < %s -S -disable-verify -instcombine | opt -S | FileCheck %s
This avoids verifying the input file (so we can get the broken code into
`-instcombine), but still verifies the output with a second call to
`opt` (to verify that `-instcombine` will clean it up like it should).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@233432 91177308-0d34-0410-b5e6-96231b3b80d8
		
	
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; Test objectsize bounds checking that won't verify until after -instcombine.
 | |
| ; RUN: opt < %s -disable-verify -instcombine -S | opt -S | FileCheck %s
 | |
| ; We need target data to get the sizes of the arrays and structures.
 | |
| target datalayout = "e-p:32:32:32-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:32:64-f32:32:32-f64:32:64-v64:64:64-v128:128:128-a0:0:64-f80:128:128"
 | |
| 
 | |
| declare i32 @llvm.objectsize.i32.p0i8(i8*, i1) nounwind readonly
 | |
| 
 | |
| ; CHECK-LABEL: @PR13390(
 | |
| define i32 @PR13390(i1 %bool, i8* %a) {
 | |
| entry:
 | |
|   %cond = or i1 %bool, true
 | |
|   br i1 %cond, label %return, label %xpto
 | |
| 
 | |
| xpto:
 | |
|   %select = select i1 %bool, i8* %select, i8* %a
 | |
|   %select2 = select i1 %bool, i8* %a, i8* %select2
 | |
|   %0 = tail call i32 @llvm.objectsize.i32.p0i8(i8* %select, i1 true)
 | |
|   %1 = tail call i32 @llvm.objectsize.i32.p0i8(i8* %select2, i1 true)
 | |
|   %2 = add i32 %0, %1
 | |
| ; CHECK: ret i32 undef
 | |
|   ret i32 %2
 | |
| 
 | |
| return:
 | |
|   ret i32 42
 | |
| }
 | |
| 
 | |
| ; CHECK-LABEL: @PR13621(
 | |
| define i32 @PR13621(i1 %bool) nounwind {
 | |
| entry:
 | |
|   %cond = or i1 %bool, true
 | |
|   br i1 %cond, label %return, label %xpto
 | |
| 
 | |
| ; technically reachable, but this malformed IR may appear as a result of constant propagation
 | |
| xpto:
 | |
|   %gep2 = getelementptr i8, i8* %gep, i32 1
 | |
|   %gep = getelementptr i8, i8* %gep2, i32 1
 | |
|   %o = call i32 @llvm.objectsize.i32.p0i8(i8* %gep, i1 true)
 | |
| ; CHECK: ret i32 undef
 | |
|   ret i32 %o
 | |
| 
 | |
| return:
 | |
|   ret i32 7
 | |
| }
 |