summaryrefslogtreecommitdiffstats
path: root/src/arch/e1/include/bits/byteswap.h
blob: 1d1a7d2f09c87b01b7fe2332bb93f65d710b5657 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
#ifndef ETHERBOOT_BITS_BYTESWAP_H
#define ETHERBOOT_BITS_BYTESWAP_H

/* We do not have byte swap functions ... We are
 * RISC processor ...
 */

static inline unsigned short __swap16(volatile unsigned short v)
{
    return ((v << 8) | (v >> 8));
}

static inline unsigned int __swap32(volatile unsigned long v)
{
    return ((v << 24) | ((v & 0xff00) << 8) | ((v & 0xff0000) >> 8) | (v >> 24));
}

#define __bswap_constant_16(x) \
	((uint16_t)((((uint16_t)(x) & 0x00ff) << 8) | \
		(((uint16_t)(x) & 0xff00) >> 8)))

#define __bswap_constant_32(x) \
	((uint32_t)((((uint32_t)(x) & 0x000000ffU) << 24) | \
		(((uint32_t)(x) & 0x0000ff00U) <<  8) | \
		(((uint32_t)(x) & 0x00ff0000U) >>  8) | \
		(((uint32_t)(x) & 0xff000000U) >> 24)))

#define __bswap_16(x) \
	(__builtin_constant_p(x) ? \
	__bswap_constant_16(x) : \
	__swap16(x))


#define __bswap_32(x) \
	(__builtin_constant_p(x) ? \
	__bswap_constant_32(x) : \
	__swap32(x))

#endif /* ETHERBOOT_BITS_BYTESWAP_H */