Mercurial > mplayer.hg
annotate bswap.h @ 17531:c6ad2343ec16
EOR in index
author | ods15 |
---|---|
date | Sat, 04 Feb 2006 08:52:35 +0000 |
parents | 28b8fc8278e0 |
children | 915a3791f6c1 |
rev | line source |
---|---|
1423 | 1 #ifndef __BSWAP_H__ |
2 #define __BSWAP_H__ | |
3 | |
4 #ifdef HAVE_BYTESWAP_H | |
5 #include <byteswap.h> | |
6 #else | |
7 | |
8 #include <inttypes.h> | |
9 | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
10 #ifdef ARCH_X86_64 |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
11 # define LEGACY_REGS "=Q" |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
12 #else |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
13 # define LEGACY_REGS "=q" |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
14 #endif |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
15 |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
16 #if defined(ARCH_X86) || defined(ARCH_X86_64) |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
17 static inline uint16_t ByteSwap16(uint16_t x) |
1423 | 18 { |
19 __asm("xchgb %b0,%h0" : | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
20 LEGACY_REGS (x) : |
1423 | 21 "0" (x)); |
22 return x; | |
23 } | |
24 #define bswap_16(x) ByteSwap16(x) | |
25 | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
26 static inline uint32_t ByteSwap32(uint32_t x) |
1423 | 27 { |
28 #if __CPU__ > 386 | |
29 __asm("bswap %0": | |
30 "=r" (x) : | |
31 #else | |
32 __asm("xchgb %b0,%h0\n" | |
33 " rorl $16,%0\n" | |
34 " xchgb %b0,%h0": | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
35 LEGACY_REGS (x) : |
1423 | 36 #endif |
37 "0" (x)); | |
38 return x; | |
39 } | |
40 #define bswap_32(x) ByteSwap32(x) | |
41 | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
42 static inline uint64_t ByteSwap64(uint64_t x) |
1423 | 43 { |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
44 #ifdef ARCH_X86_64 |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
45 __asm("bswap %0": |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
46 "=r" (x) : |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
47 "0" (x)); |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
48 return x; |
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
49 #else |
10481 | 50 register union { __extension__ uint64_t __ll; |
51 uint32_t __l[2]; } __x; | |
1423 | 52 asm("xchgl %0,%1": |
53 "=r"(__x.__l[0]),"=r"(__x.__l[1]): | |
54 "0"(bswap_32((unsigned long)x)),"1"(bswap_32((unsigned long)(x>>32)))); | |
55 return __x.__ll; | |
13720
821f464b4d90
adapting existing mmx/mmx2/sse/3dnow optimizations so they work on x86_64
aurel
parents:
10481
diff
changeset
|
56 #endif |
1423 | 57 } |
58 #define bswap_64(x) ByteSwap64(x) | |
59 | |
10481 | 60 #elif defined(ARCH_SH4) |
61 | |
62 static inline uint16_t ByteSwap16(uint16_t x) { | |
63 __asm__("swap.b %0,%0":"=r"(x):"0"(x)); | |
64 return x; | |
65 } | |
66 | |
67 static inline uint32_t ByteSwap32(uint32_t x) { | |
68 __asm__( | |
69 "swap.b %0,%0\n" | |
70 "swap.w %0,%0\n" | |
71 "swap.b %0,%0\n" | |
72 :"=r"(x):"0"(x)); | |
73 return x; | |
74 } | |
75 | |
76 #define bswap_16(x) ByteSwap16(x) | |
77 #define bswap_32(x) ByteSwap32(x) | |
78 | |
79 static inline uint64_t ByteSwap64(uint64_t x) | |
80 { | |
81 union { | |
82 uint64_t ll; | |
83 struct { | |
84 uint32_t l,h; | |
85 } l; | |
86 } r; | |
87 r.l.l = bswap_32 (x); | |
88 r.l.h = bswap_32 (x>>32); | |
89 return r.ll; | |
90 } | |
91 #define bswap_64(x) ByteSwap64(x) | |
92 | |
1423 | 93 #else |
94 | |
95 #define bswap_16(x) (((x) & 0x00ff) << 8 | ((x) & 0xff00) >> 8) | |
96 | |
97 | |
98 // code from bits/byteswap.h (C) 1997, 1998 Free Software Foundation, Inc. | |
99 #define bswap_32(x) \ | |
100 ((((x) & 0xff000000) >> 24) | (((x) & 0x00ff0000) >> 8) | \ | |
101 (((x) & 0x0000ff00) << 8) | (((x) & 0x000000ff) << 24)) | |
102 | |
10481 | 103 static inline uint64_t ByteSwap64(uint64_t x) |
104 { | |
105 union { | |
106 uint64_t ll; | |
107 uint32_t l[2]; | |
108 } w, r; | |
109 w.ll = x; | |
110 r.l[0] = bswap_32 (w.l[1]); | |
111 r.l[1] = bswap_32 (w.l[0]); | |
112 return r.ll; | |
113 } | |
114 #define bswap_64(x) ByteSwap64(x) | |
115 | |
1423 | 116 #endif /* !ARCH_X86 */ |
117 | |
118 #endif /* !HAVE_BYTESWAP_H */ | |
119 | |
15976
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
120 static float inline bswap_flt(float x) { |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
121 union {uint32_t i; float f;} u; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
122 u.f = x; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
123 u.i = bswap_32(u.i); |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
124 return u.f; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
125 } |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
126 |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
127 static double inline bswap_dbl(double x) { |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
128 union {uint64_t i; double d;} u; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
129 u.d = x; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
130 u.i = bswap_64(u.i); |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
131 return u.d; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
132 } |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
133 |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
134 static long double inline bswap_ldbl(long double x) { |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
135 union {char d[10]; long double ld;} uin; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
136 union {char d[10]; long double ld;} uout; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
137 uin.ld = x; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
138 uout.d[0] = uin.d[9]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
139 uout.d[1] = uin.d[8]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
140 uout.d[2] = uin.d[7]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
141 uout.d[3] = uin.d[6]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
142 uout.d[4] = uin.d[5]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
143 uout.d[5] = uin.d[4]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
144 uout.d[6] = uin.d[3]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
145 uout.d[7] = uin.d[2]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
146 uout.d[8] = uin.d[1]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
147 uout.d[9] = uin.d[0]; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
148 return uout.ld; |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
149 } |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
150 |
1423 | 151 // be2me ... BigEndian to MachineEndian |
152 // le2me ... LittleEndian to MachineEndian | |
153 | |
154 #ifdef WORDS_BIGENDIAN | |
155 #define be2me_16(x) (x) | |
156 #define be2me_32(x) (x) | |
157 #define be2me_64(x) (x) | |
158 #define le2me_16(x) bswap_16(x) | |
159 #define le2me_32(x) bswap_32(x) | |
160 #define le2me_64(x) bswap_64(x) | |
15976
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
161 #define be2me_flt(x) (x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
162 #define be2me_dbl(x) (x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
163 #define be2me_ldbl(x) (x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
164 #define le2me_flt(x) bswap_flt(x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
165 #define le2me_dbl(x) bswap_dbl(x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
166 #define le2me_ldbl(x) bswap_ldbl(x) |
1423 | 167 #else |
168 #define be2me_16(x) bswap_16(x) | |
169 #define be2me_32(x) bswap_32(x) | |
170 #define be2me_64(x) bswap_64(x) | |
171 #define le2me_16(x) (x) | |
172 #define le2me_32(x) (x) | |
173 #define le2me_64(x) (x) | |
15976
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
174 #define be2me_flt(x) bswap_flt(x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
175 #define be2me_dbl(x) bswap_dbl(x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
176 #define be2me_ldbl(x) bswap_ldbl(x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
177 #define le2me_flt(x) (x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
178 #define le2me_dbl(x) (x) |
28b8fc8278e0
(hopefully) fixing remaining float endianness problems
reimar
parents:
13720
diff
changeset
|
179 #define le2me_ldbl(x) (x) |
1423 | 180 #endif |
181 | |
10481 | 182 #endif /* __BSWAP_H__ */ |