| Index: third_party/libpng/pnggccrd.c
|
| diff --git a/third_party/libpng/pnggccrd.c b/third_party/libpng/pnggccrd.c
|
| index 78b8a7e4173a19fdf617f307c3f862350d83d08c..7eb7f67d6bcb9ddd81ddff1795e54250f023c08e 100644
|
| --- a/third_party/libpng/pnggccrd.c
|
| +++ b/third_party/libpng/pnggccrd.c
|
| @@ -1,6 +1,16 @@
|
| -/* pnggccrd.c was removed from libpng-1.2.20. */
|
| -
|
| -/* This code snippet is for use by configure's compilation test. */
|
| +/* pnggccrd.c
|
| + *
|
| + * Last changed in libpng 1.2.48 [March 8, 2012]
|
| + * Copyright (c) 1998-2012 Glenn Randers-Pehrson
|
| + *
|
| + * This code is released under the libpng license.
|
| + * For conditions of distribution and use, see the disclaimer
|
| + * and license in png.h
|
| + *
|
| + * This code snippet is for use by configure's compilation test. Most of the
|
| + * remainder of the file was removed from libpng-1.2.20, and all of the
|
| + * assembler code was removed from libpng-1.2.48.
|
| + */
|
|
|
| #if (!defined _MSC_VER) && \
|
| defined(PNG_ASSEMBLER_CODE_SUPPORTED) && \
|
| @@ -8,96 +18,9 @@
|
|
|
| int PNGAPI png_dummy_mmx_support(void);
|
|
|
| -static int _mmx_supported = 2; // 0: no MMX; 1: MMX supported; 2: not tested
|
| -
|
| -int PNGAPI
|
| -png_dummy_mmx_support(void) __attribute__((noinline));
|
| -
|
| -int PNGAPI
|
| -png_dummy_mmx_support(void)
|
| +int PNGAPI png_dummy_mmx_support(void)
|
| {
|
| - int result;
|
| -#ifdef PNG_MMX_CODE_SUPPORTED // superfluous, but what the heck
|
| - __asm__ __volatile__ (
|
| -#ifdef __x86_64__
|
| - "pushq %%rbx \n\t" // rbx gets clobbered by CPUID instruction
|
| - "pushq %%rcx \n\t" // so does rcx...
|
| - "pushq %%rdx \n\t" // ...and rdx (but rcx & rdx safe on Linux)
|
| - "pushfq \n\t" // save Eflag to stack
|
| - "popq %%rax \n\t" // get Eflag from stack into rax
|
| - "movq %%rax, %%rcx \n\t" // make another copy of Eflag in rcx
|
| - "xorl $0x200000, %%eax \n\t" // toggle ID bit in Eflag (i.e., bit 21)
|
| - "pushq %%rax \n\t" // save modified Eflag back to stack
|
| - "popfq \n\t" // restore modified value to Eflag reg
|
| - "pushfq \n\t" // save Eflag to stack
|
| - "popq %%rax \n\t" // get Eflag from stack
|
| - "pushq %%rcx \n\t" // save original Eflag to stack
|
| - "popfq \n\t" // restore original Eflag
|
| -#else
|
| - "pushl %%ebx \n\t" // ebx gets clobbered by CPUID instruction
|
| - "pushl %%ecx \n\t" // so does ecx...
|
| - "pushl %%edx \n\t" // ...and edx (but ecx & edx safe on Linux)
|
| - "pushfl \n\t" // save Eflag to stack
|
| - "popl %%eax \n\t" // get Eflag from stack into eax
|
| - "movl %%eax, %%ecx \n\t" // make another copy of Eflag in ecx
|
| - "xorl $0x200000, %%eax \n\t" // toggle ID bit in Eflag (i.e., bit 21)
|
| - "pushl %%eax \n\t" // save modified Eflag back to stack
|
| - "popfl \n\t" // restore modified value to Eflag reg
|
| - "pushfl \n\t" // save Eflag to stack
|
| - "popl %%eax \n\t" // get Eflag from stack
|
| - "pushl %%ecx \n\t" // save original Eflag to stack
|
| - "popfl \n\t" // restore original Eflag
|
| -#endif
|
| - "xorl %%ecx, %%eax \n\t" // compare new Eflag with original Eflag
|
| - "jz 0f \n\t" // if same, CPUID instr. is not supported
|
| -
|
| - "xorl %%eax, %%eax \n\t" // set eax to zero
|
| -// ".byte 0x0f, 0xa2 \n\t" // CPUID instruction (two-byte opcode)
|
| - "cpuid \n\t" // get the CPU identification info
|
| - "cmpl $1, %%eax \n\t" // make sure eax return non-zero value
|
| - "jl 0f \n\t" // if eax is zero, MMX is not supported
|
| -
|
| - "xorl %%eax, %%eax \n\t" // set eax to zero and...
|
| - "incl %%eax \n\t" // ...increment eax to 1. This pair is
|
| - // faster than the instruction "mov eax, 1"
|
| - "cpuid \n\t" // get the CPU identification info again
|
| - "andl $0x800000, %%edx \n\t" // mask out all bits but MMX bit (23)
|
| - "cmpl $0, %%edx \n\t" // 0 = MMX not supported
|
| - "jz 0f \n\t" // non-zero = yes, MMX IS supported
|
| -
|
| - "movl $1, %%eax \n\t" // set return value to 1
|
| - "jmp 1f \n\t" // DONE: have MMX support
|
| -
|
| - "0: \n\t" // .NOT_SUPPORTED: target label for jump instructions
|
| - "movl $0, %%eax \n\t" // set return value to 0
|
| - "1: \n\t" // .RETURN: target label for jump instructions
|
| -#ifdef __x86_64__
|
| - "popq %%rdx \n\t" // restore rdx
|
| - "popq %%rcx \n\t" // restore rcx
|
| - "popq %%rbx \n\t" // restore rbx
|
| -#else
|
| - "popl %%edx \n\t" // restore edx
|
| - "popl %%ecx \n\t" // restore ecx
|
| - "popl %%ebx \n\t" // restore ebx
|
| -#endif
|
| -
|
| -// "ret \n\t" // DONE: no MMX support
|
| - // (fall through to standard C "ret")
|
| -
|
| - : "=a" (result) // output list
|
| -
|
| - : // any variables used on input (none)
|
| -
|
| - // no clobber list
|
| -// , "%ebx", "%ecx", "%edx" // GRR: we handle these manually
|
| -// , "memory" // if write to a variable gcc thought was in a reg
|
| -// , "cc" // "condition codes" (flag bits)
|
| - );
|
| - _mmx_supported = result;
|
| -#else
|
| - _mmx_supported = 0;
|
| -#endif /* PNG_MMX_CODE_SUPPORTED */
|
| -
|
| - return _mmx_supported;
|
| + /* 0: no MMX; 1: MMX supported; 2: not tested */
|
| + return 2;
|
| }
|
| #endif
|
|
|