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