public inbox for libc-alpha@sourceware.org
 help / color / mirror / Atom feed
From: "Lucas A. M. Magalhaes" <lamm@linux.ibm.com>
To: Raphael Moreira Zinsly <rzinsly@linux.ibm.com>,
	libc-alpha@sourceware.org
Cc: murphyp@linux.ibm.com, tuliom@linux.ibm.com, fw@deneb.enyo.de,
	Raphael Moreira Zinsly <rzinsly@linux.ibm.com>
Subject: Re: [PATCH v2] powerpc: Add log IFUNC multiarch support for POWER10
Date: Mon, 26 Apr 2021 08:41:22 -0300	[thread overview]
Message-ID: <161943728297.77482.6392319551434903358@localhost.localdomain> (raw)
In-Reply-To: <20210408181511.28061-1-rzinsly@linux.ibm.com>

LGTM. All tests with -mcpu=power10.

Quoting Raphael Moreira Zinsly via Libc-alpha (2021-04-08 15:15:11)
> Changes since v1:
>          - Checks for the -mcpu=power10 support on configure instead of
>            checking GCC's version.
>          - Don't build __log_power10 without -mcpu=power10.
> 
> ---8<---
> 
> Checked on ppc64le built without --with-cpu, with --with-cpu=power9
> and with --disable-multi-arch.
> ---
>  config.h.in                                   |  3 ++
>  .../powerpc64/le/fpu/multiarch/Makefile       |  8 ++++
>  .../powerpc64/le/fpu/multiarch/configure      | 33 +++++++++++++++++
>  .../powerpc64/le/fpu/multiarch/configure.ac   | 14 +++++++
>  .../le/fpu/multiarch/e_log-power10.c          |  4 ++
>  .../powerpc64/le/fpu/multiarch/e_log-ppc64.c  |  4 ++
>  .../powerpc64/le/fpu/multiarch/e_log.c        | 37 +++++++++++++++++++
>  .../powerpc64/le/fpu/multiarch/w_log.c        |  1 +
>  8 files changed, 104 insertions(+)
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure.ac
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-power10.c
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-ppc64.c
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log.c
>  create mode 100644 sysdeps/powerpc/powerpc64/le/fpu/multiarch/w_log.c
> 
> diff --git a/config.h.in b/config.h.in
> index ca1547ae67..14c3bf0f0d 100644
> --- a/config.h.in
> +++ b/config.h.in
> @@ -23,6 +23,9 @@
>  /* On powerpc64, use @notoc.  */
>  #undef  USE_PPC64_NOTOC
>  
> +/* On powerpc64, define if the compiler supports -mcpu=power10.  */
> +#undef USE_PPC64_MCPU_POWER10
> +
>  /* Define if _Unwind_Find_FDE should be exported from glibc.  */
>  #undef  EXPORT_UNWIND_FIND_FDE
>  
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/Makefile b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/Makefile
> index 22252d9e0a..cc073b53d3 100644
> --- a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/Makefile
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/Makefile
> @@ -208,4 +208,12 @@ object-suffixes-left := $(all-object-suffixes)
>  include $(o-iterator)
>  
>  endif # do_f128_multiarch
> +
> +libm-sysdep_routines += e_log-ppc64
> +
> +ifeq ($(mcpu-power10), yes)
> +libm-sysdep_routines += e_log-power10
> +CFLAGS-e_log-power10.c += -mcpu=power10
> +endif
> +
>  endif
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure
> new file mode 100644
> index 0000000000..4ca1d15833
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure
> @@ -0,0 +1,33 @@
> +# This file is generated from configure.ac by Autoconf.  DO NOT EDIT!
> +
> +OLD_CFLAGS="$CFLAGS"
> +CFLAGS="$CFLAGS -mcpu=power10"
> +
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: checking if the compiler supports -mcpu=power10" >&5
> +$as_echo_n "checking if the compiler supports -mcpu=power10... " >&6; }
> +if ${libc_cv_mcpu_power10+:} false; then :
> +  $as_echo_n "(cached) " >&6
> +else
> +
> +cat confdefs.h - <<_ACEOF >conftest.$ac_ext
> +/* end confdefs.h.  */
> +
> +
> +_ACEOF
> +if ac_fn_c_try_compile "$LINENO"; then :
> +  libc_cv_mcpu_power10=yes
> +else
> +  libc_cv_mcpu_power10=no
> +fi
> +rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext
> +fi
> +{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $libc_cv_mcpu_power10" >&5
> +$as_echo "$libc_cv_mcpu_power10" >&6; }
> +config_vars="$config_vars
> +mcpu-power10 = $libc_cv_mcpu_power10"
> +if test "$libc_cv_mcpu_power10" == "yes"; then :
> +
> +       $as_echo "#define USE_PPC64_MCPU_POWER10 1" >>confdefs.h
> +
> +fi
> +CFLAGS="$OLD_CFLAGS"
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure.ac b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure.ac
> new file mode 100644
> index 0000000000..ceb578cc59
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/configure.ac
> @@ -0,0 +1,14 @@
> +GLIBC_PROVIDES dnl See aclocal.m4 in the top level source directory.
> +
> +OLD_CFLAGS="$CFLAGS"
> +CFLAGS="$CFLAGS -mcpu=power10"
> +AC_CACHE_CHECK([if the compiler supports -mcpu=power10],
> +              libc_cv_mcpu_power10, [
> +AC_COMPILE_IFELSE([AC_LANG_SOURCE([[
> +]])],
> +              [libc_cv_mcpu_power10=yes],
> +              [libc_cv_mcpu_power10=no])])
> +LIBC_CONFIG_VAR([mcpu-power10], [$libc_cv_mcpu_power10])
> +AS_IF([[test "$libc_cv_mcpu_power10" == "yes"]],[
> +       AC_DEFINE(USE_PPC64_MCPU_POWER10)])
> +CFLAGS="$OLD_CFLAGS"
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-power10.c b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-power10.c
> new file mode 100644
> index 0000000000..4226e07643
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-power10.c
> @@ -0,0 +1,4 @@
> +#include <math.h>
> +
> +#define __log __log_power10
> +#include <sysdeps/ieee754/dbl-64/e_log.c>
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-ppc64.c b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-ppc64.c
> new file mode 100644
> index 0000000000..cb902d727a
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log-ppc64.c
> @@ -0,0 +1,4 @@
> +#include <math.h>
> +#define __log __log_ppc64
> +
> +#include <sysdeps/ieee754/dbl-64/e_log.c>
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log.c b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log.c
> new file mode 100644
> index 0000000000..b7961096a5
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/e_log.c
> @@ -0,0 +1,37 @@
> +/* Multiple versions of IEEE 754 log.
> +   Copyright (C) 2021 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 <math.h>
> +#include "init-arch.h"
> +#include <libm-alias-finite.h>
> +
> +extern double __redirect_ieee754_log (double);
> +
> +extern __typeof (log) __log_ppc64 attribute_hidden;
> +#ifdef USE_PPC64_MCPU_POWER10
> +extern __typeof (log) __log_power10 attribute_hidden;
> +#endif
> +
> +libc_ifunc_redirected (__redirect_ieee754_log, __ieee754_log,
> +#ifdef USE_PPC64_MCPU_POWER10
> +           (hwcap2 & PPC_FEATURE2_ARCH_3_1)
> +           ? __log_power10 :
> +#endif
> +            __log_ppc64);
> +
> +libm_alias_finite (__ieee754_log, __log)
> diff --git a/sysdeps/powerpc/powerpc64/le/fpu/multiarch/w_log.c b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/w_log.c
> new file mode 100644
> index 0000000000..9b2b018711
> --- /dev/null
> +++ b/sysdeps/powerpc/powerpc64/le/fpu/multiarch/w_log.c
> @@ -0,0 +1 @@
> +#include <sysdeps/../math/w_log.c>
> -- 
> 2.29.2
>

  parent reply	other threads:[~2021-04-26 11:43 UTC|newest]

Thread overview: 4+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2021-04-08 18:15 Raphael Moreira Zinsly
2021-04-22 18:51 ` Matheus Castanho
2021-04-26 11:41 ` Lucas A. M. Magalhaes [this message]
2021-04-26 13:55 ` Raphael M Zinsly

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=161943728297.77482.6392319551434903358@localhost.localdomain \
    --to=lamm@linux.ibm.com \
    --cc=fw@deneb.enyo.de \
    --cc=libc-alpha@sourceware.org \
    --cc=murphyp@linux.ibm.com \
    --cc=rzinsly@linux.ibm.com \
    --cc=tuliom@linux.ibm.com \
    /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).