forked from Minki/linux
98fd433aa6
These are not the most efficient versions of swab but the wrapper does not do much byte swapping. On a big endian cpu, these routines are a no-op. Signed-off-by: Cédric Le Goater <clg@fr.ibm.com> Signed-off-by: Benjamin Herrenschmidt <benh@kernel.crashing.org>
30 lines
816 B
C
30 lines
816 B
C
#ifndef _PPC_BOOT_SWAB_H_
|
|
#define _PPC_BOOT_SWAB_H_
|
|
|
|
static inline u16 swab16(u16 x)
|
|
{
|
|
return ((x & (u16)0x00ffU) << 8) |
|
|
((x & (u16)0xff00U) >> 8);
|
|
}
|
|
|
|
static inline u32 swab32(u32 x)
|
|
{
|
|
return ((x & (u32)0x000000ffUL) << 24) |
|
|
((x & (u32)0x0000ff00UL) << 8) |
|
|
((x & (u32)0x00ff0000UL) >> 8) |
|
|
((x & (u32)0xff000000UL) >> 24);
|
|
}
|
|
|
|
static inline u64 swab64(u64 x)
|
|
{
|
|
return (u64)((x & (u64)0x00000000000000ffULL) << 56) |
|
|
(u64)((x & (u64)0x000000000000ff00ULL) << 40) |
|
|
(u64)((x & (u64)0x0000000000ff0000ULL) << 24) |
|
|
(u64)((x & (u64)0x00000000ff000000ULL) << 8) |
|
|
(u64)((x & (u64)0x000000ff00000000ULL) >> 8) |
|
|
(u64)((x & (u64)0x0000ff0000000000ULL) >> 24) |
|
|
(u64)((x & (u64)0x00ff000000000000ULL) >> 40) |
|
|
(u64)((x & (u64)0xff00000000000000ULL) >> 56);
|
|
}
|
|
#endif /* _PPC_BOOT_SWAB_H_ */
|