eina: add infrastructure to handle more CPU and compiler builtin information.

This commit is contained in:
Cedric Bail 2013-10-02 18:31:10 +09:00
parent 04b28686af
commit ff3d2a68d5
8 changed files with 140 additions and 18 deletions

View File

@ -792,6 +792,9 @@ AC_DEFINE_IF([HAVE_DIRENT_H], [test "x${have_dirent}" = "xyes"],
### Checks for structures
### Checks for compiler characteristics
EFL_CHECK_GCC_BUILTIN([bswap16], [HAVE_BSWAP16])
EFL_CHECK_GCC_BUILTIN([bswap32], [HAVE_BSWAP32])
EFL_CHECK_GCC_BUILTIN([bswap64], [HAVE_BSWAP64])
### Checks for linker characteristics

View File

@ -1,20 +1,13 @@
AC_DEFUN([EFL_CHECK_GCC_BUILTIN],
[efl_check_gcc_builtin_save_libs=$LIBS
EINA_CONFIGURE_$2=""
LIBS="-lm $LIBS"
AC_LINK_IFELSE(
[AC_LANG_PROGRAM(
[[#ifndef __GNUC__
choke me
#else
#undef $1
/* Declare this function with same prototype as __builtin_$1.
This removes warning about conflicting type with builtin */
__typeof__(__builtin_$1) $1;
__typeof__(__builtin_$1) *f = $1;
#endif
]], [[return f != $1;]]
[[]], [[return __builtin_$1(42);]]
)],
[AC_DEFINE([$2], [123], [GCC builtin $1 exists])])
[EINA_CONFIGURE_$2="#define EINA_$2"
AC_DEFINE([$2], [1], [GCC builtin $1 exists])])
AC_SUBST(EINA_CONFIGURE_$2)
LIBS=$efl_check_gcc_builtin_save_libs])

View File

@ -57,6 +57,7 @@ lib/eina/eina_trash.h \
lib/eina/eina_iterator.h \
lib/eina/eina_main.h \
lib/eina/eina_cpu.h \
lib/eina/eina_inline_cpu.x \
lib/eina/eina_sched.h \
lib/eina/eina_tiler.h \
lib/eina/eina_hamster.h \

View File

@ -72,4 +72,19 @@
#endif
@EINA_CONFIGURE_HAVE_ALLOCA_H@
#ifdef EINA_HAVE_BSWAP16
# undef EINA_HAVE_BSWAP16
#endif
@EINA_CONFIGURE_HAVE_BSWAP16@
#ifdef EINA_HAVE_BSWAP32
# undef EINA_HAVE_BSWAP32
#endif
@EINA_CONFIGURE_HAVE_BSWAP32@
#ifdef EINA_HAVE_BSWAP64
# undef EINA_HAVE_BSWAP64
#endif
@EINA_CONFIGURE_HAVE_BSWAP64@
#endif /* EINA_CONFIG_H_ */

View File

@ -92,6 +92,9 @@ void _x86_simd(Eina_Cpu_Features *features)
* 28 = HTT (Hyper Threading)
* ecx
* 0 = SSE3
* 9 = SSSE3
* 19 = SSE4.1
* 20 = SSE4.2
*/
if ((d >> 23) & 1)
*features |= EINA_CPU_MMX;
@ -104,6 +107,15 @@ void _x86_simd(Eina_Cpu_Features *features)
if (c & 1)
*features |= EINA_CPU_SSE3;
if ((c >> 9) & 1)
*features |= EINA_CPU_SSSE3;
if ((c >> 19) & 1)
*features |= EINA_CPU_SSE41;
if ((c >> 20) & 1)
*features |= EINA_CPU_SSE42;
}
#endif
@ -118,17 +130,32 @@ void _x86_simd(Eina_Cpu_Features *features)
/* FIXME the features checks should be called when this function is called?
* or make it static by doing eina_cpu_init() and return a local var
*/
EAPI Eina_Cpu_Features eina_cpu_features = 0;
Eina_Bool
eina_cpu_init(void)
{
#if defined(__i386__) || defined(__x86_64__)
_x86_simd(&eina_cpu_features);
#endif
// FIXME: Handle NEON and friends
return EINA_TRUE;
}
Eina_Bool
eina_cpu_shutdown(void)
{
return EINA_TRUE;
}
/**
*
* @return
*/
EAPI Eina_Cpu_Features eina_cpu_features_get(void)
{
Eina_Cpu_Features ecf = 0;
#if defined(__i386__) || defined(__x86_64__)
_x86_simd(&ecf);
#endif
return ecf;
return eina_cpu_features;
}
static int _cpu_count = -1;

View File

@ -31,9 +31,20 @@ typedef enum _Eina_Cpu_Features
EINA_CPU_ALTIVEC = 0x00000010,
EINA_CPU_VIS = 0x00000020,
EINA_CPU_NEON = 0x00000040,
EINA_CPU_SSSE3 = 0x00000080,
EINA_CPU_SSE41 = 0x00000100,
EINA_CPU_SSE42 = 0x00000200
} Eina_Cpu_Features;
EAPI extern Eina_Cpu_Features eina_cpu_features;
EAPI Eina_Cpu_Features eina_cpu_features_get(void);
EAPI int eina_cpu_count(void);
static inline unsigned short eina_swap16(unsigned short x);
static inline unsigned int eina_swap32(unsigned int x);
static inline unsigned long long eina_swap64(unsigned long long x);
#include "eina_inline_cpu.x"
#endif /* EINA_CPU_H_ */

View File

@ -0,0 +1,70 @@
/* EINA - EFL data type library
* Copyright (C) 2013 Cedric Bail
*
* This 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.
*
* This 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 this library;
* if not, see <http://www.gnu.org/licenses/>.
*/
/*
* This code has been partially inspired by :
* - http://create.stephan-brumme.com/crc32/
*/
#ifndef EINA_INLINE_CPU_X_
#define EINA_INLINE_CPU_X_
static inline unsigned short
eina_swap16(unsigned short x)
{
#ifdef EINA_HAVE_BSWAP16
return __builtin_bswap16(x);
#else
return (((x & 0xff00) >> 8) |
((x & 0x00ff) << 8));
#endif
}
static inline unsigned int
eina_swap32(unsigned int x)
{
#ifdef EINA_HAVE_BSWAP32
return __builtin_bswap32(x);
#else
return (x >> 24) |
((x >> 8) & 0x0000FF00) |
((x << 8) & 0x00FF0000) |
(x << 24);
#endif
}
static inline unsigned long long
eina_swap64(unsigned long long x)
{
#ifdef EINA_HAVE_BSWAP64
return __builtin_bswap64(x);
#else
return (((x & 0xff00000000000000ull) >> 56) |
((x & 0x00ff000000000000ull) >> 40) |
((x & 0x0000ff0000000000ull) >> 24) |
((x & 0x000000ff00000000ull) >> 8) |
((x & 0x00000000ff000000ull) << 8) |
((x & 0x0000000000ff0000ull) << 24) |
((x & 0x000000000000ff00ull) << 40) |
((x & 0x00000000000000ffull) << 56)));
#endif
}
#endif

View File

@ -159,6 +159,7 @@ EAPI Eina_Inlist *_eina_tracking = NULL;
S(tmpstr);
S(thread);
S(cow);
S(cpu);
/* no model for now
S(model);
*/
@ -201,7 +202,8 @@ static const struct eina_desc_setup _eina_desc_setup[] = {
S(value),
S(tmpstr),
S(thread),
S(cow)
S(cow),
S(cpu)
/* no model for now
S(model)
*/