]> icculus.org git repositories - btb/d2x.git/blob - include/byteswap.h
7622c90e1b3664763fe99a79bf8157d1d8df1b21
[btb/d2x.git] / include / byteswap.h
1 /* $Id: byteswap.h,v 1.8 2003-10-03 04:01:21 btb Exp $ */
2 /*
3 THE COMPUTER CODE CONTAINED HEREIN IS THE SOLE PROPERTY OF PARALLAX
4 SOFTWARE CORPORATION ("PARALLAX").  PARALLAX, IN DISTRIBUTING THE CODE TO
5 END-USERS, AND SUBJECT TO ALL OF THE TERMS AND CONDITIONS HEREIN, GRANTS A
6 ROYALTY-FREE, PERPETUAL LICENSE TO SUCH END-USERS FOR USE BY SUCH END-USERS
7 IN USING, DISPLAYING,  AND CREATING DERIVATIVE WORKS THEREOF, SO LONG AS
8 SUCH USE, DISPLAY OR CREATION IS FOR NON-COMMERCIAL, ROYALTY OR REVENUE
9 FREE PURPOSES.  IN NO EVENT SHALL THE END-USER USE THE COMPUTER CODE
10 CONTAINED HEREIN FOR REVENUE-BEARING PURPOSES.  THE END-USER UNDERSTANDS
11 AND AGREES TO THE TERMS HEREIN AND ACCEPTS THE SAME BY USE OF THIS FILE.
12 COPYRIGHT 1993-1999 PARALLAX SOFTWARE CORPORATION.  ALL RIGHTS RESERVED.
13 */
14
15 /*
16  *
17  * code to swap bytes because of big/little endian problems.
18  * contains the macros:
19  * SWAP{INT,SHORT}(x): returns a swapped version of x
20  * INTEL_{INT,SHORT}(x): returns x after conversion to/from little endian
21  * GET_INTEL_{INT,SHORT}(dest, src): gets value dest from buffer src
22  * PUT_INTEL_{INT,SHORT}(dest, src): puts value src into buffer dest
23  *
24  * the GET/PUT macros are safe to use on platforms which segfault on unaligned word access
25  *
26  * Old Log:
27  * Revision 1.4  1995/08/23  21:28:15  allender
28  * fix mcc compiler warning
29  *
30  * Revision 1.3  1995/08/18  15:51:42  allender
31  * put back in old byteswapping code
32  *
33  * Revision 1.2  1995/05/04  20:10:18  allender
34  * proper prototypes
35  *
36  * Revision 1.1  1995/03/30  15:02:11  allender
37  * Initial revision
38  *
39  */
40
41 #ifndef _BYTESWAP_H
42 #define _BYTESWAP_H
43
44 #include "pstypes.h"
45
46 #define SWAPSHORT(x) (((ubyte)(x) << 8) | (((ushort)(x)) >> 8))
47 #define SWAPINT(x)   (((x)<<24) | (((uint)(x)) >> 24) | (((x) &0x0000ff00) << 8) | (((x) & 0x00ff0000) >> 8))
48
49 #ifndef WORDS_BIGENDIAN
50 #define INTEL_INT(x)    x
51 #define INTEL_SHORT(x)  x
52 #else // ! WORDS_BIGENDIAN
53 #define INTEL_INT(x)    SWAPINT(x)
54 #define INTEL_SHORT(x)  SWAPSHORT(x)
55 #endif // ! WORDS_BIGENDIAN
56
57 #ifndef WORDS_NEED_ALIGNMENT
58 #define GET_INTEL_INT(d, s)     { (uint)(d) = INTEL_INT(*(uint *)(s)); }
59 #define GET_INTEL_SHORT(d, s)   { (ushort)(d) = INTEL_SHORT(*(ushort *)(s)); }
60 #define PUT_INTEL_INT(d, s)     { *(uint *)(d) = INTEL_INT((uint)(s)); }
61 #define PUT_INTEL_SHORT(d, s)   { *(ushort *)(d) = INTEL_SHORT((ushort)(s)); }
62 #else // ! WORDS_NEED_ALIGNMENT
63 #define GET_INTEL_INT(d, s)     { uint tmp; \
64                                   memcpy((void *)&tmp, (void *)(s), 4); \
65                                   (uint)(d) = INTEL_INT(tmp); }
66 #define GET_INTEL_SHORT(d, s)   { ushort tmp; \
67                                   memcpy((void *)&tmp, (void *)(s), 4); \
68                                   (ushort)(d) = INTEL_SHORT(tmp); }
69 #define PUT_INTEL_INT(d, s)     { uint tmp = INTEL_INT(s); \
70                                   memcpy((void *)d, (void *)&tmp, 4);}
71 #define PUT_INTEL_SHORT(d, s)   { ushort tmp = INTEL_SHORT(s); \
72                                   memcpy((void *)d, (void *)&tmp, 4);}
73 #endif // ! WORDS_NEED_ALIGNMENT
74
75 #endif // ! _BYTESWAP_H