public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
From: Adhemerval Zanella Netto <adhemerval.zanella@linaro.org>
To: libc-alpha@sourceware.org, caiyinyu <caiyinyu@loongson.cn>
Cc: joseph_myers@mentor.com
Subject: Re: [PATCH v6 06/13] LoongArch: Generic <math.h> and soft-fp Routines
Date: Wed, 13 Jul 2022 10:25:05 -0300	[thread overview]
Message-ID: <0311e767-ec22-35d4-0753-7745dc88f462@linaro.org> (raw)
In-Reply-To: <20220708065255.2316410-7-caiyinyu@loongson.cn>

Some comments below.

On 08/07/22 03:52, caiyinyu wrote:
> ---
>  sysdeps/loongarch/bits/fenv.h   |  90 ++++++++++++++++++++++++++++
>  sysdeps/loongarch/e_sqrtl.c     |  38 ++++++++++++
>  sysdeps/loongarch/fpu_control.h | 102 ++++++++++++++++++++++++++++++++
>  sysdeps/loongarch/sfp-machine.h | 102 ++++++++++++++++++++++++++++++++
>  sysdeps/loongarch/tininess.h    |   1 +
>  5 files changed, 333 insertions(+)
>  create mode 100644 sysdeps/loongarch/bits/fenv.h
>  create mode 100644 sysdeps/loongarch/e_sqrtl.c
>  create mode 100644 sysdeps/loongarch/fpu_control.h
>  create mode 100644 sysdeps/loongarch/sfp-machine.h
>  create mode 100644 sysdeps/loongarch/tininess.h
> 
> diff --git a/sysdeps/loongarch/bits/fenv.h b/sysdeps/loongarch/bits/fenv.h
> new file mode 100644
> index 0000000000..7e223b402b
> --- /dev/null
> +++ b/sysdeps/loongarch/bits/fenv.h
> @@ -0,0 +1,90 @@
> +/* Floating point environment.
> +   Copyright (C) 2022 Free Software Foundation, Inc.
> +   This file is part of the GNU C Library.
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library 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
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library.  If not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#ifndef _FENV_H
> +#error "Never use <bits/fenv.h> directly; include <fenv.h> instead."
> +#endif
> +
> +/* Define bits representing the exception.  We use the bit positions
> +   of the appropriate bits in the FPU control word.  */
> +enum
> +{
> +  FE_INEXACT =
> +#define FE_INEXACT 0x010000
> +    FE_INEXACT,
> +  FE_UNDERFLOW =
> +#define FE_UNDERFLOW 0x020000
> +    FE_UNDERFLOW,
> +  FE_OVERFLOW =
> +#define FE_OVERFLOW 0x040000
> +    FE_OVERFLOW,
> +  FE_DIVBYZERO =
> +#define FE_DIVBYZERO 0x080000
> +    FE_DIVBYZERO,
> +  FE_INVALID =
> +#define FE_INVALID 0x100000
> +    FE_INVALID,
> +};
> +
> +#define FE_ALL_EXCEPT \
> +  (FE_INEXACT | FE_DIVBYZERO | FE_UNDERFLOW | FE_OVERFLOW | FE_INVALID)
> +
> +/* The LoongArch FPU supports all of the four defined rounding modes.  We
> +   use again the bit positions in the FPU control word as the values
> +   for the appropriate macros.  */
> +enum
> +{
> +  FE_TONEAREST =
> +#define FE_TONEAREST 0x000
> +    FE_TONEAREST,
> +  FE_TOWARDZERO =
> +#define FE_TOWARDZERO 0x100
> +    FE_TOWARDZERO,
> +  FE_UPWARD =
> +#define FE_UPWARD 0x200
> +    FE_UPWARD,
> +  FE_DOWNWARD =
> +#define FE_DOWNWARD 0x300
> +    FE_DOWNWARD
> +};
> +
> +/* Type representing exception flags.  */
> +typedef unsigned int fexcept_t;
> +
> +/* Type representing floating-point environment.  This function corresponds
> +   to the layout of the block written by the `fstenv'.  */
> +typedef struct
> +{
> +  unsigned int __fp_control_register;
> +} fenv_t;
> +
> +/* If the default argument is used we use this value.  */
> +#define FE_DFL_ENV ((const fenv_t *) -1)
> +
> +#ifdef __USE_GNU
> +/* Floating-point environment where none of the exception is masked.  */
> +#define FE_NOMASK_ENV ((const fenv_t *) -257)
> +#endif
> +
> +#if __GLIBC_USE (IEC_60559_BFP_EXT_C2X)
> +/* Type representing floating-point control modes.  */
> +typedef unsigned int femode_t;
> +
> +/* Default floating-point control modes.  */
> +#define FE_DFL_MODE ((const femode_t *) -1L)
> +#endif
> diff --git a/sysdeps/loongarch/e_sqrtl.c b/sysdeps/loongarch/e_sqrtl.c
> new file mode 100644
> index 0000000000..5eb8cc8adb
> --- /dev/null
> +++ b/sysdeps/loongarch/e_sqrtl.c
> @@ -0,0 +1,38 @@
> +/* long double square root in software floating-point emulation.
> +   Copyright (C) 2022 Free Software Foundation, Inc.
> +   This file is part of the GNU C Library.
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library 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
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library.  If not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#include <stdlib.h>
> +#include <soft-fp/soft-fp.h>
> +#include <soft-fp/quad.h>
> +
> +long double
> +__ieee754_sqrtl (const long double a)
> +{
> +  FP_DECL_EX;
> +  FP_DECL_Q (A);
> +  FP_DECL_Q (C);
> +  long double c;
> +
> +  FP_INIT_ROUNDMODE;
> +  FP_UNPACK_Q (A, a);
> +  FP_SQRT_Q (C, A);
> +  FP_PACK_Q (c, C);
> +  FP_HANDLE_EXCEPTIONS;
> +  return c;
> +}
> +strong_alias (__ieee754_sqrtl, __sqrtl_finite)

Ok, but we will need to refactor this because now aarch64, mips64,
riscv, and sparc64 duplicate the same code.

> diff --git a/sysdeps/loongarch/fpu_control.h b/sysdeps/loongarch/fpu_control.h
> new file mode 100644
> index 0000000000..e302ae52b1
> --- /dev/null
> +++ b/sysdeps/loongarch/fpu_control.h
> @@ -0,0 +1,102 @@
> +/* FPU control word bits.
> +   Copyright (C) 2022 Free Software Foundation, Inc.
> +   This file is part of the GNU C Library.
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library 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
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library.  If not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#ifndef _FPU_CONTROL_H
> +#define _FPU_CONTROL_H
> +
> +/* LoongArch FPU floating point control register bits.
> + *
> + * 31-29  -> reserved (read as 0, can not changed by software)
> + * 28     -> cause bit for invalid exception
> + * 27     -> cause bit for division by zero exception
> + * 26     -> cause bit for overflow exception
> + * 25     -> cause bit for underflow exception
> + * 24     -> cause bit for inexact exception
> + * 23-21  -> reserved (read as 0, can not changed by software)
> + * 20     -> flag invalid exception
> + * 19     -> flag division by zero exception
> + * 18     -> flag overflow exception
> + * 17     -> flag underflow exception
> + * 16     -> flag inexact exception
> + *  9-8   -> rounding control
> + *  7-5   -> reserved (read as 0, can not changed by software)
> + *  4     -> enable exception for invalid exception
> + *  3     -> enable exception for division by zero exception
> + *  2     -> enable exception for overflow exception
> + *  1     -> enable exception for underflow exception
> + *  0     -> enable exception for inexact exception
> + *
> + *
> + * Rounding Control:
> + * 00 - rounding ties to even (RNE)
> + * 01 - rounding toward zero (RZ)
> + * 10 - rounding (up) toward plus infinity (RP)
> + * 11 - rounding (down) toward minus infinity (RM)
> + */
> +
> +#include <features.h>
> +
> +#ifdef __loongarch_soft_float
> +
> +#define _FPU_RESERVED 0xffffffff
> +#define _FPU_DEFAULT 0x00000000
> +typedef unsigned int fpu_control_t;
> +#define _FPU_GETCW(cw) (cw) = 0
> +#define _FPU_SETCW(cw) (void) (cw)
> +extern fpu_control_t __fpu_control;

