| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -mattr=+fp64 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32R2-FP64 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -mattr=+soft-float -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32R2-SF | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r3 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32R3R5 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r5 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32R3R5 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r6 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M32R6 | 
 | ; RUN: llc < %s -mtriple=mips64-linux-gnu -mcpu=mips3 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M64 | 
 | ; RUN: llc < %s -mtriple=mips64-linux-gnu -mcpu=mips64 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M64 | 
 | ; RUN: llc < %s -mtriple=mips64-linux-gnu -mcpu=mips64r2 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M64 | 
 | ; RUN: llc < %s -mtriple=mips64-linux-gnu -mcpu=mips64r6 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=M64R6 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -mattr=+micromips -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=MMR2-FP32 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -mattr=+micromips,fp64 -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=MMR2-FP64 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r2 -mattr=+micromips,soft-float -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=MMR2-SF | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r6 -mattr=+micromips -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=MMR6 | 
 | ; RUN: llc < %s -mtriple=mips-linux-gnu -mcpu=mips32r6 -mattr=+micromips,soft-float -asm-show-inst |\ | 
 | ; RUN:   FileCheck %s -check-prefixes=MMR6-SF | 
 |  | 
 | ; Test that fptosi can be matched for MIPS targets for various FPU | 
 | ; configurations | 
 |  | 
 | define i32 @test1(float %t) { | 
 | ; M32-LABEL: test1: | 
 | ; M32:       # %bb.0: # %entry | 
 | ; M32-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R2-FP64-LABEL: test1: | 
 | ; M32R2-FP64:       # %bb.0: # %entry | 
 | ; M32R2-FP64-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-FP64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-FP64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R2-SF-LABEL: test1: | 
 | ; M32R2-SF:       # %bb.0: # %entry | 
 | ; M32R2-SF-NEXT:    addiu $sp, $sp, -24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; M32R2-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; M32R2-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; M32R2-SF-NEXT:    # <MCInst #{{[0-9]+}} SW | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; M32R2-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; M32R2-SF-NEXT:    jal __fixsfsi # <MCInst #{{[0-9]+}} JAL | 
 | ; M32R2-SF-NEXT:    # <MCOperand Expr:(__fixsfsi)>> | 
 | ; M32R2-SF-NEXT:    nop # <MCInst #{{[0-9]+}} SLL | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:0>> | 
 | ; M32R2-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; M32R2-SF-NEXT:    # <MCInst #{{[0-9]+}} LW | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; M32R2-SF-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-SF-NEXT:    addiu $sp, $sp, 24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; | 
 | ; M32R3R5-LABEL: test1: | 
 | ; M32R3R5:       # %bb.0: # %entry | 
 | ; M32R3R5-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R3R5-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R3R5-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R6-LABEL: test1: | 
 | ; M32R6:       # %bb.0: # %entry | 
 | ; M32R6-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R6-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JALR | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M64-LABEL: test1: | 
 | ; M64:       # %bb.0: # %entry | 
 | ; M64-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M64R6-LABEL: test1: | 
 | ; M64R6:       # %bb.0: # %entry | 
 | ; M64R6-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64R6-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JALR64 | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64R6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-FP32-LABEL: test1: | 
 | ; MMR2-FP32:       # %bb.0: # %entry | 
 | ; MMR2-FP32-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP32-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP32-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-FP64-LABEL: test1: | 
 | ; MMR2-FP64:       # %bb.0: # %entry | 
 | ; MMR2-FP64-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-SF-LABEL: test1: | 
 | ; MMR2-SF:       # %bb.0: # %entry | 
 | ; MMR2-SF-NEXT:    addiusp -24 # <MCInst #{{[0-9]+}} ADDIUSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; MMR2-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; MMR2-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; MMR2-SF-NEXT:    # <MCInst #{{[0-9]+}} SWSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR2-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; MMR2-SF-NEXT:    jal __fixsfsi # <MCInst #{{[0-9]+}} JAL_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Expr:(__fixsfsi)>> | 
 | ; MMR2-SF-NEXT:    nop # <MCInst #{{[0-9]+}} SLL | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:0>> | 
 | ; MMR2-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; MMR2-SF-NEXT:    # <MCInst #{{[0-9]+}} LWSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR2-SF-NEXT:    addiusp 24 # <MCInst #{{[0-9]+}} ADDIUSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; MMR2-SF-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR6-LABEL: test1: | 
 | ; MMR6:       # %bb.0: # %entry | 
 | ; MMR6-NEXT:    trunc.w.s $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_S_MMR6 | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR6-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR6-SF-LABEL: test1: | 
 | ; MMR6-SF:       # %bb.0: # %entry | 
 | ; MMR6-SF-NEXT:    addiu $sp, $sp, -24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; MMR6-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; MMR6-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; MMR6-SF-NEXT:    # <MCInst #{{[0-9]+}} SW | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR6-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; MMR6-SF-NEXT:    balc __fixsfsi # <MCInst #{{[0-9]+}} BALC_MMR6 | 
 | ; MMR6-SF-NEXT:    # <MCOperand Expr:(__fixsfsi)>> | 
 | ; MMR6-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; MMR6-SF-NEXT:    # <MCInst #{{[0-9]+}} LW | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR6-SF-NEXT:    addiu $sp, $sp, 24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; MMR6-SF-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | entry: | 
 |   %conv = fptosi float %t to i32 | 
 |   ret i32 %conv | 
 | } | 
 |  | 
 | define i32 @test2(double %t) { | 
 | ; M32-LABEL: test2: | 
 | ; M32:       # %bb.0: # %entry | 
 | ; M32-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D32 | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R2-FP64-LABEL: test2: | 
 | ; M32R2-FP64:       # %bb.0: # %entry | 
 | ; M32R2-FP64-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D64 | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-FP64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-FP64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R2-SF-LABEL: test2: | 
 | ; M32R2-SF:       # %bb.0: # %entry | 
 | ; M32R2-SF-NEXT:    addiu $sp, $sp, -24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; M32R2-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; M32R2-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; M32R2-SF-NEXT:    # <MCInst #{{[0-9]+}} SW | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; M32R2-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; M32R2-SF-NEXT:    jal __fixdfsi # <MCInst #{{[0-9]+}} JAL | 
 | ; M32R2-SF-NEXT:    # <MCOperand Expr:(__fixdfsi)>> | 
 | ; M32R2-SF-NEXT:    nop # <MCInst #{{[0-9]+}} SLL | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:0>> | 
 | ; M32R2-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; M32R2-SF-NEXT:    # <MCInst #{{[0-9]+}} LW | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; M32R2-SF-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R2-SF-NEXT:    addiu $sp, $sp, 24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R2-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; | 
 | ; M32R3R5-LABEL: test2: | 
 | ; M32R3R5:       # %bb.0: # %entry | 
 | ; M32R3R5-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D32 | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R3R5-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R3R5-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R3R5-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M32R6-LABEL: test2: | 
 | ; M32R6:       # %bb.0: # %entry | 
 | ; M32R6-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D64 | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R6-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JALR | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M32R6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M32R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M64-LABEL: test2: | 
 | ; M64:       # %bb.0: # %entry | 
 | ; M64-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D64 | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; M64R6-LABEL: test2: | 
 | ; M64R6:       # %bb.0: # %entry | 
 | ; M64R6-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D64 | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64R6-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JALR64 | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; M64R6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1 | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; M64R6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-FP32-LABEL: test2: | 
 | ; MMR2-FP32:       # %bb.0: # %entry | 
 | ; MMR2-FP32-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP32-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP32-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP32-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-FP64-LABEL: test2: | 
 | ; MMR2-FP64:       # %bb.0: # %entry | 
 | ; MMR2-FP64-NEXT:    cvt.w.d $f0, $f12 # <MCInst #{{[0-9]+}} CVT_W_D64_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP64-NEXT:    jr $ra # <MCInst #{{[0-9]+}} JR_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR2-FP64-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-FP64-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR2-SF-LABEL: test2: | 
 | ; MMR2-SF:       # %bb.0: # %entry | 
 | ; MMR2-SF-NEXT:    addiusp -24 # <MCInst #{{[0-9]+}} ADDIUSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; MMR2-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; MMR2-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; MMR2-SF-NEXT:    # <MCInst #{{[0-9]+}} SWSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR2-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; MMR2-SF-NEXT:    jal __fixdfsi # <MCInst #{{[0-9]+}} JAL_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Expr:(__fixdfsi)>> | 
 | ; MMR2-SF-NEXT:    nop # <MCInst #{{[0-9]+}} SLL | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:0>> | 
 | ; MMR2-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; MMR2-SF-NEXT:    # <MCInst #{{[0-9]+}} LWSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR2-SF-NEXT:    addiusp 24 # <MCInst #{{[0-9]+}} ADDIUSP_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; MMR2-SF-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR2-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR6-LABEL: test2: | 
 | ; MMR6:       # %bb.0: # %entry | 
 | ; MMR6-NEXT:    trunc.w.d $f0, $f12 # <MCInst #{{[0-9]+}} TRUNC_W_D_MMR6 | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR6-NEXT:    mfc1 $2, $f0 # <MCInst #{{[0-9]+}} MFC1_MM | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; MMR6-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR6-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | ; | 
 | ; MMR6-SF-LABEL: test2: | 
 | ; MMR6-SF:       # %bb.0: # %entry | 
 | ; MMR6-SF-NEXT:    addiu $sp, $sp, -24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:-24>> | 
 | ; MMR6-SF-NEXT:    .cfi_def_cfa_offset 24 | 
 | ; MMR6-SF-NEXT:    sw $ra, 20($sp) # 4-byte Folded Spill | 
 | ; MMR6-SF-NEXT:    # <MCInst #{{[0-9]+}} SW | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR6-SF-NEXT:    .cfi_offset 31, -4 | 
 | ; MMR6-SF-NEXT:    balc __fixdfsi # <MCInst #{{[0-9]+}} BALC_MMR6 | 
 | ; MMR6-SF-NEXT:    # <MCOperand Expr:(__fixdfsi)>> | 
 | ; MMR6-SF-NEXT:    lw $ra, 20($sp) # 4-byte Folded Reload | 
 | ; MMR6-SF-NEXT:    # <MCInst #{{[0-9]+}} LW | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:20>> | 
 | ; MMR6-SF-NEXT:    addiu $sp, $sp, 24 # <MCInst #{{[0-9]+}} ADDiu | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}> | 
 | ; MMR6-SF-NEXT:    # <MCOperand Imm:24>> | 
 | ; MMR6-SF-NEXT:    jrc $ra # <MCInst #{{[0-9]+}} JRC16_MM | 
 | ; MMR6-SF-NEXT:    # <MCOperand Reg:{{[0-9]+}}>> | 
 | entry: | 
 |   %conv = fptosi double %t to i32 | 
 |   ret i32 %conv | 
 | } |