| 
									
										
										
										
											2009-09-24 14:11:24 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * Copyright 2009 Analog Devices Inc. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Licensed under the GPL-2 or later. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-06 14:56:30 -08:00
										 |  |  | #ifndef _BLACKFIN_SWAB_H
 | 
					
						
							|  |  |  | #define _BLACKFIN_SWAB_H
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-01-31 10:48:44 +05:30
										 |  |  | #include <linux/types.h>
 | 
					
						
							| 
									
										
										
										
											2009-06-13 11:21:51 -04:00
										 |  |  | #include <asm-generic/swab.h>
 | 
					
						
							| 
									
										
										
										
											2009-01-06 14:56:30 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifdef __GNUC__
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __inline__ __attribute_const__ __u32 __arch_swahb32(__u32 xx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__u32 tmp; | 
					
						
							|  |  |  | 	__asm__("%1 = %0 >> 8 (V);\n\t" | 
					
						
							|  |  |  | 		"%0 = %0 << 8 (V);\n\t" | 
					
						
							|  |  |  | 		"%0 = %0 | %1;\n\t" | 
					
						
							|  |  |  | 		: "+d"(xx), "=&d"(tmp)); | 
					
						
							|  |  |  | 	return xx; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #define __arch_swahb32 __arch_swahb32
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __inline__ __attribute_const__ __u32 __arch_swahw32(__u32 xx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__u32 rv; | 
					
						
							|  |  |  | 	__asm__("%0 = PACK(%1.L, %1.H);\n\t": "=d"(rv): "d"(xx)); | 
					
						
							|  |  |  | 	return rv; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #define __arch_swahw32 __arch_swahw32
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __inline__ __attribute_const__ __u32 __arch_swab32(__u32 xx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return __arch_swahb32(__arch_swahw32(xx)); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #define __arch_swab32 __arch_swab32
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __inline__ __attribute_const__ __u16 __arch_swab16(__u16 xx) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	__u32 xw = xx; | 
					
						
							|  |  |  | 	__asm__("%0 <<= 8;\n	%0.L = %0.L + %0.H (NS);\n": "+d"(xw)); | 
					
						
							|  |  |  | 	return (__u16)xw; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #define __arch_swab16 __arch_swab16
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif /* __GNUC__ */
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #endif				/* _BLACKFIN_SWAB_H */
 |