[PATCH webrtc-audio-processing] configure.ac: fix architecture detection

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Sat, 6 Aug 2016, at 02:32 PM, Thomas Petazzoni wrote:
> The current architecture detection, based on the "host_cpu" part of the
> tuple does not work properly for a number of reason:
> 
>  - The code assumes that if host_cpu starts with "arm" then ARM
>    instructions are available, which is incorrect. Indeed, Cortex-M
>    platforms can run Linux, they are ARM platforms (so host_cpu = arm),
>    but they don't support ARM instructions: they support only the
>    Thumb-2 instruction set.
> 
>  - The armv7 case is also not very useful, as it is not standard at all
>    to pass armv7 as host_cpu even if the host system is actually ARMv7
>    based.
> 
>  - For the same reason, the armv8 case is not very useful: ARMv8 is
>    AArch64, and there is already a separate case to handle this
>    architecture.
> 
> So, this commit moves away from a host_cpu based logic, and instead
> tests using AC_CHECK_DECLS() the built-in definitions of the compiler:
> 
>  - If we have __ARM_ARCH_ISA_ARM defined, then it's an ARM processor
>    that supports the ARM instruction set (this allows to exclude Thumb-2
>    only processors).
> 
>  - If we have __ARM_ARCH_7A__, then we have an ARMv7-A processor, and
>    we can enable the corresponding optimizations
> 
>  - Same for __aarch64__, __i386__ and __x86_64__.
> 
> In addition, we remove the AC_MSG_ERROR() that makes the build fail for
> all architectures but the ones that are explicitly supported. Indeed,
> webrtc-audio-processing builds just fine for other architectures (tested
> on MIPS), it's just that none of the architecture-specific optimizations
> will be used.
> 
> Signed-off-by: Thomas Petazzoni <thomas.petazzoni at free-electrons.com>
> ---

Looks good, will push shortly, thanks.

-- Arun


[Index of Archives]     [Linux Audio Users]     [AMD Graphics]     [Linux USB Devel]     [Linux Audio Users]     [Yosemite News]     [Linux Kernel]     [Linux SCSI]

  Powered by Linux