Please remove the softfp pieces since there is no current support.

> +
> +#else /* __loongarch_soft_float */
> +
> +/* Masks for interrupts.  */
> +#define _FPU_MASK_V 0x10 /* Invalid operation */
> +#define _FPU_MASK_Z 0x08 /* Division by zero  */
> +#define _FPU_MASK_O 0x04 /* Overflow */
> +#define _FPU_MASK_U 0x02 /* Underflow */
> +#define _FPU_MASK_I 0x01 /* Inexact operation */
> +
> +/* Flush denormalized numbers to zero.  */
> +#define _FPU_FLUSH_TZ 0x1000000
> +
> +/* Rounding control.  */
> +#define _FPU_RC_NEAREST 0x000 /* RECOMMENDED */
> +#define _FPU_RC_ZERO 0x100
> +#define _FPU_RC_UP 0x200
> +#define _FPU_RC_DOWN 0x300
> +/* Mask for rounding control.  */
> +#define _FPU_RC_MASK 0x300
> +
> +#define _FPU_RESERVED 0x0
> +
> +#define _FPU_DEFAULT 0x0
> +#define _FPU_IEEE 0x1F
> +
> +/* Type of the control word.  */
> +typedef unsigned int fpu_control_t __attribute__ ((__mode__ (__SI__)));
> +
> +/* Macros for accessing the hardware control word.  */
> +extern fpu_control_t __loongarch_fpu_getcw (void) __THROW;
> +extern void __loongarch_fpu_setcw (fpu_control_t) __THROW;
> +#define _FPU_GETCW(cw) __asm__ volatile("movfcsr2gr %0,$r0" : "=r"(cw))
> +#define _FPU_SETCW(cw) __asm__ volatile("movgr2fcsr $r0,%0" : : "r"(cw))

