openalbridge/endianness.c
author nemo
Sun, 28 Jun 2009 14:37:26 +0000
changeset 2200 8192be6e3aef
parent 2191 20c62f787a4d
child 2203 6bd39d75e0dd
permissions -rw-r--r--
koda/Smaxx changes to openal for crossplatform building
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
2191
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     1
/*
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     2
 * OpenAL Bridge - a simple portable library for OpenAL interface
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     3
 * Copyright (c) 2009 Vittorio Giovara <vittorio.giovara@gmail.com>
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     4
 *
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     5
 * This program is free software; you can redistribute it and/or modify
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     6
 * it under the terms of the GNU General Public License as published by
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     7
 * the Free Software Foundation; version 2 of the License
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     8
 *
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
     9
 * This program is distributed in the hope that it will be useful,
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    10
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    11
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    12
 * GNU General Public License for more details.
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    13
 *
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    14
 * You should have received a copy of the GNU General Public License
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    15
 * along with this program; if not, write to the Free Software
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    16
 * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    17
 */
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    18
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    19
#include "endianness.h"
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    20
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    21
#ifdef __CPLUSPLUS
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    22
extern "C" {
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    23
#endif 
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    24
	
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    25
	//from big endian to little endian
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    26
	int invert_endianness(int number){
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    27
		uint8_t n1,n2,n3,n4;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    28
		uint32_t a1,a2,a3,a4;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    29
		uint32_t done = 0;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    30
		
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    31
		n1 = number;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    32
		n2 = number >> 8;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    33
		n3 = number >> 16;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    34
		n4 = number >> 24;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    35
		
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    36
		//printf("%X, %X, %X, %X\n", n1, n2, n3, n4);
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    37
		a1 = (uint32_t) n1 << 24;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    38
		a2 = (uint32_t) n2 << 16;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    39
		a3 = (uint32_t) n3 << 8;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    40
		a4 = (uint32_t) n4;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    41
		done = a1 + a2 + a3 + a4;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    42
		//printf("%08X %08X %08X %08X = %08X\n", a1, a2, a3, a4, done);
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    43
		return done;
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    44
	}
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    45
	
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    46
#ifdef __CPLUSPLUS
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    47
}
20c62f787a4d koda's OpenAL conversion:
unc0rr
parents:
diff changeset
    48
#endif