1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
|
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -mtriple=mipsel-linux-gnu -mcpu=mips3 -target-abi o32 < %s | FileCheck %s -check-prefixes=MIPS3-O32
; RUN: llc -mtriple=mipsel-linux-gnu -mcpu=mips3 -target-abi n32 < %s | FileCheck %s -check-prefixes=MIPS3-N32
; RUN: llc -mtriple=mipsel-linux-gnu -mcpu=mips3 -target-abi n64 < %s | FileCheck %s -check-prefixes=MIPS3-N64
define void @func(ptr nocapture %x, ...) nounwind {
; MIPS3-O32-LABEL: func:
; MIPS32-O32: # %bb.0: # %entry
; MIPS32-O32-NEXT: addiu $sp, $sp, -48
; MIPS32-O32-NEXT: sd $11, 56($sp)
; MIPS32-O32-NEXT: sd $10, 48($sp)
; MIPS32-O32-NEXT: sd $9, 40($sp)
; MIPS32-O32-NEXT: sd $8, 32($sp)
; MIPS32-O32-NEXT: sd $7, 24($sp)
; MIPS32-O32-NEXT: sd $6, 16($sp)
; MIPS32-O32-NEXT: sd $5, 8($sp)
; MIPS32-O32-NEXT: sw $4, 4($sp)
; MIPS32-O32-NEXT: jr $ra
; MIPS32-O32-NEXT: addiu $sp, $sp, 48
;
; MIPS3-N32-LABEL: func:
; MIPS32-N32: # %bb.0: # %entry
; MIPS32-N32-NEXT: addiu $sp, $sp, -64
; MIPS32-N32-NEXT: sd $11, 56($sp)
; MIPS32-N32-NEXT: sd $10, 48($sp)
; MIPS32-N32-NEXT: sd $9, 40($sp)
; MIPS32-N32-NEXT: sd $8, 32($sp)
; MIPS32-N32-NEXT: sd $7, 24($sp)
; MIPS32-N32-NEXT: sd $6, 16($sp)
; MIPS32-N32-NEXT: sd $5, 8($sp)
; MIPS32-N32-NEXT: sw $4, 4($sp)
; MIPS32-N32-NEXT: jr $ra
; MIPS32-N32-NEXT: addiu $sp, $sp, 64
;
; MIPS3-N64-LABEL: func:
; MIPS32-N64: # %bb.0: # %entry
; MIPS32-N64-NEXT: addiu $sp, $sp, -64
; MIPS32-N64-NEXT: sdl $4, 7($sp)
; MIPS32-N64-NEXT: sd $11, 56($sp)
; MIPS32-N64-NEXT: sd $10, 48($sp)
; MIPS32-N64-NEXT: sd $9, 40($sp)
; MIPS32-N64-NEXT: sd $8, 32($sp)
; MIPS32-N64-NEXT: sd $7, 24($sp)
; MIPS32-N64-NEXT: sd $6, 16($sp)
; MIPS32-N64-NEXT: sd $5, 8($sp)
; MIPS32-N64-NEXT: sw $4, 4($sp)
; MIPS32-N64-NEXT: jr $ra
; MIPS32-N64-NEXT: addiu $sp, $sp, 64
entry:
%x.addr = alloca ptr, align 4
store ptr %x, ptr %x.addr, align 4
ret void
}
|