forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			27 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			27 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; REQUIRES: x86_64-apple, x86-registered-target, arm-registered-target
 | |
| ;
 | |
| ; RUN: rm -rf %t && mkdir -p %t
 | |
| ; RUN: llc -filetype=obj -mtriple=x86_64-apple-macosx -o %t/foo.x86_64.o \
 | |
| ; RUN:   %p/Inputs/foo-return-i32-0.ll
 | |
| ; RUN: llvm-ar r %t/foo.x86_64.a %t/foo.x86_64.o
 | |
| ; RUN: llc -filetype=obj -mtriple=arm-apple-ios -o %t/foo.arm.o \
 | |
| ; RUN:   %p/Inputs/foo-return-i32-0.ll
 | |
| ; RUN: llvm-ar r %t/foo.arm.a %t/foo.arm.o
 | |
| ; RUN: llvm-lipo -create %t/foo.x86_64.a %t/foo.arm.a -output %t/foo.a
 | |
| ; RUN: lli -jit-kind=orc-lazy -extra-archive %t/foo.a %s
 | |
| ;
 | |
| ; Check that MachO universal binaries containing archives work.
 | |
| ; This test compiles two copies of a simple int foo() function that returns
 | |
| ; zero, one copy for x86_64 and one for arm. It then puts each of these in an
 | |
| ; archive and combines these two archives into a macho universal binary.
 | |
| ; Finally we execute a main function that references foo to ensure that the
 | |
| ; x86-64 copy is correctly found and linked.
 | |
| 
 | |
| declare i32 @foo()
 | |
| 
 | |
| define i32 @main(i32 %argc, i8** nocapture readnone %argv) {
 | |
| entry:
 | |
|   %0 = call i32 @foo()
 | |
|   ret i32 %0
 | |
| }
 |