Blame sysdeps/powerpc/dl-procinfo.h

Packit 6c4009
/* Processor capability information handling macros.  PowerPC version.
Packit 6c4009
   Copyright (C) 2005-2018 Free Software Foundation, Inc.
Packit 6c4009
   This file is part of the GNU C Library.
Packit 6c4009
Packit 6c4009
   The GNU C Library is free software; you can redistribute it and/or
Packit 6c4009
   modify it under the terms of the GNU Lesser General Public
Packit 6c4009
   License as published by the Free Software Foundation; either
Packit 6c4009
   version 2.1 of the License, or (at your option) any later version.
Packit 6c4009
Packit 6c4009
   The GNU C Library is distributed in the hope that it will be useful,
Packit 6c4009
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 6c4009
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 6c4009
   Lesser General Public License for more details.
Packit 6c4009
Packit 6c4009
   You should have received a copy of the GNU Lesser General Public
Packit 6c4009
   License along with the GNU C Library.  If not, see
Packit 6c4009
   <http://www.gnu.org/licenses/>.  */
Packit 6c4009
Packit 6c4009
#ifndef _DL_PROCINFO_H
Packit 6c4009
#define _DL_PROCINFO_H 1
Packit 6c4009
Packit 6c4009
#include <ldsodefs.h>
Packit 6c4009
#include <sysdep.h>	/* This defines the PPC_FEATURE[2]_* macros.  */
Packit 6c4009
Packit 6c4009
/* The total number of available bits (including those prior to
Packit 6c4009
   _DL_HWCAP_FIRST).  Some of these bits might not be used.  */
Packit 6c4009
#define _DL_HWCAP_COUNT		64
Packit 6c4009
Packit 6c4009
/* Features started at bit 31 and decremented as new features were added.  */
Packit 6c4009
#define _DL_HWCAP_LAST		31
Packit 6c4009
Packit 6c4009
/* AT_HWCAP2 features started at bit 31 and decremented as new features were
Packit 6c4009
   added.  HWCAP2 feature bits start at bit 0.  */
Packit 6c4009
#define _DL_HWCAP2_LAST		31
Packit 6c4009
Packit 6c4009
/* These bits influence library search.  */
Packit 6c4009
#define HWCAP_IMPORTANT		(PPC_FEATURE_HAS_ALTIVEC \
Packit 6c4009
				+ PPC_FEATURE_HAS_DFP)
Packit 6c4009
Packit 6c4009
#define _DL_PLATFORMS_COUNT	15
Packit 6c4009
Packit 6c4009
#define _DL_FIRST_PLATFORM	32
Packit 6c4009
/* Mask to filter out platforms.  */
Packit 6c4009
#define _DL_HWCAP_PLATFORM	(((1ULL << _DL_PLATFORMS_COUNT) - 1) \
Packit 6c4009
				<< _DL_FIRST_PLATFORM)
