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