[cvs] / xvidcore / src / portab.h Repository:
ViewVC logotype

Diff of /xvidcore/src/portab.h

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

revision 1.14, Sun Apr 7 11:57:47 2002 UTC revision 1.35, Sat Nov 16 23:38:16 2002 UTC
# Line 1  Line 1 
1    /*****************************************************************************
2     *
3     *  XVID MPEG-4 VIDEO CODEC
4     *  - Portable macros, types and inlined assembly -
5     *
6     *  Copyright(C) 2002 Michael Militzer <isibaar@xvid.org>
7     *               2002 Peter Ross <pross@xvid.org>
8     *               2002 Edouard Gomez <ed.gomez@wanadoo.fr>
9     *
10     *  This file is part of XviD, a free MPEG-4 video encoder/decoder
11     *
12     *  XviD is free software; you can redistribute it and/or modify it
13     *  under the terms of the GNU General Public License as published by
14     *  the Free Software Foundation; either version 2 of the License, or
15     *  (at your option) any later version.
16     *
17     *  This program is distributed in the hope that it will be useful,
18     *  but WITHOUT ANY WARRANTY; without even the implied warranty of
19     *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20     *  GNU General Public License for more details.
21     *
22     *  You should have received a copy of the GNU General Public License
23     *  along with this program; if not, write to the Free Software
24     *  Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307 USA
25     *
26     *  Under section 8 of the GNU General Public License, the copyright
27     *  holders of XVID explicitly forbid distribution in the following
28     *  countries:
29     *
30     *    - Japan
31     *    - United States of America
32     *
33     *  Linking XviD statically or dynamically with other modules is making a
34     *  combined work based on XviD.  Thus, the terms and conditions of the
35     *  GNU General Public License cover the whole combination.
36     *
37     *  As a special exception, the copyright holders of XviD give you
38     *  permission to link XviD with independent modules that communicate with
39     *  XviD solely through the VFW1.1 and DShow interfaces, regardless of the
40     *  license terms of these independent modules, and to copy and distribute
41     *  the resulting combined work under terms of your choice, provided that
42     *  every copy of the combined work is accompanied by a complete copy of
43     *  the source code of XviD (the version of XviD used to produce the
44     *  combined work), being distributed under the terms of the GNU General
45     *  Public License plus this exception.  An independent module is a module
46     *  which is not derived from or based on XviD.
47     *
48     *  Note that people who make modified versions of XviD are not obligated
49     *  to grant this special exception for their modified versions; it is
50     *  their choice whether to do so.  The GNU General Public License gives
51     *  permission to release a modified version without this exception; this
52     *  exception also makes it possible to release a modified version which
53     *  carries forward this exception.
54     *
55     * $Id$
56     *
57     ****************************************************************************/
58    
59  #ifndef _PORTAB_H_  #ifndef _PORTAB_H_
60  #define _PORTAB_H_  #define _PORTAB_H_
61    
62  #if defined(WIN32)  /*****************************************************************************
63     *  Common things
64  #include <windows.h>   ****************************************************************************/
65    
66    /* Debug level masks */
67    #define DPRINTF_ERROR           0x00000001
68    #define DPRINTF_STARTCODE       0x00000002
69    #define DPRINTF_HEADER          0x00000004
70    #define DPRINTF_TIMECODE        0x00000008
71    #define DPRINTF_MB                      0x00000010
72    #define DPRINTF_COEFF           0x00000020
73    #define DPRINTF_MV                      0x00000040
74    #define DPRINTF_DEBUG           0x80000000
75    
76    /* debug level for this library */
77    #define DPRINTF_LEVEL           0
78    
79    /* Buffer size for non C99 compliant compilers (msvc) */
80    #define DPRINTF_BUF_SZ  1024
81    
82    /*****************************************************************************
83     *  Types used in XviD sources
84     ****************************************************************************/
85    
86    /*----------------------------------------------------------------------------
87     | Standard Unix include file (sorry, we put all unix into "linux" case)
88     *---------------------------------------------------------------------------*/
89    
90  #define DEBUGCBR(A,B,C) { char tmp[100]; wsprintf(tmp, "CBR: frame: %i, quant: %i, deviation: %i\n", (A), (B), (C)); OutputDebugString(tmp); }  #if defined(LINUX) || defined(BEOS) || defined(FREEBSD)
91    
92  #ifdef _DEBUG  /* All (u)int(size)_t types are defined here */
93  #define DEBUG(S) OutputDebugString((S));  #    include <inttypes.h>
 #define DEBUG1(S,I) { char tmp[100]; wsprintf(tmp, "%s %i\n", (S), (I)); OutputDebugString(tmp); }  
 #define DEBUG2(X,A,B) { char tmp[100]; wsprintf(tmp, "%s %i %i\n", (X), (A), (B)); OutputDebugString(tmp); }  
 #define DEBUG3(X,A,B,C){ char tmp[1000]; wsprintf(tmp,"%s %i %i %i",(X),(A), (B), (C)); OutputDebugString(tmp); }  
 #define DEBUG8(X,A,B,C,D,E,F,G,H){ char tmp[1000]; wsprintf(tmp,"%s %i %i %i %i %i %i %i %i",(X),(A),(B),(C),(D),(E),(F),(G),(H)); OutputDebugString(tmp); }  
 #else  
 #define DEBUG(S)  
 #define DEBUG1(S,I)  
 #define DEBUG2(X,A,B)  
 #define DEBUG3(X,A,B,C)  
 #define DEBUG8(X,A,B,C,D,E,F,G,H)  
 #endif  
