23 |
* along with this program; if not, write to the Free Software |
* along with this program; if not, write to the Free Software |
24 |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA |
25 |
* |
* |
26 |
* $Id: portab.h,v 1.44 2003-02-16 01:41:24 edgomez Exp $ |
* $Id: portab.h,v 1.47 2003-03-04 16:33:16 chl Exp $ |
27 |
* |
* |
28 |
****************************************************************************/ |
****************************************************************************/ |
29 |
|
|
89 |
****************************************************************************/ |
****************************************************************************/ |
90 |
|
|
91 |
#if defined(ARCH_IS_32BIT) |
#if defined(ARCH_IS_32BIT) |
92 |
# define CACHE_LINE 16 |
# define CACHE_LINE 64 |
93 |
# define ptr_t uint32_t |
# define ptr_t uint32_t |
94 |
|
# define intptr_t int32_t |
95 |
|
# define uintptr_t uint32_t |
96 |
#elif defined(ARCH_IS_64BIT) |
#elif defined(ARCH_IS_64BIT) |
97 |
# define CACHE_LINE 32 |
# define CACHE_LINE 64 |
98 |
# define ptr_t uint64_t |
# define ptr_t uint64_t |
99 |
|
# define intptr_t int64_t |
100 |
|
# define uintptr_t uint64_t |
101 |
#else |
#else |
102 |
# error You are trying to compile XviD without defining address bus size. |
# error You are trying to compile XviD without defining address bus size. |
103 |
#endif |
#endif |
143 |
} |
} |
144 |
} |
} |
145 |
# else |
# else |
146 |
static __inline void DPRINTF(int level, char *fmt, ...) |
static __inline void DPRINTF(int level, char *fmt, ...) {} |
|
{ |
|
|
} |
|
147 |
# endif |
# endif |
148 |
|
|
149 |
# if _MSC_VER <= 1200 |
# if _MSC_VER <= 1200 |
162 |
# if defined(ARCH_IS_IA32) |
# if defined(ARCH_IS_IA32) |
163 |
# 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 |
164 |
|
|
|
# ifdef _PROFILING_ |
|
165 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
166 |
{ |
{ |
167 |
int64_t ts; |
int64_t ts; |
174 |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
175 |
return ts; |
return ts; |
176 |
} |
} |
|
# endif |
|
177 |
|
|
178 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
179 |
| msvc GENERIC (plain C only) - Probably alpha or some embedded device |
| msvc GENERIC (plain C only) - Probably alpha or some embedded device |
183 |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
184 |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
185 |
|
|
|
# ifdef _PROFILING_ |
|
186 |
# include <time.h> |
# include <time.h> |
187 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
188 |
{ |
{ |
189 |
return (int64_t)clock(); |
return (int64_t)clock(); |
190 |
} |
} |
|
# endif |
|
191 |
|
|
192 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
193 |
| msvc Not given architecture - This is probably an user who tries to build |
| msvc Not given architecture - This is probably an user who tries to build |
245 |
# if defined(ARCH_IS_IA32) |
# if defined(ARCH_IS_IA32) |
246 |
# define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) ); |
# define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) ); |
247 |
|
|
|
# ifdef _PROFILING_ |
|
248 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
249 |
{ |
{ |
250 |
int64_t ts; |
int64_t ts; |
253 |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
254 |
return ts; |
return ts; |
255 |
} |
} |
|
# endif |
|
256 |
|
|
257 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
258 |
| gcc PPC and PPC Altivec specific macros/functions |
| gcc PPC and PPC Altivec specific macros/functions |
261 |
# define BSWAP(a) __asm__ __volatile__ \ |
# define BSWAP(a) __asm__ __volatile__ \ |
262 |
( "lwbrx %0,0,%1; eieio" : "=r" (a) : "r" (&(a)), "m" (a)); |
( "lwbrx %0,0,%1; eieio" : "=r" (a) : "r" (&(a)), "m" (a)); |
263 |
|
|
|
# ifdef _PROFILING_ |
|
264 |
static __inline unsigned long get_tbl(void) |
static __inline unsigned long get_tbl(void) |
265 |
{ |
{ |
266 |
unsigned long tbl; |
unsigned long tbl; |
284 |
}while (tb != get_tbl()); |
}while (tb != get_tbl()); |
285 |
return (((int64_t) tu) << 32) | (int64_t) tb; |
return (((int64_t) tu) << 32) | (int64_t) tb; |
286 |
} |
} |
|
# endif |
|
287 |
|
|
288 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
289 |
| gcc IA64 specific macros/functions |
| gcc IA64 specific macros/functions |
293 |
("mux1 %1 = %0, @rev" ";;" \ |
("mux1 %1 = %0, @rev" ";;" \ |
294 |
"shr.u %1 = %1, 32" : "=r" (a) : "r" (a)); |
"shr.u %1 = %1, 32" : "=r" (a) : "r" (a)); |
295 |
|
|
|
# ifdef _PROFILING_ |
|
296 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
297 |
{ |
{ |
298 |
unsigned long result; |
unsigned long result; |
299 |
__asm__ __volatile__("mov %0=ar.itc" : "=r"(result) :: "memory"); |
__asm__ __volatile__("mov %0=ar.itc" : "=r"(result) :: "memory"); |
300 |
return result; |
return result; |
301 |
} |
} |
|
# endif |
|
302 |
|
|
303 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
304 |
| gcc GENERIC (plain C only) specific macros/functions |
| gcc GENERIC (plain C only) specific macros/functions |
308 |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
309 |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
310 |
|
|
|
# ifdef _PROFILING_ |
|
311 |
# include <time.h> |
# include <time.h> |
312 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
313 |
{ |
{ |
314 |
return (int64_t)clock(); |
return (int64_t)clock(); |
315 |
} |
} |
|
# endif |
|
316 |
|
|
317 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
318 |
| gcc Not given architecture - This is probably an user who tries to build |
| gcc Not given architecture - This is probably an user who tries to build |
360 |
|
|
361 |
# 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 |
362 |
|
|
|
# ifdef _PROFILING_ |
|
363 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
364 |
{ |
{ |
365 |
uint64_t ts; |
uint64_t ts; |
372 |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1); |
373 |
return ts; |
return ts; |
374 |
} |
} |
|
# endif |
|
375 |
|
|
376 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
377 |
| watcom GENERIC (plain C only) specific macros/functions. |
| watcom GENERIC (plain C only) specific macros/functions. |
384 |
(((x) & 0x0000ff00) << 8) | \ |
(((x) & 0x0000ff00) << 8) | \ |
385 |
(((x) & 0x000000ff) << 24)) |
(((x) & 0x000000ff) << 24)) |
386 |
|
|
|
# ifdef _PROFILING_ |
|
387 |
static int64_t read_counter() { return 0; } |
static int64_t read_counter() { return 0; } |
|
# endif |
|
388 |
|
|
389 |
/*---------------------------------------------------------------------------- |
/*---------------------------------------------------------------------------- |
390 |
| watcom Not given architecture - This is probably an user who tries to build |
| watcom Not given architecture - This is probably an user who tries to build |
431 |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
((a) = (((a) & 0xff) << 24) | (((a) & 0xff00) << 8) | \ |
432 |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
(((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff)) |
433 |
|
|
|
# ifdef _PROFILING_ |
|
434 |
# include <time.h> |
# include <time.h> |
435 |
static __inline int64_t read_counter(void) |
static __inline int64_t read_counter(void) |
436 |
{ |
{ |
437 |
return (int64_t)clock(); |
return (int64_t)clock(); |
438 |
} |
} |
|
# endif |
|
439 |
|
|
440 |
# define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \ |
# define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \ |
441 |
type name[(sizex)*(sizey)] |
type name[(sizex)*(sizey)] |