Packit 6c4009
Packit 6c4009
/* Platform bits (relative to _DL_FIRST_PLATFORM).  */
Packit 6c4009
#define PPC_PLATFORM_POWER4		0
Packit 6c4009
#define PPC_PLATFORM_PPC970		1
Packit 6c4009
#define PPC_PLATFORM_POWER5		2
Packit 6c4009
#define PPC_PLATFORM_POWER5_PLUS	3
Packit 6c4009
#define PPC_PLATFORM_POWER6		4
Packit 6c4009
#define PPC_PLATFORM_CELL_BE		5
Packit 6c4009
#define PPC_PLATFORM_POWER6X		6
Packit 6c4009
#define PPC_PLATFORM_POWER7		7
Packit 6c4009
#define PPC_PLATFORM_PPCA2		8
Packit 6c4009
#define PPC_PLATFORM_PPC405		9
Packit 6c4009
#define PPC_PLATFORM_PPC440		10
Packit 6c4009
#define PPC_PLATFORM_PPC464		11
Packit 6c4009
#define PPC_PLATFORM_PPC476		12
Packit 6c4009
#define PPC_PLATFORM_POWER8		13
Packit 6c4009
#define PPC_PLATFORM_POWER9		14
Packit 6c4009
Packit 6c4009
static inline const char *
Packit 6c4009
__attribute__ ((unused))
Packit 6c4009
_dl_hwcap_string (int idx)
Packit 6c4009
{
Packit 6c4009
  return GLRO(dl_powerpc_cap_flags)[idx];
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
static inline int
Packit 6c4009
__attribute__ ((unused))
Packit 6c4009
_dl_string_hwcap (const char *str)
Packit 6c4009
{
Packit 6c4009
  for (int i = 0; i < _DL_HWCAP_COUNT; ++i)
Packit 6c4009
    if (strcmp (str, _dl_hwcap_string (i)) == 0)
Packit 6c4009
      return i;
Packit 6c4009
  return -1;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
static inline int
Packit 6c4009
__attribute__ ((unused, always_inline))
Packit 6c4009
_dl_string_platform (const char *str)
Packit 6c4009
{
Packit 6c4009
  if (str == NULL)
Packit 6c4009
    return -1;
Packit 6c4009
Packit 6c4009
  if (strncmp (str, "power", 5) == 0)
Packit 6c4009
    {
Packit 6c4009
      int ret;
Packit 6c4009
      str += 5;
Packit 6c4009
      switch (*str)
Packit 6c4009
	{
Packit 6c4009
	case '4':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER4;
Packit 6c4009
	  break;
Packit 6c4009
	case '5':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER5;
Packit 6c4009
	  if (str[1] == '+')
Packit 6c4009
	    {
Packit 6c4009
	      ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER5_PLUS;
Packit 6c4009
	      ++str;
Packit 6c4009
	    }
Packit 6c4009
	  break;
Packit 6c4009
	case '6':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER6;
Packit 6c4009
	  if (str[1] == 'x')
Packit 6c4009
	    {
Packit 6c4009
	      ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER6X;
Packit 6c4009
	      ++str;
Packit 6c4009
	    }
Packit 6c4009
	  break;
Packit 6c4009
	case '7':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER7;
Packit 6c4009
	  break;
Packit 6c4009
	case '8':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER8;
Packit 6c4009
	  break;
Packit 6c4009
	case '9':
Packit 6c4009
	  ret = _DL_FIRST_PLATFORM + PPC_PLATFORM_POWER9;
Packit 6c4009
	  break;
Packit 6c4009
	default:
Packit 6c4009
	  return -1;
Packit 6c4009
	}
Packit 6c4009
      if (str[1] == '\0')
Packit 6c4009
       return ret;
Packit 6c4009
    }
Packit 6c4009
  else if (strncmp (str, "ppc", 3) == 0)
Packit 6c4009
    {
Packit 6c4009
      if (strcmp (str + 3, "970") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPC970;
Packit 6c4009
      else if (strcmp (str + 3, "-cell-be") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_CELL_BE;
Packit 6c4009
      else if (strcmp (str + 3, "a2") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPCA2;
Packit 6c4009
      else if (strcmp (str + 3, "405") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPC405;
Packit 6c4009
      else if (strcmp (str + 3, "440") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPC440;
Packit 6c4009
      else if (strcmp (str + 3, "464") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPC464;
Packit 6c4009
      else if (strcmp (str + 3, "476") == 0)
Packit 6c4009
	return _DL_FIRST_PLATFORM + PPC_PLATFORM_PPC476;
Packit 6c4009
    }
Packit 6c4009
Packit 6c4009
  return -1;
Packit 6c4009
}
Packit 6c4009
Packit 6c4009
#if IS_IN (rtld)
Packit 6c4009
static inline int
Packit 6c4009
__attribute__ ((unused))
Packit 6c4009
_dl_procinfo (unsigned int type, unsigned long int word)
Packit 6c4009
{
Packit 6c4009
  switch(type)
Packit 6c4009
    {
Packit 6c4009
    case AT_HWCAP:
Packit 6c4009
      _dl_printf ("AT_HWCAP:       ");
Packit 6c4009
Packit 6c4009
      for (int i = 0; i <= _DL_HWCAP_LAST; ++i)
Packit 6c4009
       if (word & (1 << i))
Packit 6c4009
         _dl_printf (" %s", _dl_hwcap_string (i));
Packit 6c4009
      break;
Packit 6c4009
    case AT_HWCAP2:
Packit 6c4009
      {
Packit 6c4009
       unsigned int offset = _DL_HWCAP_LAST + 1;
Packit 6c4009
Packit 6c4009
       _dl_printf ("AT_HWCAP2:      ");
Packit 6c4009
Packit 6c4009
        /* We have to go through them all because the kernel added the
Packit 6c4009
          AT_HWCAP2 features starting with the high bits.  */
Packit 6c4009
       for (int i = 0; i <= _DL_HWCAP2_LAST; ++i)
Packit 6c4009
         if (word & (1 << i))
Packit 6c4009
           _dl_printf (" %s", _dl_hwcap_string (offset + i));
Packit 6c4009
       break;
Packit 6c4009
      }
Packit 6c4009
    default:
Packit 6c4009
      /* This should not happen.  */
Packit 6c4009
      return -1;
Packit 6c4009
    }
Packit 6c4009
   _dl_printf ("\n");
Packit 6c4009
  return 0;
Packit 6c4009
}
Packit 6c4009
#endif
Packit 6c4009
Packit 6c4009
#endif /* dl-procinfo.h */