libevas: autodetect cpu variant code tuning options

Similar to how we do it for ffmpeg.

Signed-off-by: Peter Korsgaard <jacmet@sunsite.dk>
This commit is contained in:
Peter Korsgaard 2012-01-29 00:21:11 +01:00
parent 73b942e57e
commit d4e64bd61b
2 changed files with 13 additions and 56 deletions

View File

@ -137,50 +137,6 @@ config BR2_PACKAGE_LIBEVAS_GLES_S3C6410
endchoice
comment "libevas code tuning"
config BR2_PACKAGE_LIBEVAS_DISABLE_C
bool "libevas disable C code"
depends on BR2_PACKAGE_LIBEVAS_MMX || BR2_PACKAGE_LIBEVAS_SSE || BR2_PACKAGE_LIBEVAS_SSE3
help
This disables the generic C fallback code which is not required
if MMX or SSE is used instead.
config BR2_PACKAGE_LIBEVAS_MMX
bool "libevas MMX routines"
depends on BR2_i386 || BR2_x86_64
help
This enables the MMX optimized routines. this works for
Pentium, Pentium 2, Pentium 3, Pentium 4, Athlon and Duron
processors.
config BR2_PACKAGE_LIBEVAS_SSE
bool "libevas SSE routines"
depends on BR2_i386 || BR2_x86_64
help
This enables SSE optimizations available in the Pentium 3 and
4 cpus (not Athlon and Duron or Pentium 2 or Pentium cpus).
config BR2_PACKAGE_LIBEVAS_SSE3
bool "libevas SSE3 routines"
depends on BR2_i386 || BR2_x86_64
help
This enables SSE3 optimizations available in the Pentium 4 and
above cpus.
config BR2_PACKAGE_LIBEVAS_ALTIVEC
bool "libevas altivec routines"
depends on BR2_powerpc
help
This enables AltiVec optimizations available in some PowerPC cpus.
config BR2_PACKAGE_LIBEVAS_NEON
bool "libevas neon routines"
depends on BR2_arm
help
This enables NEON optimizations available in some ARM cpus.
comment "libevas loaders"
config BR2_PACKAGE_LIBEVAS_PNG

View File

@ -93,27 +93,28 @@ LIBEVAS_CONF_OPT += --enable-gl-flavor-gles --enable-gles-variety-s3c6410
endif
# code options
ifeq ($(BR2_PACKAGE_LIBEVAS_DISABLE_C),y)
LIBEVAS_CONF_OPT += --disable-cpu-c
endif
ifeq ($(BR2_PACKAGE_LIBEVAS_MMX),y)
ifeq ($(BR2_i386)$(BR2_x86_64),y)
# enable if cpu variant has mmx support
ifneq ($(BR2_x86_i386)$(BR2_x86_i486)$(BR2_x86_i586)$(BR2_x86_i686)$(BR2_x86_pentiumpro)$(BR2_x86_geode),y)
LIBEVAS_CONF_OPT += --enable-cpu-mmx
endif
ifeq ($(BR2_PACKAGE_LIBEVAS_SSE),y)
ifneq ($(BR2_x86_pentium_mmx)$(BR2_x86_pentium2)$(BR2_x86_k6)$(BR2_x86_k6_2)$(BR2_x86_athlon)$(BR2_x86_c3)$(BR2_x86_winchip_c6)$(BR2_x86_winchip2),y)
LIBEVAS_CONF_OPT += --enable-cpu-sse
endif
ifeq ($(BR2_PACKAGE_LIBEVAS_SSE3),y)
ifneq ($(BR2_x86_pentium3)$(BR2_x86_pentium4)$(BR2_x86_prescott)$(BR2_x86_athlon_4)$(BR2_x86_opteron)$(BR2_x86_c32)$(BR2_x86_64_opteron),y)
LIBEVAS_CONF_OPT += --enable-cpu-sse3
endif
ifeq ($(BR2_PACKAGE_LIBEVAS_ALTIVEC),y)
endif # sse3
endif # sse
endif # mmx
endif # x86
ifeq ($(BR2_powerpc_7400)$(BR2_powerpc_7450)$(BR2_powerpc_970),y)
LIBEVAS_CONF_OPT += --enable-cpu-altivec
endif
ifeq ($(BR2_PACKAGE_LIBEVAS_NEON),y)
ifeq ($(BR2_cortex_a8)$(BR2_cortex_a9),y)
# NEON is optional for A9
LIBEVAS_CONF_OPT += --enable-cpu-neon
endif