mirror of
				https://source.denx.de/u-boot/u-boot.git
				synced 2025-11-04 10:21:25 +01:00 
			
		
		
		
	This patch adds LZO decompression support to U-Boot. It is needed for the upcoming UBIFS support, since UBIFS uses LZO as default compressor/ decompressor. Since we only support read-only in UBIFS, only the decompressor is needed. All this is copied with minor changes from the current Linux kernel version (2.6.28-rc8). This patch only implements this LZO decompressor support for PPC. Other platforms using UBIFS will have to add the required "include/asm/unaligned.h" as well. It should be fairly easy to copy this from the Linux source tree as I have done it for PPC in this patch. Signed-off-by: Stefan Roese <sr@denx.de>
		
			
				
	
	
		
			72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef _LINUX_UNALIGNED_GENERIC_H
 | 
						|
#define _LINUX_UNALIGNED_GENERIC_H
 | 
						|
 | 
						|
/* define __force to nothing in U-Boot */
 | 
						|
#define __force
 | 
						|
 | 
						|
/*
 | 
						|
 * Cause a link-time error if we try an unaligned access other than
 | 
						|
 * 1,2,4 or 8 bytes long
 | 
						|
 */
 | 
						|
extern void __bad_unaligned_access_size(void);
 | 
						|
 | 
						|
#define __get_unaligned_le(ptr) ((__force typeof(*(ptr)))({			\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 1, *(ptr),			\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 2, get_unaligned_le16((ptr)),	\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 4, get_unaligned_le32((ptr)),	\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 8, get_unaligned_le64((ptr)),	\
 | 
						|
	__bad_unaligned_access_size()))));					\
 | 
						|
	}))
 | 
						|
 | 
						|
#define __get_unaligned_be(ptr) ((__force typeof(*(ptr)))({			\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 1, *(ptr),			\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 2, get_unaligned_be16((ptr)),	\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 4, get_unaligned_be32((ptr)),	\
 | 
						|
	__builtin_choose_expr(sizeof(*(ptr)) == 8, get_unaligned_be64((ptr)),	\
 | 
						|
	__bad_unaligned_access_size()))));					\
 | 
						|
	}))
 | 
						|
 | 
						|
#define __put_unaligned_le(val, ptr) ({					\
 | 
						|
	void *__gu_p = (ptr);						\
 | 
						|
	switch (sizeof(*(ptr))) {					\
 | 
						|
	case 1:								\
 | 
						|
		*(u8 *)__gu_p = (__force u8)(val);			\
 | 
						|
		break;							\
 | 
						|
	case 2:								\
 | 
						|
		put_unaligned_le16((__force u16)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	case 4:								\
 | 
						|
		put_unaligned_le32((__force u32)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	case 8:								\
 | 
						|
		put_unaligned_le64((__force u64)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	default:							\
 | 
						|
		__bad_unaligned_access_size();				\
 | 
						|
		break;							\
 | 
						|
	}								\
 | 
						|
	(void)0; })
 | 
						|
 | 
						|
#define __put_unaligned_be(val, ptr) ({					\
 | 
						|
	void *__gu_p = (ptr);						\
 | 
						|
	switch (sizeof(*(ptr))) {					\
 | 
						|
	case 1:								\
 | 
						|
		*(u8 *)__gu_p = (__force u8)(val);			\
 | 
						|
		break;							\
 | 
						|
	case 2:								\
 | 
						|
		put_unaligned_be16((__force u16)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	case 4:								\
 | 
						|
		put_unaligned_be32((__force u32)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	case 8:								\
 | 
						|
		put_unaligned_be64((__force u64)(val), __gu_p);		\
 | 
						|
		break;							\
 | 
						|
	default:							\
 | 
						|
		__bad_unaligned_access_size();				\
 | 
						|
		break;							\
 | 
						|
	}								\
 | 
						|
	(void)0; })
 | 
						|
 | 
						|
#endif /* _LINUX_UNALIGNED_GENERIC_H */
 |