[FFmpeg-devel] [PATCH] Move CPU detection to libavutil and cleanup

Måns Rullgård mans
Wed Sep 8 17:52:00 CEST 2010


Stefano Sabatini <stefano.sabatini-lala at poste.it> writes:

> On date Wednesday 2010-09-08 15:15:11 +0200, Michael Niedermayer encoded:
>> On Wed, Sep 08, 2010 at 01:14:03PM +0200, Stefano Sabatini wrote:
>> [...]
>> > +#include "cpu.h"
>> > +#include "config.h"
>> > +
>> > +#if   ARCH_ARM
>> > +#   include "arm/cpu.h"
>> > +#elif ARCH_PPC
>> > +#   include "ppc/cpu.h"
>> > +#elif ARCH_X86
>> > +#   include "x86/cpu.h"
>> > +#else
>> > +int av_get_cpu_flags(void)
>> > +{
>> > +    return 0;
>> > +}
>> > +#endif

This part is madness.

>> > +#ifdef TEST
>> > +
>> > +#undef printf
>> > +
>> > +int main(void)
>> > +{
>> > +    int cpu_flags = av_get_cpu_flags();
>> > +
>> > +    printf("cpu_flags = 0x%08X\n", cpu_flags);
>> > +    printf("cpu_flags = %s%s%s%s%s%s%s%s%s%s%s%s\n",
>> > +#if    ARCH_ARM
>> > +           cpu_flags & AV_CPU_FLAG_IWMMXT   ? "IWMMXT "     : "",
>> > +#elsif ARCH_PPC
>> > +           cpu_flags & AV_CPU_FLAG_ALTIVEC  ? "ALTIVEC "    : "",
>> > +#else
>> > +           cpu_flags & AV_CPU_FLAG_MMX      ? "MMX "        : "",
>> > +#endif
>> > +           cpu_flags & AV_CPU_FLAG_MMX2     ? "MMX2 "       : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE      ? "SSE "        : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE2     ? "SSE2 "       : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE2SLOW ? "SSE2(slow) " : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE3     ? "SSE3 "       : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE3SLOW ? "SSE3(slow) " : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSSE3    ? "SSSE3 "      : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE4     ? "SSE4.1 "     : "",
>> > +           cpu_flags & AV_CPU_FLAG_SSE42    ? "SSE4.2 "     : "",
>> > +           cpu_flags & AV_CPU_FLAG_3DNOW    ? "3DNow "      : "",
>> > +           cpu_flags & AV_CPU_FLAG_3DNOWEXT ? "3DNowExt "   : "");
>> 
>> the rest of the x86 flags should be under that ifdef too or be defined to 0
>> 
>> patch should be ok otherwise if tested 
>
> Applied.

Flamed.

-- 
M?ns Rullg?rd
mans at mansr.com



More information about the ffmpeg-devel mailing list