Orange Pi5 kernel

Deprecated Linux kernel 5.10.110 for OrangePi 5/5B/5+ boards

3 Commits   0 Branches   0 Tags
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  1) /* SPDX-License-Identifier: GPL-2.0 */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3) #ifndef _ASM_RISCV_IMAGE_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4) #define _ASM_RISCV_IMAGE_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6) #define RISCV_IMAGE_MAGIC	"RISCV\0\0\0"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7) #define RISCV_IMAGE_MAGIC2	"RSC\x05"
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9) #define RISCV_IMAGE_FLAG_BE_SHIFT	0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) #define RISCV_IMAGE_FLAG_BE_MASK	0x1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #define RISCV_IMAGE_FLAG_LE		0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) #define RISCV_IMAGE_FLAG_BE		1
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) #ifdef CONFIG_CPU_BIG_ENDIAN
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16) #error conversion of header fields to LE not yet implemented
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17) #else
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18) #define __HEAD_FLAG_BE		RISCV_IMAGE_FLAG_LE
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) #define __HEAD_FLAG(field)	(__HEAD_FLAG_##field << \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) 				RISCV_IMAGE_FLAG_##field##_SHIFT)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) #define __HEAD_FLAGS		(__HEAD_FLAG(BE))
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) #define RISCV_HEADER_VERSION_MAJOR 0
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) #define RISCV_HEADER_VERSION_MINOR 2
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) #define RISCV_HEADER_VERSION (RISCV_HEADER_VERSION_MAJOR << 16 | \
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) 			      RISCV_HEADER_VERSION_MINOR)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) #ifndef __ASSEMBLY__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) /**
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34)  * struct riscv_image_header - riscv kernel image header
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35)  * @code0:		Executable code
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36)  * @code1:		Executable code
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37)  * @text_offset:	Image load offset (little endian)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38)  * @image_size:		Effective Image size (little endian)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39)  * @flags:		kernel flags (little endian)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40)  * @version:		version
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41)  * @res1:		reserved
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42)  * @res2:		reserved
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43)  * @magic:		Magic number (RISC-V specific; deprecated)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44)  * @magic2:		Magic number 2 (to match the ARM64 'magic' field pos)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45)  * @res3:		reserved (will be used for PE COFF offset)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47)  * The intention is for this header format to be shared between multiple
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48)  * architectures to avoid a proliferation of image header formats.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 50) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 51) struct riscv_image_header {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 52) 	u32 code0;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 53) 	u32 code1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 54) 	u64 text_offset;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 55) 	u64 image_size;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 56) 	u64 flags;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 57) 	u32 version;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 58) 	u32 res1;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 59) 	u64 res2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 60) 	u64 magic;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 61) 	u32 magic2;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 62) 	u32 res3;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 63) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 64) #endif /* __ASSEMBLY__ */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 65) #endif /* _ASM_RISCV_IMAGE_H */