1 //===-- lib/adddf3.c - Double-precision subtraction ---------------*- C -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is dual licensed under the MIT and the University of Illinois Open
6 // Source Licenses. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file implements double-precision soft-float subtraction with the
11 // IEEE-754 default rounding (to nearest, ties to even).
13 //===----------------------------------------------------------------------===//
15 #define DOUBLE_PRECISION
18 fp_t COMPILER_RT_ABI
__adddf3(fp_t a
, fp_t b
);
21 ARM_EABI_FNALIAS(dsub
, subdf3
);
23 // Subtraction; flip the sign bit of b and add.
25 __subdf3(fp_t a
, fp_t b
) {
26 return __adddf3(a
, fromRep(toRep(b
) ^ signBit
));
29 /* FIXME: rsub for ARM EABI */