mirror of
				https://sourceware.org/git/glibc.git
				synced 2025-11-03 20:53:13 +03:00 
			
		
		
		
	Also, change sources.redhat.com to sourceware.org.
This patch was automatically generated by running the following shell
script, which uses GNU sed, and which avoids modifying files imported
from upstream:
sed -ri '
  s,(http|ftp)(://(.*\.)?(gnu|fsf|sourceware)\.org($|[^.]|\.[^a-z])),https\2,g
  s,(http|ftp)(://(.*\.)?)sources\.redhat\.com($|[^.]|\.[^a-z]),https\2sourceware.org\4,g
' \
  $(find $(git ls-files) -prune -type f \
      ! -name '*.po' \
      ! -name 'ChangeLog*' \
      ! -path COPYING ! -path COPYING.LIB \
      ! -path manual/fdl-1.3.texi ! -path manual/lgpl-2.1.texi \
      ! -path manual/texinfo.tex ! -path scripts/config.guess \
      ! -path scripts/config.sub ! -path scripts/install-sh \
      ! -path scripts/mkinstalldirs ! -path scripts/move-if-change \
      ! -path INSTALL ! -path  locale/programs/charmap-kw.h \
      ! -path po/libc.pot ! -path sysdeps/gnu/errlist.c \
      ! '(' -name configure \
            -execdir test -f configure.ac -o -f configure.in ';' ')' \
      ! '(' -name preconfigure \
            -execdir test -f preconfigure.ac ';' ')' \
      -print)
and then by running 'make dist-prepare' to regenerate files built
from the altered files, and then executing the following to cleanup:
  chmod a+x sysdeps/unix/sysv/linux/riscv/configure
  # Omit irrelevant whitespace and comment-only changes,
  # perhaps from a slightly-different Autoconf version.
  git checkout -f \
    sysdeps/csky/configure \
    sysdeps/hppa/configure \
    sysdeps/riscv/configure \
    sysdeps/unix/sysv/linux/csky/configure
  # Omit changes that caused a pre-commit check to fail like this:
  # remote: *** error: sysdeps/powerpc/powerpc64/ppc-mcount.S: trailing lines
  git checkout -f \
    sysdeps/powerpc/powerpc64/ppc-mcount.S \
    sysdeps/unix/sysv/linux/s390/s390-64/syscall.S
  # Omit change that caused a pre-commit check to fail like this:
  # remote: *** error: sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S: last line does not end in newline
  git checkout -f sysdeps/sparc/sparc64/multiarch/memcpy-ultra3.S
		
	
		
			
				
	
	
		
			103 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			103 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/* Inline floating-point environment handling functions for powerpc.
 | 
						|
   Copyright (C) 1995-2019 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/>.  */
 | 
						|
 | 
						|
#if defined __GNUC__ && !defined _SOFT_FLOAT && !defined __NO_FPRS__
 | 
						|
 | 
						|
/* Inline definitions for fegetround.  */
 | 
						|
# define __fegetround_ISA300()						\
 | 
						|
  (__extension__  ({							\
 | 
						|
    union { double __d; unsigned long long __ll; } __u;			\
 | 
						|
    __asm__ __volatile__ (						\
 | 
						|
      ".machine push; .machine \"power9\"; mffsl %0; .machine pop"	\
 | 
						|
      : "=f" (__u.__d));						\
 | 
						|
    __u.__ll & 0x0000000000000003LL;					\
 | 
						|
  }))
 | 
						|
 | 
						|
# define __fegetround_ISA2()						\
 | 
						|
  (__extension__  ({							\
 | 
						|
     int __fegetround_result;						\
 | 
						|
     __asm__ __volatile__ ("mcrfs 7,7 ; mfcr %0"			\
 | 
						|
			   : "=r"(__fegetround_result) : : "cr7");	\
 | 
						|
     __fegetround_result & 3;						\
 | 
						|
  }))
 | 
						|
 | 
						|
# ifdef _ARCH_PWR9
 | 
						|
#  define __fegetround() __fegetround_ISA300()
 | 
						|
# elif defined __BUILTIN_CPU_SUPPORTS__
 | 
						|
#  define __fegetround()						\
 | 
						|
  (__glibc_likely (__builtin_cpu_supports ("arch_3_00"))		\
 | 
						|
   ? __fegetround_ISA300()						\
 | 
						|
   : __fegetround_ISA2()						\
 | 
						|
  )
 | 
						|
# else
 | 
						|
#  define __fegetround() __fegetround_ISA2()
 | 
						|
# endif
 | 
						|
 | 
						|
# define fegetround() __fegetround ()
 | 
						|
 | 
						|
# ifndef __NO_MATH_INLINES
 | 
						|
/* The weird 'i#*X' constraints on the following suppress a gcc
 | 
						|
   warning when __excepts is not a constant.  Otherwise, they mean the
 | 
						|
   same as just plain 'i'.  */
 | 
						|
 | 
						|
#  if __GNUC_PREREQ(3, 4)
 | 
						|
 | 
						|
/* Inline definition for feraiseexcept.  */
 | 
						|
#   define feraiseexcept(__excepts) \
 | 
						|
  (__extension__  ({ 							      \
 | 
						|
    int __e = __excepts;						      \
 | 
						|
    int __ret;								      \
 | 
						|
    if (__builtin_constant_p (__e)					      \
 | 
						|
        && (__e & (__e - 1)) == 0					      \
 | 
						|
        && __e != FE_INVALID)						      \
 | 
						|
      {									      \
 | 
						|
	if (__e != 0)							      \
 | 
						|
	  __asm__ __volatile__ ("mtfsb1 %0"				      \
 | 
						|
				: : "i#*X" (__builtin_clz (__e)));	      \
 | 
						|
        __ret = 0;							      \
 | 
						|
      }									      \
 | 
						|
    else								      \
 | 
						|
      __ret = feraiseexcept (__e);					      \
 | 
						|
    __ret;								      \
 | 
						|
  }))
 | 
						|
 | 
						|
/* Inline definition for feclearexcept.  */
 | 
						|
#   define feclearexcept(__excepts) \
 | 
						|
  (__extension__  ({ 							      \
 | 
						|
    int __e = __excepts;						      \
 | 
						|
    int __ret;								      \
 | 
						|
    if (__builtin_constant_p (__e)					      \
 | 
						|
        && (__e & (__e - 1)) == 0					      \
 | 
						|
        && __e != FE_INVALID)						      \
 | 
						|
      {									      \
 | 
						|
	if (__e != 0)							      \
 | 
						|
	  __asm__ __volatile__ ("mtfsb0 %0"				      \
 | 
						|
				: : "i#*X" (__builtin_clz (__e)));	      \
 | 
						|
        __ret = 0;							      \
 | 
						|
      }									      \
 | 
						|
    else								      \
 | 
						|
      __ret = feclearexcept (__e);					      \
 | 
						|
    __ret;								      \
 | 
						|
  }))
 | 
						|
 | 
						|
#  endif /* __GNUC_PREREQ(3, 4).  */
 | 
						|
 | 
						|
# endif /* !__NO_MATH_INLINES.  */
 | 
						|
 | 
						|
#endif /* __GNUC__ && !_SOFT_FLOAT && !__NO_FPRS__ */
 |