94    
95    /*----------------------------------------------------------------------------
96     | msvc (lacks such a header file)
97     *---------------------------------------------------------------------------*/
98    
99    #elif defined(_MSC_VER)
100  #define int8_t char  #define int8_t char
101  #define uint8_t unsigned char  #define uint8_t unsigned char
102  #define int16_t short  #define int16_t short
# Line 31  Line 106 
106  #define int64_t __int64  #define int64_t __int64
107  #define uint64_t unsigned __int64  #define uint64_t unsigned __int64
108    
109  #define EMMS() __asm {emms}  /*----------------------------------------------------------------------------
110     | Fallback when using gcc
111     *---------------------------------------------------------------------------*/
112    
113    #elif defined(__GNUC__)
114    
115    #    define int8_t   char
116    #    define uint8_t  unsigned char
117    #    define int16_t  short
118    #    define uint16_t unsigned short
119    #    define int32_t  int
120    #    define uint32_t unsigned int
121    #    define int64_t  long long
122    #    define uint64_t unsigned long long
123    
124    /*----------------------------------------------------------------------------
125     | Ok, we don't know how to define these types... error
126     *---------------------------------------------------------------------------*/
127    
128    #else
129    #    error Do not know how to define (u)int(size)_t types
130    #endif
131    
132    /*****************************************************************************
133     *  Some things that are only architecture dependant
134     ****************************************************************************/
135    
136    #if defined(ARCH_X86) || defined(ARCH_PPC) || defined(ARCH_MIPS)  || defined(ARCH_SPARC)
137  #define CACHE_LINE  16  #define CACHE_LINE  16
138    #    define ptr_t uint32_t
139    #elif defined(ARCH_IA64)
140    #    define CACHE_LINE  32
141    #    define ptr_t uint64_t
142    #else
143    #    error Architecture not supported.
144    #endif
145    
146    /*****************************************************************************
147     *  Things that must be sorted by compiler and then by architecture
148     ****************************************************************************/
149    
150    /*****************************************************************************
151     *  MSVC compiler specific macros, functions
152     ****************************************************************************/
153    
154    #if defined(_MSC_VER)
155    
156    /*----------------------------------------------------------------------------
157     | Common msvc stuff
158     *---------------------------------------------------------------------------*/
159    
160    #include <windows.h>
161    #include <stdio.h>
162    
163        /*
164         * This function must be declared/defined all the time because MSVC does
165         * not support C99 variable arguments macros
166         */
167        static __inline void DPRINTF(int level, char *fmt, ...)
168        {
169            if (DPRINTF_LEVEL & level) {
170                va_list args;
171                char buf[DPRINTF_BUF_SZ];
172                va_start(args, fmt);
173                vsprintf(buf, fmt, args);
174                OutputDebugString(buf);
175                fprintf(stderr, "%s\n", buf);
176             }
177         }
178    
179  #if _MSC_VER <= 1200  #if _MSC_VER <= 1200
180  #define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \  #define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \
# Line 44  Line 185 
185          __declspec(align(alignment)) type name[(sizex)*(sizey)]          __declspec(align(alignment)) type name[(sizex)*(sizey)]
186  #endif  #endif
187    
188  // needed for bitstream.h  
189    /*----------------------------------------------------------------------------
190     | msvc x86 specific macros/functions
191     *---------------------------------------------------------------------------*/
192    #    if defined(ARCH_X86)
193  #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
194    #        define EMMS() __asm {emms}
195    
196  // needed for timer.c               static __inline int64_t read_counter(void)
197  static __inline int64_t read_counter() {               {
198          int64_t ts;          int64_t ts;
199          uint32_t ts1, ts2;          uint32_t ts1, ts2;
   
200          __asm {          __asm {
201                  rdtsc                  rdtsc
202                  mov  ts1, eax                  mov  ts1, eax
203                  mov  ts2, edx                  mov  ts2, edx
204          }          }
   
205          ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1);          ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1);
   
