79b87c74d7
Co-Authored-By: H.J. Lu <hongjiu.lu@intel.com> Co-Authored-By: Marius Cornea <marius.cornea@intel.com> From-SVN: r123185
87 lines
2.6 KiB
C
87 lines
2.6 KiB
C
/* This is a software decimal floating point library.
|
|
Copyright (C) 2007 Free Software Foundation, Inc.
|
|
|
|
This file is part of GCC.
|
|
|
|
GCC is free software; you can redistribute it and/or modify it under
|
|
the terms of the GNU General Public License as published by the Free
|
|
Software Foundation; either version 2, or (at your option) any later
|
|
version.
|
|
|
|
In addition to the permissions in the GNU General Public License, the
|
|
Free Software Foundation gives you unlimited permission to link the
|
|
compiled version of this file into combinations with other programs,
|
|
and to distribute those combinations without any restriction coming
|
|
from the use of this file. (The General Public License restrictions
|
|
do apply in other respects; for example, they cover modification of
|
|
the file, and distribution when not linked into a combine
|
|
executable.)
|
|
|
|
GCC is distributed in the hope that it will be useful, but WITHOUT ANY
|
|
WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
|
FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
|
|
for more details.
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
along with GCC; see the file COPYING. If not, write to the Free
|
|
Software Foundation, 51 Franklin Street, Fifth Floor, Boston, MA
|
|
02110-1301, USA. */
|
|
|
|
/* This implements IEEE 754R decimal floating point arithmetic, but
|
|
does not provide a mechanism for setting the rounding mode, or for
|
|
generating or handling exceptions. Conversions between decimal
|
|
floating point types and other types depend on C library functions.
|
|
|
|
Contributed by Ben Elliston <bje@au.ibm.com>. */
|
|
|
|
/* The intended way to use this file is to make two copies, add `#define '
|
|
to one copy, then compile both copies and add them to libgcc.a. */
|
|
|
|
#include <stdio.h>
|
|
#include <stdlib.h>
|
|
#include <string.h>
|
|
#include <limits.h>
|
|
|
|
#include "config.h"
|
|
#include "gstdint.h"
|
|
#include "bid-dpd.h"
|
|
#include "decimal64.h"
|
|
|
|
uint32_t __dec_byte_swap (uint32_t);
|
|
void __host_to_ieee_64 (_Decimal64 in, decimal64 *out);
|
|
void __ieee_to_host_64 (decimal64 in, _Decimal64 *out);
|
|
|
|
#ifndef WORDS_BIGENDIAN
|
|
#define WORDS_BIGENDIAN 0
|
|
#endif
|
|
|
|
static void
|
|
__swap64 (char *src, char *dst)
|
|
{
|
|
uint32_t t1, t2;
|
|
|
|
if (!WORDS_BIGENDIAN)
|
|
{
|
|
memcpy (&t1, src, 4);
|
|
memcpy (&t2, src + 4, 4);
|
|
t1 = __dec_byte_swap (t1);
|
|
t2 = __dec_byte_swap (t2);
|
|
memcpy (dst, &t2, 4);
|
|
memcpy (dst + 4, &t1, 4);
|
|
}
|
|
else
|
|
memcpy (dst, src, 8);
|
|
}
|
|
|
|
void
|
|
__host_to_ieee_64 (_Decimal64 in, decimal64 *out)
|
|
{
|
|
__swap64 ((char *) &in, (char *) out);
|
|
}
|
|
|
|
void
|
|
__ieee_to_host_64 (decimal64 in, _Decimal64 *out)
|
|
{
|
|
__swap64 ((char *) &in, (char *) out);
|
|
}
|