]> CyberLeo.Net >> Repos - FreeBSD/releng/10.3.git/blob - lib/libc/arm/aeabi/aeabi_asm_double.S
- Copy stable/10@296371 to releng/10.3 in preparation for 10.3-RC1
[FreeBSD/releng/10.3.git] / lib / libc / arm / aeabi / aeabi_asm_double.S
1 /*
2  * Copyright (C) 2014 Andrew Turner
3  * All rights reserved.
4  *
5  * Redistribution and use in source and binary forms, with or without
6  * modification, are permitted provided that the following conditions
7  * are met:
8  * 1. Redistributions of source code must retain the above copyright
9  *    notice, this list of conditions and the following disclaimer.
10  * 2. Redistributions in binary form must reproduce the above copyright
11  *    notice, this list of conditions and the following disclaimer in the
12  *    documentation and/or other materials provided with the distribution.
13  *
14  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
15  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
16  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
17  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
18  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
19  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
20  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
21  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
22  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
23  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
24  * SUCH DAMAGE.
25  *
26  */
27
28 #include <machine/asm.h>
29 __FBSDID("$FreeBSD$");
30
31 #define PCR_Z   (1 << 30)
32 #define PCR_C   (1 << 29)
33
34 /*
35  * These functions return the result in the CPSR register.
36  *
37  * For __aeabi_cdcmple:
38  *      Z C
39  *   LT 0 0
40  *   EQ 1 1
41  * else 0 1
42  *
43  * __aeabi_cdrcmple is the same as __aeabi_cdcmple, however the arguments
44  * have been swapped.
45  */
46 ENTRY(__aeabi_cdcmple)
47         push    {r4, r5, r6, r7, ip, lr}
48
49         /* Backup the input registers */
50         mov     r4, r0
51         mov     r5, r1
52         mov     r6, r2
53         mov     r7, r3
54         /* Is it less than? */
55         bl      __aeabi_dcmplt
56         cmp     r0, #1
57         bne     1f
58         /* Yes, clear Z and C */
59         msr     cpsr_c, #(0)
60         b       99f
61
62 1:
63         /* Restore the input regsters for the next function call */
64         mov     r0, r4
65         mov     r1, r5
66         mov     r2, r6
67         mov     r3, r7
68         /* Is it equal? */
69         bl      __aeabi_dcmpeq
70         cmp     r0, #1
71         bne     2f
72         /* Yes, set Z and C */
73         msr     cpsr_c, #(PCR_Z | PCR_C)
74         b 99f
75
76 2:
77         /* Not less than or equal, set C and clear Z */
78         msr     cpsr_c, #(PCR_C)
79
80 99:
81         pop     {r4, r5, r6, r7, ip, pc}
82 END(__aeabi_cdcmple)
83
84 ENTRY(__aeabi_cdrcmple)
85         /* Swap the first half of the arguments */
86         mov     ip, r0
87         mov     r0, r2
88         mov     r2, ip
89
90         /* And the second half */
91         mov     ip, r1
92         mov     r1, r3
93         mov     r3, ip
94
95         b       __aeabi_cdcmple
96 END(__aeabi_cdrcmple)
97
98 /*
99  * This is just like __aeabi_cdcmple except it will not throw an exception
100  * in the presence of a quiet NaN. If either argument is a signalling NaN we
101  * will still signal.
102  */
103 ENTRY(__aeabi_cdcmpeq)
104         /* Check if we can call __aeabi_cfcmple safely */
105         push    {r0, r1, r2, r3, r4, lr}
106         bl      __aeabi_cdcmpeq_helper
107         cmp     r0, #1
108         pop     {r0, r1, r2, r3, r4, lr}
109         beq     1f
110
111         bl      __aeabi_cdcmple
112         RET
113
114 1:
115         msr     cpsr_c, #(PCR_C)
116         RET
117 END(__aeabi_cdcmpeq)