206          return ts;          return ts;
207  }  }
208    
209  #elif defined(LINUX) || defined(DJGPP)  /*----------------------------------------------------------------------------
210     | msvc unknown architecture
211     *---------------------------------------------------------------------------*/
212    #    else
213    #        error Architecture not supported.
214    #    endif
215    
216    
217    
218    
219    /*****************************************************************************
220     *  GNU CC compiler stuff
221     ****************************************************************************/
222    
223    #elif defined(__GNUC__) /* Compiler test */
224    
225    /*----------------------------------------------------------------------------
226     | Common gcc stuff
227     *---------------------------------------------------------------------------*/
228    
229    /*
230     * As gcc is (mostly) C99 compliant, we define DPRINTF only if it's realy needed
231     * and it's a macro calling fprintf directly
232     */
233  #ifdef _DEBUG  #ifdef _DEBUG
234    
235            /* Needed for all debuf fprintf calls */
236  #include <stdio.h>  #include <stdio.h>
 #define DEBUG_WHERE               stdout  
 #define DEBUG(S)                  fprintf(DEBUG_WHERE, "%s\n", (S));  
 #define DEBUG1(S,I)               fprintf(DEBUG_WHERE, "%s %i\n", (S), (I))  
 #define DEBUG2(S,A,B)             fprintf(DEBUG_WHERE, "%s%i=%i\n", (S), (A), (B))  
 #define DEBUG3(S,A,B,C)           fprintf(DEBUG_WHERE, "%s %i %x %x\n", (S), (A), (B), (C))  
 #define DEBUG8(S,A,B,C,D,E,F,G,H)  
 #define DEBUGCBR(A,B,C)           fprintf(DEBUG_WHERE, "CBR: frame: %i, quant: %i, deviation: %i\n", (A), (B), (C))  
 #else  
 #define DEBUG(S)  
 #define DEBUG1(S,I)  
 #define DEBUG2(X,A,B)  
 #define DEBUG3(X,A,B,C)  
 #define DEBUG8(X,A,B,C,D,E,F,G,H)  
 #define DEBUGCBR(A,B,C)  
 #endif  
