Mercurial > libavcodec.hg
changeset 16:89bc3bf1a031 libavcodec
added external cpuid code to solve -fPIC and gcc unclear constraints problems
author | glantau |
---|---|
date | Mon, 30 Jul 2001 23:51:20 +0000 |
parents | 076bcac8d059 |
children | b69fe46fd708 |
files | i386/cpuid.s i386/cputest.c |
diffstat | 2 files changed, 33 insertions(+), 12 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/i386/cpuid.s Mon Jul 30 23:51:20 2001 +0000 @@ -0,0 +1,31 @@ + .file "cpuid.s" + .version "01.01" +gcc2_compiled.: +.text + .align 4 + .globl cpuid + .type cpuid,@function +cpuid: + pushl %ebp + movl %esp,%ebp + pushl %edi + pushl %esi + pushl %ebx + movl 8(%ebp),%eax + movl 12(%ebp),%edi + movl 24(%ebp),%esi + cpuid + movl %eax,(%edi) + movl 16(%ebp),%eax + movl %ebx,(%eax) + movl 20(%ebp),%eax + movl %ecx,(%eax) + movl %edx,(%esi) + popl %ebx + popl %esi + popl %edi + leave + ret +.Lfe1: + .size cpuid,.Lfe1-cpuid + .align 4
--- a/i386/cputest.c Mon Jul 30 23:50:04 2001 +0000 +++ b/i386/cputest.c Mon Jul 30 23:51:20 2001 +0000 @@ -4,18 +4,8 @@ #include <stdlib.h> #include "../dsputil.h" -/* ebx saving is necessary for PIC. gcc seems unable to see it alone */ -static inline void cpuid(int index, int *eax, int *ebx, int *ecx, int *edx) -{ - asm ("pushl %%ebx\n\t" - "cpuid\n\t" - "movl %%ebx, %1\n\t" - "popl %%ebx\n\t" - : "=a" (*eax), "=m" (*ebx), - "=c" (*ecx), "=d" (*edx) - : "a" (index) - : "cc"); -} +/* need this external function to solve -fPIC ebx issues ! */ +extern void cpuid(int index, int *eax, int *ebx, int *ecx, int *edx); /* Function to test if multimedia instructions are supported... */ int mm_support(void)