blob: 8bcf277c84680a14e9403c4f113ebf7627016cf3 [file] [log] [blame]
Linus Torvalds1da177e2005-04-16 15:20:36 -07001#ifndef _S390_BYTEORDER_H
2#define _S390_BYTEORDER_H
3
4/*
5 * include/asm-s390/byteorder.h
6 *
7 * S390 version
8 * Copyright (C) 1999 IBM Deutschland Entwicklung GmbH, IBM Corporation
9 * Author(s): Martin Schwidefsky (schwidefsky@de.ibm.com)
10 */
11
12#include <asm/types.h>
13
Harvey Harrison64253ac2008-12-25 13:39:20 +010014#define __BIG_ENDIAN
15
16#ifndef __s390x__
17# define __SWAB_64_THRU_32__
18#endif
Linus Torvalds1da177e2005-04-16 15:20:36 -070019
20#ifdef __s390x__
Harvey Harrison64253ac2008-12-25 13:39:20 +010021static inline __u64 __arch_swab64p(const __u64 *x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070022{
23 __u64 result;
24
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020025 asm volatile("lrvg %0,%1" : "=d" (result) : "m" (*x));
Linus Torvalds1da177e2005-04-16 15:20:36 -070026 return result;
27}
Harvey Harrison64253ac2008-12-25 13:39:20 +010028#define __arch_swab64p __arch_swab64p
Linus Torvalds1da177e2005-04-16 15:20:36 -070029
Harvey Harrison64253ac2008-12-25 13:39:20 +010030static inline __u64 __arch_swab64(__u64 x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070031{
32 __u64 result;
33
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020034 asm volatile("lrvgr %0,%1" : "=d" (result) : "d" (x));
Linus Torvalds1da177e2005-04-16 15:20:36 -070035 return result;
36}
Harvey Harrison64253ac2008-12-25 13:39:20 +010037#define __arch_swab64 __arch_swab64
Linus Torvalds1da177e2005-04-16 15:20:36 -070038
Harvey Harrison64253ac2008-12-25 13:39:20 +010039static inline void __arch_swab64s(__u64 *x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070040{
Harvey Harrison64253ac2008-12-25 13:39:20 +010041 *x = __arch_swab64p(x);
Linus Torvalds1da177e2005-04-16 15:20:36 -070042}
Harvey Harrison64253ac2008-12-25 13:39:20 +010043#define __arch_swab64s __arch_swab64s
Linus Torvalds1da177e2005-04-16 15:20:36 -070044#endif /* __s390x__ */
45
Harvey Harrison64253ac2008-12-25 13:39:20 +010046static inline __u32 __arch_swab32p(const __u32 *x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070047{
48 __u32 result;
49
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020050 asm volatile(
Linus Torvalds1da177e2005-04-16 15:20:36 -070051#ifndef __s390x__
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020052 " icm %0,8,3(%1)\n"
53 " icm %0,4,2(%1)\n"
54 " icm %0,2,1(%1)\n"
55 " ic %0,0(%1)"
56 : "=&d" (result) : "a" (x), "m" (*x) : "cc");
Linus Torvalds1da177e2005-04-16 15:20:36 -070057#else /* __s390x__ */
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020058 " lrv %0,%1"
59 : "=d" (result) : "m" (*x));
Linus Torvalds1da177e2005-04-16 15:20:36 -070060#endif /* __s390x__ */
61 return result;
62}
Harvey Harrison64253ac2008-12-25 13:39:20 +010063#define __arch_swab32p __arch_swab32p
Linus Torvalds1da177e2005-04-16 15:20:36 -070064
Harvey Harrison64253ac2008-12-25 13:39:20 +010065#ifdef __s390x__
66static inline __u32 __arch_swab32(__u32 x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070067{
Linus Torvalds1da177e2005-04-16 15:20:36 -070068 __u32 result;
69
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020070 asm volatile("lrvr %0,%1" : "=d" (result) : "d" (x));
Linus Torvalds1da177e2005-04-16 15:20:36 -070071 return result;
Harvey Harrison64253ac2008-12-25 13:39:20 +010072}
73#define __arch_swab32 __arch_swab32
Linus Torvalds1da177e2005-04-16 15:20:36 -070074#endif /* __s390x__ */
Linus Torvalds1da177e2005-04-16 15:20:36 -070075
Harvey Harrison64253ac2008-12-25 13:39:20 +010076static inline __u16 __arch_swab16p(const __u16 *x)
Linus Torvalds1da177e2005-04-16 15:20:36 -070077{
78 __u16 result;
79
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020080 asm volatile(
Linus Torvalds1da177e2005-04-16 15:20:36 -070081#ifndef __s390x__
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020082 " icm %0,2,1(%1)\n"
83 " ic %0,0(%1)\n"
84 : "=&d" (result) : "a" (x), "m" (*x) : "cc");
Linus Torvalds1da177e2005-04-16 15:20:36 -070085#else /* __s390x__ */
Martin Schwidefsky94c12cc2006-09-28 16:56:43 +020086 " lrvh %0,%1"
87 : "=d" (result) : "m" (*x));
Linus Torvalds1da177e2005-04-16 15:20:36 -070088#endif /* __s390x__ */
89 return result;
90}
Harvey Harrison64253ac2008-12-25 13:39:20 +010091#define __arch_swab16p __arch_swab16p
Linus Torvalds1da177e2005-04-16 15:20:36 -070092
Harvey Harrison64253ac2008-12-25 13:39:20 +010093#include <linux/byteorder.h>
Linus Torvalds1da177e2005-04-16 15:20:36 -070094
95#endif /* _S390_BYTEORDER_H */