21 |
* along with this program ; if not, write to the Free Software |
* along with this program ; if not, write to the Free Software |
22 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
23 |
* |
* |
24 |
* $Id: portab.h,v 1.50 2004-04-05 20:36:36 edgomez Exp $ |
* $Id: portab.h,v 1.55 2006-04-26 17:44:29 Skal Exp $ |
25 |
* |
* |
26 |
****************************************************************************/ |
****************************************************************************/ |
27 |
|
|
75 |
# define CACHE_LINE 64 |
# define CACHE_LINE 64 |
76 |
# define ptr_t uint32_t |
# define ptr_t uint32_t |
77 |
# define intptr_t int32_t |
# define intptr_t int32_t |
78 |
# if _MSC_VER < 1300 |
# if defined(_MSC_VER) && _MSC_VER >= 1300 && !defined(__INTEL_COMPILER) |
|
# define uintptr_t uint32_t |
|
|
# else |
|
79 |
# include <stdarg.h> |
# include <stdarg.h> |
80 |
|
# else |
81 |
|
# define uintptr_t uint32_t |
82 |
# endif |
# endif |
83 |
#elif defined(ARCH_IS_64BIT) |
#elif defined(ARCH_IS_64BIT) |
84 |
# define CACHE_LINE 64 |
# define CACHE_LINE 64 |
85 |
# define ptr_t uint64_t |
# define ptr_t uint64_t |
86 |
# define intptr_t int64_t |
# define intptr_t int64_t |
87 |
# if _MSC_VER < 1300 |
# if defined (_MSC_VER) && _MSC_VER >= 1300 && !defined(__INTEL_COMPILER) |
|
# define uintptr_t uint64_t |
|
|
# else |
|
88 |
# include <stdarg.h> |
# include <stdarg.h> |
89 |
|
# else |
90 |
|
# define uintptr_t uint64_t |
91 |
# endif |
# endif |
92 |
#else |
#else |
93 |
# error You are trying to compile XviD without defining address bus size. |
# error You are trying to compile XviD without defining address bus size. |
129 |
char buf[DPRINTF_BUF_SZ]; |
char buf[DPRINTF_BUF_SZ]; |
130 |
va_start(args, fmt); |
va_start(args, fmt); |
131 |
vsprintf(buf, fmt, args); |
vsprintf(buf, fmt, args); |
132 |
|
va_end(args); |
133 |
OutputDebugString(buf); |
OutputDebugString(buf); |
134 |
fprintf(stderr, "%s", buf); |
fprintf(stderr, "%s", buf); |
135 |
} |
} |
151 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
152 |
| msvc x86 specific macros/functions |
| msvc x86 specific macros/functions |
153 |
*---------------------------------------------------------------------------*/ |
*---------------------------------------------------------------------------*/ |
154 |
# if defined(ARCH_IS_IA32) |
# if defined(ARCH_IS_IA32) || defined(ARCH_IS_X86_64) |
155 |
# define BSWAP(a) __asm mov eax,a __asm bswap eax __asm mov a, eax |
# define BSWAP(a) __asm mov eax,a __asm bswap eax __asm mov a, eax |
156 |
|
|
157 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
219 |
if(xvid_debug & level) { |
if(xvid_debug & level) { |
220 |
vfprintf(stderr, format, args); |
vfprintf(stderr, format, args); |
221 |
} |
} |
222 |
|
va_end(args); |
223 |
} |
} |
224 |
|
|
225 |
# else /* _DEBUG */ |
# else /* _DEBUG */ |
234 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
235 |
| gcc IA32 specific macros/functions |
| gcc IA32 specific macros/functions |
236 |
*---------------------------------------------------------------------------*/ |
*---------------------------------------------------------------------------*/ |
237 |
# if defined(ARCH_IS_IA32) |
# if defined(ARCH_IS_IA32) || defined(ARCH_IS_X86_64) |
238 |
# define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) ); |
# define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) ); |
239 |
|
|
240 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
291 |
*---------------------------------------------------------------------------*/ |
*---------------------------------------------------------------------------*/ |
292 |
# elif defined(ARCH_IS_IA64) |
# elif defined(ARCH_IS_IA64) |
293 |
# define BSWAP(a) __asm__ __volatile__ \ |
# define BSWAP(a) __asm__ __volatile__ \ |
294 |
("mux1 %1 = %0, @rev" ";;" \ |
("mux1 %0 = %1, @rev" ";;" \ |
295 |
"shr.u %1 = %1, 32" : "=r" (a) : "r" (a)); |
"shr.u %0 = %0, 32" : "=r" (a) : "r" (a)); |
296 |
|
|
297 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
298 |
{ |
{ |
343 |
char buf[DPRINTF_BUF_SZ]; |
char buf[DPRINTF_BUF_SZ]; |
344 |
va_start(args, fmt); |
va_start(args, fmt); |
345 |
vsprintf(buf, fmt, args); |
vsprintf(buf, fmt, args); |
346 |
|
va_end(args); |
347 |
fprintf(stderr, "%s", buf); |
fprintf(stderr, "%s", buf); |
348 |
} |
} |
349 |
} |
} |
422 |
if(xvid_debug & level) { |
if(xvid_debug & level) { |
423 |
vfprintf(stderr, format, args); |
vfprintf(stderr, format, args); |
424 |
} |
} |
425 |
|
va_end(args); |
426 |
} |
} |
427 |
|
|
428 |
# else /* _DEBUG */ |
# else /* _DEBUG */ |