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-only */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  2) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  3)  * Copied from arch/arm64/include/asm/hwcap.h
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  4)  *
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  5)  * Copyright (C) 2012 ARM Ltd.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  6)  * Copyright (C) 2017 SiFive
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  7)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  8) #ifndef _ASM_RISCV_HWCAP_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300  9) #define _ASM_RISCV_HWCAP_H
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 10) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 11) #include <linux/bits.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 12) #include <uapi/asm/hwcap.h>
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 13) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 14) #ifndef __ASSEMBLY__
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 15) /*
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 16)  * This yields a mask that user programs can use to figure out what
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 17)  * instruction set this cpu supports.
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 18)  */
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 19) #define ELF_HWCAP		(elf_hwcap)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 20) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 21) enum {
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 22) 	CAP_HWCAP = 1,
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 23) };
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 24) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 25) extern unsigned long elf_hwcap;
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 26) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 27) #define RISCV_ISA_EXT_a		('a' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 28) #define RISCV_ISA_EXT_c		('c' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 29) #define RISCV_ISA_EXT_d		('d' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 30) #define RISCV_ISA_EXT_f		('f' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 31) #define RISCV_ISA_EXT_h		('h' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 32) #define RISCV_ISA_EXT_i		('i' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 33) #define RISCV_ISA_EXT_m		('m' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 34) #define RISCV_ISA_EXT_s		('s' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 35) #define RISCV_ISA_EXT_u		('u' - 'a')
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 36) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 37) #define RISCV_ISA_EXT_MAX	64
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 38) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 39) unsigned long riscv_isa_extension_base(const unsigned long *isa_bitmap);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 40) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 41) #define riscv_isa_extension_mask(ext) BIT_MASK(RISCV_ISA_EXT_##ext)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 42) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 43) bool __riscv_isa_extension_available(const unsigned long *isa_bitmap, int bit);
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 44) #define riscv_isa_extension_available(isa_bitmap, ext)	\
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 45) 	__riscv_isa_extension_available(isa_bitmap, RISCV_ISA_EXT_##ext)
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 46) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 47) #endif
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 48) 
^8f3ce5b39 (kx 2023-10-28 12:00:06 +0300 49) #endif /* _ASM_RISCV_HWCAP_H */