Missing space after volatile.

> +
> +/* Default control word set at startup.  */
> +extern fpu_control_t __fpu_control;
> +
> +#endif /* __loongarch_soft_float */
> +
> +#endif /* fpu_control.h */
> diff --git a/sysdeps/loongarch/sfp-machine.h b/sysdeps/loongarch/sfp-machine.h
> new file mode 100644
> index 0000000000..5b92ac4ba2
> --- /dev/null
> +++ b/sysdeps/loongarch/sfp-machine.h
> @@ -0,0 +1,102 @@
> +/* LoongArch softfloat definitions
> +   Copyright (C) 2022 Free Software Foundation, Inc.
> +   This file is part of the GNU C Library.
> +
> +
> +   The GNU C Library is free software; you can redistribute it and/or
> +   modify it under the terms of the GNU Lesser General Public
> +   License as published by the Free Software Foundation; either
> +   version 2.1 of the License, or (at your option) any later version.
> +
> +   The GNU C Library 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
> +   Lesser General Public License for more details.
> +
> +   You should have received a copy of the GNU Lesser General Public
> +   License along with the GNU C Library.  If not, see
> +   <https://www.gnu.org/licenses/>.  */
> +
> +#include <fenv.h>
> +#include <fpu_control.h>
> +
> +#define _FP_W_TYPE_SIZE 64
> +#define _FP_W_TYPE unsigned long long
> +#define _FP_WS_TYPE signed long long
> +#define _FP_I_TYPE long long
> +
> +#define _FP_MUL_MEAT_S(R, X, Y) _FP_MUL_MEAT_1_imm (_FP_WFRACBITS_S, R, X, Y)
> +#define _FP_MUL_MEAT_D(R, X, Y) \
> +  _FP_MUL_MEAT_1_wide (_FP_WFRACBITS_D, R, X, Y, umul_ppmm)
> +#define _FP_MUL_MEAT_Q(R, X, Y) \
> +  _FP_MUL_MEAT_2_wide_3mul (_FP_WFRACBITS_Q, R, X, Y, umul_ppmm)
> +
> +#define _FP_MUL_MEAT_DW_S(R, X, Y) \
> +  _FP_MUL_MEAT_DW_1_imm (_FP_WFRACBITS_S, R, X, Y)
> +#define _FP_MUL_MEAT_DW_D(R, X, Y) \
> +  _FP_MUL_MEAT_DW_1_wide (_FP_WFRACBITS_D, R, X, Y, umul_ppmm)
> +#define _FP_MUL_MEAT_DW_Q(R, X, Y) \
> +  _FP_MUL_MEAT_DW_2_wide_3mul (_FP_WFRACBITS_Q, R, X, Y, umul_ppmm)
> +
> +#define _FP_DIV_MEAT_S(R, X, Y) \
> +  _FP_DIV_MEAT_1_imm (S, R, X, Y, _FP_DIV_HELP_imm)
> +#define _FP_DIV_MEAT_D(R, X, Y) _FP_DIV_MEAT_1_udiv_norm (D, R, X, Y)
> +#define _FP_DIV_MEAT_Q(R, X, Y) _FP_DIV_MEAT_2_udiv (Q, R, X, Y)
> +
> +#define _FP_NANFRAC_S _FP_QNANBIT_S
> +#define _FP_NANFRAC_D _FP_QNANBIT_D
> +#define _FP_NANFRAC_Q _FP_QNANBIT_Q, 0
> +
> +#define _FP_NANSIGN_S 0
> +#define _FP_NANSIGN_D 0
> +#define _FP_NANSIGN_Q 0
> +
> +#define _FP_KEEPNANFRACP 1
> +#define _FP_QNANNEGATEDP 0
> +
> +/* NaN payloads should be preserved for NAN2008.  */
> +#define _FP_CHOOSENAN(fs, wc, R, X, Y, OP) \
> +  do \
> +    { \
> +      R##_s = X##_s; \
> +      _FP_FRAC_COPY_##wc (R, X); \
> +      R##_c = FP_CLS_NAN; \
> +    } \
> +  while (0)
> +
> +#define _FP_DECL_EX fpu_control_t _fcw
> +
> +#define FP_ROUNDMODE (_fcw & 0x300)
> +
> +#define FP_RND_NEAREST FE_TONEAREST
> +#define FP_RND_ZERO FE_TOWARDZERO
> +#define FP_RND_PINF FE_UPWARD
> +#define FP_RND_MINF FE_DOWNWARD
> +
> +#define FP_EX_INVALID FE_INVALID
> +#define FP_EX_OVERFLOW FE_OVERFLOW
> +#define FP_EX_UNDERFLOW FE_UNDERFLOW
> +#define FP_EX_DIVZERO FE_DIVBYZERO
> +#define FP_EX_INEXACT FE_INEXACT
> +
> +#define _FP_TININESS_AFTER_ROUNDING 1
> +
> +#ifdef __loongarch_hard_float
> +#define FP_INIT_ROUNDMODE \
> +  do \
> +    { \
> +      _FPU_GETCW (_fcw); \
> +    } \
> +  while (0)
> +
> +#define FP_HANDLE_EXCEPTIONS \
> +  do \
> +    { \
> +      if (__glibc_unlikely (_fex)) \
> +	_FPU_SETCW (_fcw | _fex | (_fex << 8)); \
> +    } \
> +  while (0)
> +#define FP_TRAPPING_EXCEPTIONS ((_fcw << 16) & 0x1f0000)
> +#else
> +#define FP_INIT_ROUNDMODE _fcw = FP_RND_NEAREST
> +#endif
> diff --git a/sysdeps/loongarch/tininess.h b/sysdeps/loongarch/tininess.h
> new file mode 100644
> index 0000000000..90956c35f7
> --- /dev/null
> +++ b/sysdeps/loongarch/tininess.h
> @@ -0,0 +1 @@
> +#define TININESS_AFTER_ROUNDING 1

  reply	other threads:[~2022-07-13 13:25 UTC|newest]

