1//===-- aeabi_cfcmp.S - EABI cfcmp* implementation ------------------------===//
2//
3//                     The LLVM Compiler Infrastructure
4//
5// This file is dual licensed under the MIT and the University of Illinois Open
6// Source Licenses. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#include "../assembly.h"
11
12#if __BYTE_ORDER__ != __ORDER_LITTLE_ENDIAN__
13#error big endian support not implemented
14#endif
15
16#define APSR_Z (1 << 30)
17#define APSR_C (1 << 29)
18
19// void __aeabi_cfcmpeq(float a, float b) {
20//   if (isnan(a) || isnan(b)) {
21//     Z = 0; C = 1;
22//   } else {
23//     __aeabi_cfcmple(a, b);
24//   }
25// }
26
27        .syntax unified
28        .p2align 2
29DEFINE_COMPILERRT_FUNCTION(__aeabi_cfcmpeq)
30        push {r0-r3, lr}
31        bl __aeabi_cfcmpeq_check_nan
32        cmp r0, #1
33        pop {r0-r3, lr}
34
35        // NaN has been ruled out, so __aeabi_cfcmple can't trap
36        bne __aeabi_cfcmple
37
38        msr CPSR_f, #APSR_C
39        JMP(lr)
40END_COMPILERRT_FUNCTION(__aeabi_cfcmpeq)
41
42
43// void __aeabi_cfcmple(float a, float b) {
44//   if (__aeabi_fcmplt(a, b)) {
45//     Z = 0; C = 0;
46//   } else if (__aeabi_fcmpeq(a, b)) {
47//     Z = 1; C = 1;
48//   } else {
49//     Z = 0; C = 1;
50//   }
51// }
52
53        .syntax unified
54        .p2align 2
55DEFINE_COMPILERRT_FUNCTION(__aeabi_cfcmple)
56        // Per the RTABI, this function must preserve r0-r11.
57        // Save lr in the same instruction for compactness
58        push {r0-r3, lr}
59
60        bl __aeabi_fcmplt
61        cmp r0, #1
62        moveq ip, #0
63        beq 1f
64
65        ldm sp, {r0-r3}
66        bl __aeabi_fcmpeq
67        cmp r0, #1
68        moveq ip, #(APSR_C | APSR_Z)
69        movne ip, #(APSR_C)
70
711:
72        msr CPSR_f, ip
73        pop {r0-r3}
74        POP_PC()
75END_COMPILERRT_FUNCTION(__aeabi_cfcmple)
76
77// int __aeabi_cfrcmple(float a, float b) {
78//   return __aeabi_cfcmple(b, a);
79// }
80
81        .syntax unified
82        .p2align 2
83DEFINE_COMPILERRT_FUNCTION(__aeabi_cfrcmple)
84        // Swap r0 and r1
85        mov ip, r0
86        mov r0, r1
87        mov r1, ip
88
89        b __aeabi_cfcmple
90END_COMPILERRT_FUNCTION(__aeabi_cfrcmple)
91
92