1*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mips -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX %s 2*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mipsel -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX %s 3*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mips -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX-INV %s 4*9880d681SAndroid Build Coastguard Worker; RUN: llc -march=mipsel -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX-INV %s 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; RUN-TODO: llc -march=mips64 -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX %s 7*9880d681SAndroid Build Coastguard Worker; RUN-TODO: llc -march=mips64el -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX %s 8*9880d681SAndroid Build Coastguard Worker; RUN-TODO: llc -march=mips64 -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX-INV,O32-FPXX-INV %s 9*9880d681SAndroid Build Coastguard Worker; RUN-TODO: llc -march=mips64el -mattr=+o32,+fpxx < %s | FileCheck --check-prefixes=ALL,O32-FPXX-INV,O32-FPXX-INV %s 10*9880d681SAndroid Build Coastguard Worker 11*9880d681SAndroid Build Coastguard Workerdefine void @fpu_clobber() nounwind { 12*9880d681SAndroid Build Coastguard Workerentry: 13*9880d681SAndroid Build Coastguard Worker call void asm "# Clobber", "~{$f0},~{$f1},~{$f2},~{$f3},~{$f4},~{$f5},~{$f6},~{$f7},~{$f8},~{$f9},~{$f10},~{$f11},~{$f12},~{$f13},~{$f14},~{$f15},~{$f16},~{$f17},~{$f18},~{$f19},~{$f20},~{$f21},~{$f22},~{$f23},~{$f24},~{$f25},~{$f26},~{$f27},~{$f28},~{$f29},~{$f30},~{$f31}"() 14*9880d681SAndroid Build Coastguard Worker ret void 15*9880d681SAndroid Build Coastguard Worker} 16*9880d681SAndroid Build Coastguard Worker 17*9880d681SAndroid Build Coastguard Worker; O32-FPXX-LABEL: fpu_clobber: 18*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f0, 19*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f1, 20*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f2, 21*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f3, 22*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f4, 23*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f5, 24*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f6, 25*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f7, 26*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f8, 27*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f9, 28*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f10, 29*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f11, 30*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f12, 31*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f13, 32*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f14, 33*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f15, 34*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f16, 35*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f17, 36*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f18, 37*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f19, 38*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f21, 39*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f23, 40*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f25, 41*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f27, 42*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f29, 43*9880d681SAndroid Build Coastguard Worker; O32-FPXX-INV-NOT: sdc1 $f31, 44*9880d681SAndroid Build Coastguard Worker 45*9880d681SAndroid Build Coastguard Worker; O32-FPXX: addiu $sp, $sp, -48 46*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F20:\$f20]], [[OFF20:[0-9]+]]($sp) 47*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F22:\$f22]], [[OFF22:[0-9]+]]($sp) 48*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F24:\$f24]], [[OFF24:[0-9]+]]($sp) 49*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F26:\$f26]], [[OFF26:[0-9]+]]($sp) 50*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F28:\$f28]], [[OFF28:[0-9]+]]($sp) 51*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: sdc1 [[F30:\$f30]], [[OFF30:[0-9]+]]($sp) 52*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F20]], [[OFF20]]($sp) 53*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F22]], [[OFF22]]($sp) 54*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F24]], [[OFF24]]($sp) 55*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F26]], [[OFF26]]($sp) 56*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F28]], [[OFF28]]($sp) 57*9880d681SAndroid Build Coastguard Worker; O32-FPXX-DAG: ldc1 [[F30]], [[OFF30]]($sp) 58*9880d681SAndroid Build Coastguard Worker; O32-FPXX: addiu $sp, $sp, 48 59