mirror of
				https://github.com/c64scene-ar/llvm-6502.git
				synced 2025-10-31 08:16:47 +00:00 
			
		
		
		
	This commit includes a mention of the landingpad instruction, but it's not changing the behavior around it. I think the current behavior is correct, though. Bill, can you double-check that? git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@137691 91177308-0d34-0410-b5e6-96231b3b80d8
		
			
				
	
	
		
			88 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
		
			1.6 KiB
		
	
	
	
		
			LLVM
		
	
	
	
	
	
| ; RUN: opt < %s -simplifycfg -S | FileCheck %s
 | |
| ; PR2967
 | |
| 
 | |
| 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"
 | |
| target triple = "i386-pc-linux-gnu"
 | |
| 
 | |
| define void @test1(i32 %x) nounwind {
 | |
| entry:
 | |
|         %0 = icmp eq i32 %x, 0          ; <i1> [#uses=1]
 | |
|         br i1 %0, label %bb, label %return
 | |
| 
 | |
| bb:             ; preds = %entry
 | |
|         %1 = load volatile i32* null
 | |
|         unreachable
 | |
|         
 | |
|         br label %return
 | |
| return:         ; preds = %entry
 | |
|         ret void
 | |
| ; CHECK: @test1
 | |
| ; CHECK: load volatile
 | |
| }
 | |
| 
 | |
| ; rdar://7958343
 | |
| define void @test2() nounwind {
 | |
| entry:
 | |
|         store i32 4,i32* null
 | |
|         ret void
 | |
|         
 | |
| ; CHECK: @test2
 | |
| ; CHECK: call void @llvm.trap
 | |
| ; CHECK: unreachable
 | |
| }
 | |
| 
 | |
| ; PR7369
 | |
| define void @test3() nounwind {
 | |
| entry:
 | |
|         store volatile i32 4, i32* null
 | |
|         ret void
 | |
| 
 | |
| ; CHECK: @test3
 | |
| ; CHECK: store volatile i32 4, i32* null
 | |
| ; CHECK: ret
 | |
| }
 | |
| 
 | |
| ; Check store before unreachable.
 | |
| define void @test4(i1 %C, i32* %P) {
 | |
| ; CHECK: @test4
 | |
| ; CHECK: entry:
 | |
| ; CHECK-NEXT: br i1 %C
 | |
| entry:
 | |
|   br i1 %C, label %T, label %F
 | |
| T:
 | |
|   store volatile i32 0, i32* %P
 | |
|   unreachable
 | |
| F:
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| ; Check cmpxchg before unreachable.
 | |
| define void @test5(i1 %C, i32* %P) {
 | |
| ; CHECK: @test5
 | |
| ; CHECK: entry:
 | |
| ; CHECK-NEXT: br i1 %C
 | |
| entry:
 | |
|   br i1 %C, label %T, label %F
 | |
| T:
 | |
|   cmpxchg volatile i32* %P, i32 0, i32 1 seq_cst
 | |
|   unreachable
 | |
| F:
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| ; Check atomicrmw before unreachable.
 | |
| define void @test6(i1 %C, i32* %P) {
 | |
| ; CHECK: @test6
 | |
| ; CHECK: entry:
 | |
| ; CHECK-NEXT: br i1 %C
 | |
| entry:
 | |
|   br i1 %C, label %T, label %F
 | |
| T:
 | |
|   atomicrmw volatile xchg i32* %P, i32 0 seq_cst
 | |
|   unreachable
 | |
| F:
 | |
|   ret void
 | |
| }
 | |
| 
 |