blob: 1b2ac19cba0056622f6c1cff670950dbc316279b [file] [log] [blame]
Simon Pilgrim68c0e5a2018-10-27 15:00:38 +00001; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
2; RUN: llc < %s -mtriple=mips-- | FileCheck %s
Bruno Cardoso Lopes6b9077a2008-08-08 04:03:25 +00003
4define i32 @fptoint(float %a) nounwind {
Simon Pilgrim68c0e5a2018-10-27 15:00:38 +00005; CHECK-LABEL: fptoint:
6; CHECK: # %bb.0: # %entry
7; CHECK-NEXT: trunc.w.s $f0, $f12
8; CHECK-NEXT: jr $ra
9; CHECK-NEXT: mfc1 $2, $f0
Bruno Cardoso Lopes6b9077a2008-08-08 04:03:25 +000010entry:
Akira Hatanakabbc55552011-12-02 22:28:09 +000011 fptosi float %a to i32 ; <i32>:0 [#uses=1]
12 ret i32 %0
Bruno Cardoso Lopes6b9077a2008-08-08 04:03:25 +000013}
14
15define i32 @fptouint(float %a) nounwind {
Simon Pilgrim68c0e5a2018-10-27 15:00:38 +000016; CHECK-LABEL: fptouint:
17; CHECK: # %bb.0: # %entry
18; CHECK-NEXT: lui $1, %hi($CPI1_0)
19; CHECK-NEXT: lwc1 $f0, %lo($CPI1_0)($1)
20; CHECK-NEXT: sub.s $f1, $f12, $f0
21; CHECK-NEXT: trunc.w.s $f1, $f1
22; CHECK-NEXT: mfc1 $1, $f1
23; CHECK-NEXT: lui $2, 32768
24; CHECK-NEXT: xor $2, $1, $2
25; CHECK-NEXT: trunc.w.s $f1, $f12
26; CHECK-NEXT: mfc1 $1, $f1
27; CHECK-NEXT: c.olt.s $f12, $f0
28; CHECK-NEXT: jr $ra
29; CHECK-NEXT: movt $2, $1, $fcc0
Bruno Cardoso Lopes6b9077a2008-08-08 04:03:25 +000030entry:
Akira Hatanakabbc55552011-12-02 22:28:09 +000031 fptoui float %a to i32 ; <i32>:0 [#uses=1]
32 ret i32 %0
Bruno Cardoso Lopes6b9077a2008-08-08 04:03:25 +000033}