summaryrefslogtreecommitdiffstats
path: root/newlib/libm/machine/nds32/wf_sqrt.S
diff options
context:
space:
mode:
Diffstat (limited to 'newlib/libm/machine/nds32/wf_sqrt.S')
-rw-r--r--newlib/libm/machine/nds32/wf_sqrt.S68
1 files changed, 68 insertions, 0 deletions
diff --git a/newlib/libm/machine/nds32/wf_sqrt.S b/newlib/libm/machine/nds32/wf_sqrt.S
new file mode 100644
index 000000000..e000d7536
--- /dev/null
+++ b/newlib/libm/machine/nds32/wf_sqrt.S
@@ -0,0 +1,68 @@
+/*
+Copyright (c) 2013-2014 Andes Technology Corporation.
+All rights reserved.
+
+Redistribution and use in source and binary forms, with or without
+modification, are permitted provided that the following conditions are met:
+
+ Redistributions of source code must retain the above copyright
+ notice, this list of conditions and the following disclaimer.
+
+ Redistributions in binary form must reproduce the above copyright
+ notice, this list of conditions and the following disclaimer in the
+ documentation and/or other materials provided with the distribution.
+
+ The name of the company may not be used to endorse or promote
+ products derived from this software without specific prior written
+ permission.
+
+THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
+DISCLAIMED. IN NO EVENT SHALL RED HAT INCORPORATED BE LIABLE FOR ANY
+DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
+(INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
+LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
+ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
+(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
+SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+*/
+ .text
+ .align 1
+ .global sqrtf
+ .type sqrtf, @function
+sqrtf:
+ /* The input argument is supposed to be stored in $fs0.
+ The return value is supposed to be stored in $fs0 either. */
+
+ /* Clear the IEEE cumulative exceptions flags. ($fpcsr.b[6:2]) */
+ FMFCSR $r0
+ bitci $r0, $r0, #0b1111100
+ FMTCSR $r0
+
+ fsqrts $fs0, $fs0
+
+ /* Check the IEEE cumulative exceptions flags. */
+ FMFCSR $r5
+ bmski33 $r5, #2 /* Is $fpcsr.IVO('b2) set ? */
+ bnez $r5, .L_EDOM /* Set errno as EDOM. */
+
+ bmski33 $r5, #4 /* Is $fpcsr.OVF('b4) set ? */
+ bnez $r5, .L_ERANGE /* Set errno as ERANGE. */
+
+ bmski33 $r5, #5 /* Is $fpcsr.UDF('b5) set ? */
+ bnez $r5, .L_ERANGE /* Set errno as ERANGE. */
+
+ /* No error at all. Just ret. */
+ ret
+
+.L_EDOM:
+ movi $r0, #33 /* EDOM: Math arg out of domain of func. */
+ j .L_Set_errno
+.L_ERANGE:
+ movi $r0, #34 /* ERANGE: Math result not representable. */
+.L_Set_errno:
+ l.w $r15, _impure_ptr
+ swi $r0, [$r15] /* Set errno. */
+ ret
+ .size sqrtf, .-sqrtf