Thread overview: 40+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2022-07-08  6:52 [PATCH v6 00/13] GLIBC LoongArch PATCHES caiyinyu
2022-07-08  6:52 ` [PATCH v6 01/13] LoongArch: Update NEWS and README for the LoongArch port caiyinyu
2022-07-12 11:06   ` Adhemerval Zanella Netto
2022-07-08  6:52 ` [PATCH v6 02/13] LoongArch: Add LoongArch entries to config.h.in caiyinyu
2022-07-12 18:51   ` Adhemerval Zanella Netto
2022-07-08  6:52 ` [PATCH v6 03/13] LoongArch: Add relocations and ELF flags to elf.h and scripts/glibcelf.py caiyinyu
2022-07-12 19:27   ` Adhemerval Zanella Netto
2022-07-08  6:52 ` [PATCH v6 04/13] LoongArch: ABI Implementation caiyinyu
2022-07-12 20:39   ` Adhemerval Zanella Netto
2022-07-15  1:46     ` caiyinyu
2022-07-08  6:52 ` [PATCH v6 05/13] LoongArch: Thread-Local Storage Support caiyinyu
2022-07-13 13:10   ` Adhemerval Zanella Netto
2022-07-08  6:52 ` [PATCH v6 06/13] LoongArch: Generic <math.h> and soft-fp Routines caiyinyu
2022-07-13 13:25   ` Adhemerval Zanella Netto [this message]
2022-07-08  6:52 ` [PATCH v6 07/13] LoongArch: Atomic and Locking Routines caiyinyu
2022-07-13 13:53   ` Adhemerval Zanella Netto
2022-07-15  1:46     ` caiyinyu
2022-07-08  6:52 ` [PATCH v6 08/13] LoongArch: Linux Syscall Interface caiyinyu
2022-07-13 16:19   ` Adhemerval Zanella Netto
2023-09-13 11:05     ` caiyinyu
2022-07-08  6:52 ` [PATCH v6 09/13] LoongArch: Linux ABI caiyinyu
2022-07-13 16:35   ` Adhemerval Zanella Netto
2022-07-15  1:48     ` caiyinyu
2022-07-08  6:52 ` [PATCH v6 10/13] LoongArch: Add ABI Lists caiyinyu
2022-07-13 17:12   ` Adhemerval Zanella Netto
2022-07-08  6:52 ` [PATCH v6 11/13] LoongArch: Build Infastructure caiyinyu
2022-07-13  3:07   ` Xi Ruoyao
2022-07-13  3:43     ` WANG Xuerui
2022-07-13  7:51       ` caiyinyu
2022-07-13 17:48   ` Adhemerval Zanella Netto
2022-07-15  1:49     ` caiyinyu
2022-07-08  6:52 ` [PATCH v6 12/13] LoongArch: Hard Float Support caiyinyu
2022-07-13 19:22   ` Adhemerval Zanella Netto
2022-07-14 13:00     ` caiyinyu
2022-07-08  7:13 ` [PATCH v6 00/13] GLIBC LoongArch PATCHES Xi Ruoyao
2022-07-08  7:15   ` Xi Ruoyao
2022-07-13 19:55   ` Adhemerval Zanella Netto
2022-07-14 11:33     ` Xi Ruoyao
2022-07-14 12:11       ` Adhemerval Zanella Netto
2022-07-18 13:54 ` Carlos O'Donell

Reply instructions:

You may reply publicly to this message via plain-text email
using any one of the following methods:

* Save the following mbox file, import it into your mail client,
  and reply-to-all from there: mbox

  Avoid top-posting and favor interleaved quoting:
  https://en.wikipedia.org/wiki/Posting_style#Interleaved_style

* Reply using the --to, --cc, and --in-reply-to
  switches of git-send-email(1):

  git send-email \
    --in-reply-to=0311e767-ec22-35d4-0753-7745dc88f462@linaro.org \
    --to=adhemerval.zanella@linaro.org \
    --cc=caiyinyu@loongson.cn \
    --cc=joseph_myers@mentor.com \
    --cc=libc-alpha@sourceware.org \
    /path/to/YOUR_REPLY

  https://kernel.org/pub/software/scm/git/docs/git-send-email.html

* If your mail client supports setting the In-Reply-To header
  via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).