42 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			42 lines
		
	
	
		
			1.0 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; RUN: opt < %s -instcombine -S | FileCheck %s
 | |
| 
 | |
| ; Don't assume that external global variables or those with weak linkage have
 | |
| ; their preferred alignment. They may only have the ABI minimum alignment.
 | |
| 
 | |
| target datalayout = "i32:8:32"
 | |
| 
 | |
| @A = external global i32
 | |
| @B = weak_odr global i32 0
 | |
| 
 | |
| @C = available_externally global <4 x i32> zeroinitializer, align 4
 | |
| ; CHECK: @C = available_externally global <4 x i32> zeroinitializer, align 4
 | |
| 
 | |
| define i64 @foo(i64 %a) {
 | |
|   %t = ptrtoint i32* @A to i64
 | |
|   %s = shl i64 %a, 3
 | |
|   %r = or i64 %t, %s
 | |
|   %q = add i64 %r, 1
 | |
|   ret i64 %q
 | |
| }
 | |
| 
 | |
| ; CHECK-LABEL: define i64 @foo(i64 %a)
 | |
| ; CHECK: %s = shl i64 %a, 3
 | |
| ; CHECK: %r = or i64 %s, ptrtoint (i32* @A to i64)
 | |
| ; CHECK: %q = add i64 %r, 1
 | |
| ; CHECK: ret i64 %q
 | |
| 
 | |
| define i32 @bar() {
 | |
|   %r = load i32, i32* @B, align 1
 | |
|   ret i32 %r
 | |
| }
 | |
| 
 | |
| ; CHECK-LABEL: @bar()
 | |
| ; CHECK: align 1
 | |
| 
 | |
| define void @vec_store() {
 | |
|   store <4 x i32> <i32 0, i32 1, i32 2, i32 3>, <4 x i32>* @C, align 4
 | |
|   ret void
 | |
| }
 | |
| ; CHECK: define void @vec_store()
 | |
| ; CHECK: store <4 x i32> <i32 0, i32 1, i32 2, i32 3>, <4 x i32>* @C, align 4
 |