237    
238  #define CACHE_LINE  16  #       define DPRINTF(level, format, ...) \
239                do {\
240                    if(DPRINTF_LEVEL & level)\
241                        fprintf(stderr, format"\n", ##__VA_ARGS__);\
242                }while(0);
243    
244    #    else /* _DEBUG */
245    #        define DPRINTF(level, format, ...)
246    #    endif /* _DEBUG */
247    
 #if defined(LINUX)  
248    
 #include <stdint.h>  
249    
250  #define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \  #define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \
251          type name##_storage[(sizex)*(sizey)+(alignment)-1]; \          type name##_storage[(sizex)*(sizey)+(alignment)-1]; \
252          type * name = (type *) (((int32_t) name##_storage+(alignment - 1)) & ~((int32_t)(alignment)-1))              type * name = (type *) (((ptr_t) name##_storage+(alignment - 1)) & ~((ptr_t)(alignment)-1))
   
 #else  
   
 #define #define #define DECLARE_ALIGNED_MATRIX(name,sizex,sizey,type,alignment) \  
         __attribute__ ((__aligned__(CACHE_LINE))) type name[(sizex)*(sizey)]  
   
 #define int8_t   char  
 #define uint8_t  unsigned char  
 #define int16_t  short  
 #define uint16_t unsigned short  
 #define int32_t  int  
 #define uint32_t unsigned int  
 #define int64_t  long long  
 #define uint64_t unsigned long long  
253    
254  #endif  /*----------------------------------------------------------------------------
255     | gcc x86 specific macros/functions
256     *---------------------------------------------------------------------------*/
257    #    if defined(ARCH_X86)
258    #        define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) );
259    #        define EMMS() __asm__ ("emms\n\t");
260    
261             static __inline int64_t read_counter(void)
262             {
263                 int64_t ts;
264                 uint32_t ts1, ts2;
265                 __asm__ __volatile__("rdtsc\n\t":"=a"(ts1), "=d"(ts2));
266                 ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1);
267                 return ts;
268             }
269    
270  // needed for bitstream.h  /*----------------------------------------------------------------------------
271  #ifdef ARCH_PPC   | gcc PPC and PPC Altivec specific macros/functions
272          #define BSWAP(a) __asm__ __volatile__ ( "lwbrx %0,0,%1; eieio" : "=r" (a) : \   *---------------------------------------------------------------------------*/
273                  "r" (&(a)), "m" (a));  #    elif defined(ARCH_PPC)
274    #        define BSWAP(a) __asm__ __volatile__ \
275                    ( "lwbrx %0,0,%1; eieio" : "=r" (a) : "r" (&(a)), "m" (a));
276          #define EMMS()          #define EMMS()
277    
278          static __inline unsigned long get_tbl(void) {           static __inline unsigned long get_tbl(void)
279             {
280                  unsigned long tbl;                  unsigned long tbl;
281                  asm volatile("mftb %0" : "=r" (tbl));                  asm volatile("mftb %0" : "=r" (tbl));
282                  return tbl;                  return tbl;
283          }          }
284          static __inline unsigned long get_tbu(void) {  
285             static __inline unsigned long get_tbu(void)
286             {
287                  unsigned long tbl;                  unsigned long tbl;
288                  asm volatile("mftbu %0" : "=r" (tbl));                  asm volatile("mftbu %0" : "=r" (tbl));
289                  return tbl;                  return tbl;
290          }          }
291          static __inline int64_t read_counter() {  
292             static __inline int64_t read_counter(void)
293             {
294                  unsigned long tb, tu;                  unsigned long tb, tu;
295                  do {                  do {
296                          tu = get_tbu();                          tu = get_tbu();
# Line 135  Line 298 
298                  } while(tb != get_tbl());                  } while(tb != get_tbl());
299                  return (((int64_t)tu) << 32) | (int64_t)tb;                  return (((int64_t)tu) << 32) | (int64_t)tb;
300          }          }
 #else  
         #define BSWAP(a) __asm__ ( "bswapl %0\n" : "=r" (a) : "0" (a) )  
         #define EMMS() __asm__("emms\n\t")  
301    
302    /*----------------------------------------------------------------------------
303     | gcc IA64 specific macros/functions
304     *---------------------------------------------------------------------------*/
305    #    elif defined(ARCH_IA64)
306    #        define BSWAP(a)  __asm__ __volatile__ \
307                    ("mux1 %1 = %0, @rev" ";;" \
308                     "shr.u %1 = %1, 32" : "=r" (a) : "r" (a));
309    #        define EMMS()
310    
311  // needed for timer.c           static __inline int64_t read_counter(void) {
312  static __inline int64_t read_counter() {               unsigned long result;
313      int64_t ts;               __asm__ __volatile__("mov %0=ar.itc" : "=r"(result) :: "memory");
314      uint32_t ts1, ts2;               return result;
   
     __asm__ __volatile__("rdtsc\n\t":"=a"(ts1), "=d"(ts2));  
   
     ts = ((uint64_t) ts2 << 32) | ((uint64_t) ts1);  
   
     return ts;  
315  }  }
316    
317  #endif  /*----------------------------------------------------------------------------
318     | gcc SPARC specific macros/functions
319  #else // OTHER OS   *---------------------------------------------------------------------------*/
320    #    elif defined(ARCH_SPARC)
321  #define DEBUG(S)  #        define BSWAP(a) \
322  #define DEBUG1(S,I)                  ((a) = (((a) & 0xff) << 24)  | (((a) & 0xff00) << 8) | \
323  #define DEBUG2(X,A,B)                         (((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff))
 #define DEBUG3(X,A,B,C)  
 #define DEBUG8(X,A,B,C,D,E,F,G,H)  
 #define DEBUGCBR(A,B,C)  
   
 #include <inttypes.h>  
   
324  #define EMMS()  #define EMMS()
325    
326  // needed for bitstream.h           static __inline int64_t read_counter(void)
327             {
328                 return 0;
329             }
330    
331    /*----------------------------------------------------------------------------
332     | gcc MIPS specific macros/functions
333     *---------------------------------------------------------------------------*/
334    #    elif defined(ARCH_MIPS)
335  #define BSWAP(a) \  #define BSWAP(a) \
336           ((a) = ( ((a)&0xff)<<24) | (((a)&0xff00)<<8) | (((a)>>8)&0xff00) | (((a)>>24)&0xff))                  ((a) = (((a) & 0xff) << 24)  | (((a) & 0xff00) << 8) | \
337                           (((a) >> 8) & 0xff00) | (((a) >> 24) & 0xff))
338    #        define EMMS()
339    
340  // rdtsc command most likely not supported,           static __inline int64_t read_counter(void)
341  // so just dummy code here           {
 static __inline int64_t read_counter() {  
342          return 0;          return 0;
343  }  }
344    
345  #define CACHE_LINE  16  /*----------------------------------------------------------------------------
346  #define CACHE_ALIGN   | XviD + gcc unsupported Architecture
347     *---------------------------------------------------------------------------*/
348    #    else
349    #        error Architecture not supported.
350    #    endif /* Architecture checking */
351    
352  #endif  /*****************************************************************************
353     *  Unknown compiler
354     ****************************************************************************/
355    #else /* Compiler test */
356    
357    #    error Compiler not supported
358    
359  #endif // _PORTAB_H_  #endif /* Compiler test */
360    
361    
362    #endif

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.35

No admin address has been configured
ViewVC Help
Powered by ViewVC 1.0.4