aboutsummaryrefslogtreecommitdiff
path: root/src/m_swap.h
diff options
context:
space:
mode:
Diffstat (limited to 'src/m_swap.h')
-rw-r--r--src/m_swap.h134
1 files changed, 134 insertions, 0 deletions
diff --git a/src/m_swap.h b/src/m_swap.h
new file mode 100644
index 0000000..df86460
--- /dev/null
+++ b/src/m_swap.h
@@ -0,0 +1,134 @@
1/* Emacs style mode select -*- C++ -*-
2 *-----------------------------------------------------------------------------
3 *
4 *
5 * PrBoom: a Doom port merged with LxDoom and LSDLDoom
6 * based on BOOM, a modified and improved DOOM engine
7 * Copyright (C) 1999 by
8 * id Software, Chi Hoang, Lee Killough, Jim Flynn, Rand Phares, Ty Halderman
9 * Copyright (C) 1999-2000 by
10 * Jess Haas, Nicolas Kalkhof, Colin Phipps, Florian Schulze
11 * Copyright 2005, 2006 by
12 * Florian Schulze, Colin Phipps, Neil Stevens, Andrey Budko
13 *
14 * This program is free software; you can redistribute it and/or
15 * modify it under the terms of the GNU General Public License
16 * as published by the Free Software Foundation; either version 2
17 * of the License, or (at your option) any later version.
18 *
19 * This program is distributed in the hope that it will be useful,
20 * but WITHOUT ANY WARRANTY; without even the implied warranty of
21 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
22 * GNU General Public License for more details.
23 *
24 * You should have received a copy of the GNU General Public License
25 * along with this program; if not, write to the Free Software
26 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
27 * 02111-1307, USA.
28 *
29 * DESCRIPTION:
30 * Endianess handling, swapping 16bit and 32bit.
31 *
32 *-----------------------------------------------------------------------------*/
33
34
35#ifndef __M_SWAP__
36#define __M_SWAP__
37
38#ifdef __GNUG__
39#pragma interface
40#endif
41
42/* CPhipps - now the endianness handling, converting input or output to/from
43 * the machine's endianness to that wanted for this type of I/O
44 *
45 * To find our own endianness, use config.h
46 */
47
48#ifdef HAVE_CONFIG_H
49#include "config.h"
50#endif
51
52/* Endianess handling. */
53
54/* cph - First the macros to do the actual byte swapping */
55
56/* leban
57 * rather than continue the confusing tradition of redefining the
58 * stardard macro, we now present the doom_ntoh and doom_hton macros....
59 * might as well use the xdoom macros.
60 */
61
62/* Try to use superfast macros on systems that support them */
63#ifdef HAVE_ASM_BYTEORDER_H
64#include <asm/byteorder.h>
65#ifdef __arch__swab16
66#define doom_swap_s (signed short)__arch__swab16
67#endif
68#ifdef __arch__swab32
69#define doom_swap_l (signed long)__arch__swab32
70#endif
71#endif /* HAVE_ASM_BYTEORDER_H */
72
73#ifdef HAVE_LIBKERN_OSBYTEORDER_H
74#include <libkern/OSByteOrder.h>
75
76#define doom_swap_s (short)OSSwapInt16
77#define doom_swap_l (long)OSSwapInt32
78#endif
79
80#ifndef doom_swap_l
81#define doom_swap_l(x) \
82 ((long int)((((unsigned long int)(x) & 0x000000ffU) << 24) | \
83 (((unsigned long int)(x) & 0x0000ff00U) << 8) | \
84 (((unsigned long int)(x) & 0x00ff0000U) >> 8) | \
85 (((unsigned long int)(x) & 0xff000000U) >> 24)))
86#endif
87
88#ifndef doom_swap_s
89#define doom_swap_s(x) \
90 ((short int)((((unsigned short int)(x) & 0x00ff) << 8) | \
91 (((unsigned short int)(x) & 0xff00) >> 8)))
92#endif
93
94/* Macros are named doom_XtoYT, where
95 * X is thing to convert from, Y is thing to convert to, chosen from
96 * n for network, h for host (i.e our machine's), w for WAD (Doom data files)
97 * and T is the type, l or s for long or short
98 *
99 * CPhipps - all WADs and network packets will be little endian for now
100 * Use separate macros so network could be converted to big-endian later.
101 */
102
103#ifdef WORDS_BIGENDIAN
104
105#define doom_wtohl(x) doom_swap_l(x)
106#define doom_htowl(x) doom_swap_l(x)
107#define doom_wtohs(x) doom_swap_s(x)
108#define doom_htows(x) doom_swap_s(x)
109
110#define doom_ntohl(x) doom_swap_l(x)
111#define doom_htonl(x) doom_swap_l(x)
112#define doom_ntohs(x) doom_swap_s(x)
113#define doom_htons(x) doom_swap_s(x)
114
115#else
116
117#define doom_wtohl(x) (long int)(x)
118#define doom_htowl(x) (long int)(x)
119#define doom_wtohs(x) (short int)(x)
120#define doom_htows(x) (short int)(x)
121
122#define doom_ntohl(x) (long int)(x)
123#define doom_htonl(x) (long int)(x)
124#define doom_ntohs(x) (short int)(x)
125#define doom_htons(x) (short int)(x)
126
127#endif
128
129/* CPhipps - Boom's old LONG and SHORT endianness macros are for WAD stuff */
130
131#define LONG(x) doom_wtohl(x)
132#define SHORT(x) doom_htows(x)
133
134#endif