forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			155 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			155 lines
		
	
	
		
			5.6 KiB
		
	
	
	
		
			LLVM
		
	
	
	
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-32R2,TAILCALL-32R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-64R2,TAILCALL-64R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mcpu=mips32r6 -mips-compact-branches=always < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-32R6,TAILCALL-32R6
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mcpu=mips64r6 -mips-compact-branches=always < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-64R6,TAILCALL-64R6
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mcpu=mips32r6 -mips-compact-branches=never < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-32R2,TAILCALL-32R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mcpu=mips64r6 -mips-compact-branches=never < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-64R2,TAILCALL-64R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mattr=+micromips -mcpu=mips32r2 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-MM,TAILCALL-MM
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mattr=+micromips -mcpu=mips32r6 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-MM
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 < %s | FileCheck %s -check-prefixes=ALL,JALR-32R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 < %s | FileCheck %s -check-prefixes=ALL,JALR-64R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mcpu=mips32r6 -mips-compact-branches=always < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-32R6
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mcpu=mips64r6 -mips-compact-branches=always < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-64R6
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mcpu=mips32r6 -mips-compact-branches=never < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-32R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mcpu=mips64r6 -mips-compact-branches=never < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-64R2
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mattr=+micromips -mcpu=mips32r2 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-MM
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mattr=+micromips -mcpu=mips32r6 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,JALR-MM
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mips-jalr-reloc=false < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=static -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O0 -mips-jalr-reloc=false < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips-linux-gnu -relocation-model=static -mips-tail-calls=1 \
 | |
| ; RUN:     -O0 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -mips-jalr-reloc=false < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -mips-tail-calls=1 \
 | |
| ; RUN:     -O2 -relocation-model=static < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=pic \
 | |
| ; RUN:     -O0 -mips-jalr-reloc=false < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| ; RUN: llc -mtriple=mips64-linux-gnu -relocation-model=static \
 | |
| ; RUN:     -O0 < %s | \
 | |
| ; RUN:     FileCheck %s -check-prefixes=ALL,NORELOC
 | |
| 
 | |
| define internal void @foo() noinline {
 | |
| entry:
 | |
|   ret void
 | |
| }
 | |
| 
 | |
| define void @checkCall() {
 | |
| entry:
 | |
| ; ALL-LABEL: checkCall:
 | |
|   call void @foo()
 | |
| ;	JALR-32R2: 	.reloc ([[TMPLABEL:.*]]), R_MIPS_JALR, foo
 | |
| ; JALR-32R2-NEXT: [[TMPLABEL]]:
 | |
| ;	JALR-32R2-NEXT: 	jalr	$25
 | |
| 
 | |
| ;	JALR-64R2: 	.reloc [[TMPLABEL:.*]], R_MIPS_JALR, foo
 | |
| ; JALR-64R2-NEXT: [[TMPLABEL]]:
 | |
| ;	JALR-64R2-NEXT: 	jalr	$25
 | |
| 
 | |
| ;	JALR-MM: 	.reloc ([[TMPLABEL:.*]]), R_MICROMIPS_JALR, foo
 | |
| ; JALR-MM-NEXT: [[TMPLABEL]]:
 | |
| ;	JALR-MM-NEXT: 	jalr	$25
 | |
| 
 | |
| ;	JALR-32R6: 	.reloc ([[TMPLABEL:.*]]), R_MIPS_JALR, foo
 | |
| ; JALR-32R6-NEXT: [[TMPLABEL]]:
 | |
| ;	JALR-32R6-NEXT: 	jalrc	$25
 | |
| 
 | |
| ;	JALR-64R6: 	.reloc [[TMPLABEL:.*]], R_MIPS_JALR, foo
 | |
| ; JALR-64R6-NEXT: [[TMPLABEL]]:
 | |
| ;	JALR-64R6-NEXT: 	jalrc	$25
 | |
| 
 | |
| ; NORELOC-NOT: R_MIPS_JALR
 | |
|  ret void
 | |
| }
 | |
| 
 | |
| define void @checkTailCall() {
 | |
| entry:
 | |
| ; ALL-LABEL: checkTailCall:
 | |
|   tail call void @foo()
 | |
| ;	TAILCALL-32R2: 	.reloc ([[TMPLABEL:.*]]), R_MIPS_JALR, foo
 | |
| ; TAILCALL-32R2-NEXT: [[TMPLABEL]]:
 | |
| ;	TAILCALL-32R2-NEXT: 	jr	$25
 | |
| 
 | |
| ;	TAILCALL-64R2: 	.reloc [[TMPLABEL:.*]], R_MIPS_JALR, foo
 | |
| ; TAILCALL-64R2-NEXT: [[TMPLABEL]]:
 | |
| ;	TAILCALL-64R2-NEXT: 	jr	$25
 | |
| 
 | |
| ;	TAILCALL-MM: 	.reloc ([[TMPLABEL:.*]]), R_MICROMIPS_JALR, foo
 | |
| ; TAILCALL-MM-NEXT: [[TMPLABEL]]:
 | |
| ;	TAILCALL-MM-NEXT: 	jrc	$25
 | |
| 
 | |
| ;	TAILCALL-32R6: 	.reloc ([[TMPLABEL:.*]]), R_MIPS_JALR, foo
 | |
| ; TAILCALL-32R6-NEXT: [[TMPLABEL]]:
 | |
| ;	TAILCALL-32R6-NEXT: 	jrc	$25
 | |
| 
 | |
| ;	TAILCALL-64R6: 	.reloc [[TMPLABEL:.*]], R_MIPS_JALR, foo
 | |
| ; TAILCALL-64R6-NEXT: [[TMPLABEL]]:
 | |
| ;	TAILCALL-64R6-NEXT: 	jrc	$25
 | |
| 
 | |
| ; NORELOC-NOT: R_MIPS_JALR
 | |
|   ret void
 | |
| }
 |