forked from OSchip/llvm-project
				
			
		
			
				
	
	
		
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			LLVM
		
	
	
	
			
		
		
	
	
			76 lines
		
	
	
		
			2.5 KiB
		
	
	
	
		
			LLVM
		
	
	
	
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
 | 
						|
; RUN: llc -march=sparc   < %s | FileCheck %s --check-prefix=V8
 | 
						|
; RUN: llc -march=sparcv9 < %s | FileCheck %s --check-prefix=SPARC64
 | 
						|
 | 
						|
; (this should ideally be doing "add 4+7; and -8", instead of
 | 
						|
;  "add 7; and -8; add 8"; see comments in LowerDYNAMIC_STACKALLOC)
 | 
						|
 | 
						|
define void @variable_alloca_with_adj_call_stack(i32 %num) {
 | 
						|
; V8-LABEL: variable_alloca_with_adj_call_stack:
 | 
						|
; V8:         .cfi_startproc
 | 
						|
; V8-NEXT:  ! %bb.0: ! %entry
 | 
						|
; V8-NEXT:    save %sp, -96, %sp
 | 
						|
; V8-NEXT:    .cfi_def_cfa_register %fp
 | 
						|
; V8-NEXT:    .cfi_window_save
 | 
						|
; V8-NEXT:    .cfi_register %o7, %i7
 | 
						|
; V8-NEXT:    add %i0, 7, %i0
 | 
						|
; V8-NEXT:    and %i0, -8, %i0
 | 
						|
; V8-NEXT:    sub %sp, %i0, %i0
 | 
						|
; V8-NEXT:    add %i0, -8, %sp
 | 
						|
; V8-NEXT:    add %i0, 88, %o0
 | 
						|
; V8-NEXT:    add %sp, -16, %sp
 | 
						|
; V8-NEXT:    st %o0, [%sp+104]
 | 
						|
; V8-NEXT:    st %o0, [%sp+100]
 | 
						|
; V8-NEXT:    st %o0, [%sp+96]
 | 
						|
; V8-NEXT:    st %o0, [%sp+92]
 | 
						|
; V8-NEXT:    mov %o0, %o1
 | 
						|
; V8-NEXT:    mov %o0, %o2
 | 
						|
; V8-NEXT:    mov %o0, %o3
 | 
						|
; V8-NEXT:    mov %o0, %o4
 | 
						|
; V8-NEXT:    call foo
 | 
						|
; V8-NEXT:    mov %o0, %o5
 | 
						|
; V8-NEXT:    add %sp, 16, %sp
 | 
						|
; V8-NEXT:    ret
 | 
						|
; V8-NEXT:    restore
 | 
						|
;
 | 
						|
; SPARC64-LABEL: variable_alloca_with_adj_call_stack:
 | 
						|
; SPARC64:         .cfi_startproc
 | 
						|
; SPARC64-NEXT:  ! %bb.0: ! %entry
 | 
						|
; SPARC64-NEXT:    save %sp, -128, %sp
 | 
						|
; SPARC64-NEXT:    .cfi_def_cfa_register %fp
 | 
						|
; SPARC64-NEXT:    .cfi_window_save
 | 
						|
; SPARC64-NEXT:    .cfi_register %o7, %i7
 | 
						|
; SPARC64-NEXT:    srl %i0, 0, %i0
 | 
						|
; SPARC64-NEXT:    add %i0, 15, %i0
 | 
						|
; SPARC64-NEXT:    sethi 4194303, %i1
 | 
						|
; SPARC64-NEXT:    or %i1, 1008, %i1
 | 
						|
; SPARC64-NEXT:    sethi 0, %i2
 | 
						|
; SPARC64-NEXT:    or %i2, 1, %i2
 | 
						|
; SPARC64-NEXT:    sllx %i2, 32, %i2
 | 
						|
; SPARC64-NEXT:    or %i2, %i1, %i1
 | 
						|
; SPARC64-NEXT:    and %i0, %i1, %i0
 | 
						|
; SPARC64-NEXT:    sub %sp, %i0, %i0
 | 
						|
; SPARC64-NEXT:    add %i0, 2175, %o0
 | 
						|
; SPARC64-NEXT:    mov %i0, %sp
 | 
						|
; SPARC64-NEXT:    add %sp, -80, %sp
 | 
						|
; SPARC64-NEXT:    stx %o0, [%sp+2247]
 | 
						|
; SPARC64-NEXT:    stx %o0, [%sp+2239]
 | 
						|
; SPARC64-NEXT:    stx %o0, [%sp+2231]
 | 
						|
; SPARC64-NEXT:    stx %o0, [%sp+2223]
 | 
						|
; SPARC64-NEXT:    mov %o0, %o1
 | 
						|
; SPARC64-NEXT:    mov %o0, %o2
 | 
						|
; SPARC64-NEXT:    mov %o0, %o3
 | 
						|
; SPARC64-NEXT:    mov %o0, %o4
 | 
						|
; SPARC64-NEXT:    call foo
 | 
						|
; SPARC64-NEXT:    mov %o0, %o5
 | 
						|
; SPARC64-NEXT:    add %sp, 80, %sp
 | 
						|
; SPARC64-NEXT:    ret
 | 
						|
; SPARC64-NEXT:    restore
 | 
						|
entry:
 | 
						|
  %0 = alloca i8, i32 %num, align 8
 | 
						|
  call void @foo(i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0, i8* %0)
 | 
						|
  ret void
 | 
						|
}
 | 
						|
 | 
						|
declare void @foo(i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*, i8*);
 |