1*8516d557Sskrll /* $NetBSD: byte_swap.h,v 1.8 2009/04/30 07:01:27 skrll Exp $ */
2f4f0d8a3Sfredette
3*8516d557Sskrll /* $OpenBSD: endian.h,v 1.8 2004/04/07 18:24:19 mickey Exp $ */
4f4f0d8a3Sfredette
5f4f0d8a3Sfredette /*
6*8516d557Sskrll * Copyright (c) 1998-2004 Michael Shalayeff
7f4f0d8a3Sfredette * All rights reserved.
8f4f0d8a3Sfredette *
9f4f0d8a3Sfredette * Redistribution and use in source and binary forms, with or without
10f4f0d8a3Sfredette * modification, are permitted provided that the following conditions
11f4f0d8a3Sfredette * are met:
12f4f0d8a3Sfredette * 1. Redistributions of source code must retain the above copyright
13f4f0d8a3Sfredette * notice, this list of conditions and the following disclaimer.
14f4f0d8a3Sfredette * 2. Redistributions in binary form must reproduce the above copyright
15f4f0d8a3Sfredette * notice, this list of conditions and the following disclaimer in the
16f4f0d8a3Sfredette * documentation and/or other materials provided with the distribution.
17f4f0d8a3Sfredette *
18f4f0d8a3Sfredette * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19f4f0d8a3Sfredette * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20f4f0d8a3Sfredette * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21*8516d557Sskrll * IN NO EVENT SHALL THE AUTHOR OR HIS RELATIVES BE LIABLE FOR ANY DIRECT,
22*8516d557Sskrll * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
23*8516d557Sskrll * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
24*8516d557Sskrll * SERVICES; LOSS OF MIND, USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
25*8516d557Sskrll * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
26*8516d557Sskrll * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
27*8516d557Sskrll * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
28*8516d557Sskrll * THE POSSIBILITY OF SUCH DAMAGE.
29f4f0d8a3Sfredette */
30f4f0d8a3Sfredette
31f4f0d8a3Sfredette #ifndef _HPPA_BYTE_SWAP_H_
32f4f0d8a3Sfredette #define _HPPA_BYTE_SWAP_H_
33f4f0d8a3Sfredette
34c88ae1f9Sdsl #ifdef __GNUC__
35c88ae1f9Sdsl #include <sys/types.h>
36c88ae1f9Sdsl __BEGIN_DECLS
37f4f0d8a3Sfredette
38c88ae1f9Sdsl
39c88ae1f9Sdsl #define __BYTE_SWAP_U32_VARIABLE __byte_swap_u32_variable
40c88ae1f9Sdsl static __inline uint32_t __byte_swap_u32_variable(uint32_t);
41c88ae1f9Sdsl static __inline uint32_t
__byte_swap_u32_variable(uint32_t x)42c88ae1f9Sdsl __byte_swap_u32_variable(uint32_t x)
43f4f0d8a3Sfredette {
44801edd9aSdsl register uint32_t __swap32md_x; \
45f4f0d8a3Sfredette \
460c7bac06Smatt __asm ("extru %1, 7,8,%%r22\n\t" \
47f4f0d8a3Sfredette "shd %1,%1,8,%0\n\t" \
48f4f0d8a3Sfredette "dep %0,15,8,%0\n\t" \
490c7bac06Smatt "dep %%r22,31,8,%0" \
50f4f0d8a3Sfredette : "=&r" (__swap32md_x) \
510c7bac06Smatt : "r" (x) : "r22"); \
52f4f0d8a3Sfredette return(__swap32md_x);
53f4f0d8a3Sfredette }
54f4f0d8a3Sfredette
55f4f0d8a3Sfredette #if 0
56f4f0d8a3Sfredette /*
57e7b322a5Sperry * Use generic C version because w/ asm __inline below
58f4f0d8a3Sfredette * gcc inserts extra "extru r,31,16,r" to convert
59f4f0d8a3Sfredette * to 16 bit entity, which produces overhead we don't need.
60f4f0d8a3Sfredette * Besides, gcc does swap16 same way by itself.
61f4f0d8a3Sfredette */
62f4f0d8a3Sfredette #define __swap16md(x) __swap16gen(x)
63f4f0d8a3Sfredette #else
64c88ae1f9Sdsl #define __BYTE_SWAP_U16_VARIABLE __byte_swap_u16_variable
65c88ae1f9Sdsl static __inline uint16_t __byte_swap_u16_variable(uint16_t);
66c88ae1f9Sdsl static __inline uint16_t
__byte_swap_u16_variable(uint16_t x)67c88ae1f9Sdsl __byte_swap_u16_variable(uint16_t x)
68f4f0d8a3Sfredette {
69801edd9aSdsl register uint16_t __swap16md_x; \
70f4f0d8a3Sfredette \
71f4f0d8a3Sfredette __asm ("extru %1,23,8,%0\n\t" \
72f4f0d8a3Sfredette "dep %1,23,8,%0" \
73f4f0d8a3Sfredette : "=&r" (__swap16md_x) : "r" (x)); \
74f4f0d8a3Sfredette return(__swap16md_x);
75f4f0d8a3Sfredette }
76f4f0d8a3Sfredette #endif
77f4f0d8a3Sfredette
78c88ae1f9Sdsl __END_DECLS
79c88ae1f9Sdsl #endif
80c88ae1f9Sdsl
81f4f0d8a3Sfredette #endif /* !_HPPA_BYTE_SWAP_H_ */
82