diff options
Diffstat (limited to '')
-rw-r--r-- | linden/indra/llcommon/llendianswizzle.h | 95 |
1 files changed, 95 insertions, 0 deletions
diff --git a/linden/indra/llcommon/llendianswizzle.h b/linden/indra/llcommon/llendianswizzle.h new file mode 100644 index 0000000..34a530c --- /dev/null +++ b/linden/indra/llcommon/llendianswizzle.h | |||
@@ -0,0 +1,95 @@ | |||
1 | /** | ||
2 | * @file llendianswizzle.h | ||
3 | * @brief Functions for in-place bit swizzling | ||
4 | * | ||
5 | * Copyright (c) 2002-2007, Linden Research, Inc. | ||
6 | * | ||
7 | * The source code in this file ("Source Code") is provided by Linden Lab | ||
8 | * to you under the terms of the GNU General Public License, version 2.0 | ||
9 | * ("GPL"), unless you have obtained a separate licensing agreement | ||
10 | * ("Other License"), formally executed by you and Linden Lab. Terms of | ||
11 | * the GPL can be found in doc/GPL-license.txt in this distribution, or | ||
12 | * online at http://secondlife.com/developers/opensource/gplv2 | ||
13 | * | ||
14 | * There are special exceptions to the terms and conditions of the GPL as | ||
15 | * it is applied to this Source Code. View the full text of the exception | ||
16 | * in the file doc/FLOSS-exception.txt in this software distribution, or | ||
17 | * online at http://secondlife.com/developers/opensource/flossexception | ||
18 | * | ||
19 | * By copying, modifying or distributing this software, you acknowledge | ||
20 | * that you have read and understood your obligations described above, | ||
21 | * and agree to abide by those obligations. | ||
22 | * | ||
23 | * ALL LINDEN LAB SOURCE CODE IS PROVIDED "AS IS." LINDEN LAB MAKES NO | ||
24 | * WARRANTIES, EXPRESS, IMPLIED OR OTHERWISE, REGARDING ITS ACCURACY, | ||
25 | * COMPLETENESS OR PERFORMANCE. | ||
26 | */ | ||
27 | |||
28 | #ifndef LL_LLENDIANSWIZZLE_H | ||
29 | #define LL_LLENDIANSWIZZLE_H | ||
30 | |||
31 | /* This function is intended to be used for in-place swizzling, particularly after fread() of | ||
32 | binary values from a file. Such as: | ||
33 | |||
34 | numRead = fread(scale.mV, sizeof(float), 3, fp); | ||
35 | llendianswizzle(scale.mV, sizeof(float), 3); | ||
36 | |||
37 | It assumes that the values in the file are LITTLE endian, so it's a no-op on a little endian machine. | ||
38 | |||
39 | It keys off of typesize to do the correct swizzle, so make sure that typesize is the size of the native type. | ||
40 | |||
41 | 64-bit types are not yet handled. | ||
42 | */ | ||
43 | |||
44 | #ifdef LL_LITTLE_ENDIAN | ||
45 | // little endian is native for most things. | ||
46 | inline void llendianswizzle(void *,int,int) | ||
47 | { | ||
48 | // Nothing to do | ||
49 | } | ||
50 | #endif | ||
51 | |||
52 | #ifdef LL_BIG_ENDIAN | ||
53 | // big endian requires a bit of work. | ||
54 | inline void llendianswizzle(void *p,int typesize, int count) | ||
55 | { | ||
56 | int i; | ||
57 | switch(typesize) | ||
58 | { | ||
59 | case 2: | ||
60 | { | ||
61 | U16 temp; | ||
62 | for(i=count ;i!=0 ;i--) | ||
63 | { | ||
64 | temp = ((U16*)p)[0]; | ||
65 | ((U16*)p)[0] = ((temp >> 8) & 0x000000FF) | ((temp << 8) & 0x0000FF00); | ||
66 | p = (void*)(((U16*)p) + 1); | ||
67 | } | ||
68 | } | ||
69 | break; | ||
70 | |||
71 | case 4: | ||
72 | { | ||
73 | U32 temp; | ||
74 | for(i=count; i!=0; i--) | ||
75 | { | ||
76 | temp = ((U32*)p)[0]; | ||
77 | ((U32*)p)[0] = | ||
78 | ((temp >> 24) & 0x000000FF) | | ||
79 | ((temp >> 8) & 0x0000FF00) | | ||
80 | ((temp << 8) & 0x00FF0000) | | ||
81 | ((temp << 24) & 0xFF000000); | ||
82 | p = (void*)(((U32*)p) + 1); | ||
83 | } | ||
84 | } | ||
85 | break; | ||
86 | } | ||
87 | |||
88 | } | ||
89 | #endif | ||
90 | |||
91 | // Use this when working with a single integral value you want swizzled | ||
92 | |||
93 | #define llendianswizzleone(x) llendianswizzle(&(x), sizeof(x), 1) | ||
94 | |||
95 | #endif // LL_LLENDIANSWIZZLE_H | ||