mirror of
				https://github.com/smaeul/u-boot.git
				synced 2025-11-04 14:00:19 +00:00 
			
		
		
		
	include/linux/unaligned/generic.h:5:9: warning: preprocessor token __force redefined include/linux/compiler.h:10:10: this was the original definition fixup __force definitions in compat.h code appears to be placed there as a cover up from a code import from linux when u-boot didn't yet have a compiler.h, introduced by commit b1b4e89a0f3b75854c39a62cae41bad56d210adf "Add LZO decompressor support". Signed-off-by: Kim Phillips <kim.phillips@freescale.com>
		
			
				
	
	
		
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
#ifndef _LINUX_UNALIGNED_GENERIC_H
 | 
						|
#define _LINUX_UNALIGNED_GENERIC_H
 | 
						|
 | 
						|
/*
 | 
						|
 * 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 */
 |