mirror of
				git://git.yoctoproject.org/linux-yocto.git
				synced 2025-10-22 23:13:01 +02:00 
			
		
		
		
	LoongArch fixes for v6.16-rc4
-----BEGIN PGP SIGNATURE----- iQJKBAABCAA0FiEEzOlt8mkP+tbeiYy5AoYrw/LiJnoFAmhecpMWHGNoZW5odWFj YWlAa2VybmVsLm9yZwAKCRAChivD8uImeuXAEACmM0dpvqSCnCMoDPy7h1vHUERa tA4un0egBEmFzgxHqzhAkirnRgOXtz2gAlQMdw1qWkbVVcBYMoSxuJ7U5QZykt6Q idP2ZglbnaNtb5PhRPQ6sUKrvr3sMOiYXdVA8GQdJu2CPVdQhdrusW6i5cZNykYt 8Gwjzx9Z9MlLRNCx6nrzEWFy5B4ANR5l4Vh7VnS+zsL7xOiJF0j7W4nz5qhClFVf KRobF9lyvrQhEoFHFRzFVN/EUrU5EtPkhmi54XpF0Q1a1yy0sQFDiFln9fPBNlvy P/jcxddN09bzsiIiABBAOfh7AsSeUSjvN2CJJFIvPera2pZEL+u0aYmw5+kLDJmn Hlp50EnMfVcxcjf+PgqXKXLZSBdl8k7ytpK9GOkmKr59sqGW82KnWqmCXRyy2Qsl 8dj0eIHB0rLhZT26ztkB/Ec2IBiZoZCZw696bTi9sQYPKayZOYhgoa8OrOgJUb91 N9wsK2kEErgHvruAhz7Lpxqx6cQd5/ZU4XSEQxdmWWZH0+DATzLz48OGav21IImw M/WjuHVZMHiiJtkrXKt4CiYs4FMV6vE9Kv0p5psdHZvrg1E03WE/sEWmn/r7PjJx foNTcNBErilMBh6GHAvcJDe5G1Fb35A/GP4y+J+qb9rH4DO4weNqoIirLb5CzhQF OM7AMehueYS7sVcPuQ== =jnb5 -----END PGP SIGNATURE----- Merge tag 'loongarch-fixes-6.16-1' of git://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson Pull LoongArch fixes from Huacai Chen: - replace __ASSEMBLY__ with __ASSEMBLER__ in headers like others - fix build warnings about export.h - reserve the EFI memory map region for kdump - handle __init vs inline mismatches - fix some KVM bugs * tag 'loongarch-fixes-6.16-1' of git://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson: LoongArch: KVM: Disable updating of "num_cpu" and "feature" LoongArch: KVM: Check validity of "num_cpu" from user space LoongArch: KVM: Check interrupt route from physical CPU LoongArch: KVM: Fix interrupt route update with EIOINTC LoongArch: KVM: Add address alignment check for IOCSR emulation LoongArch: KVM: Avoid overflow with array index LoongArch: Handle KCOV __init vs inline mismatches LoongArch: Reserve the EFI memory map region LoongArch: Fix build warnings about export.h LoongArch: Replace __ASSEMBLY__ with __ASSEMBLER__ in headers
This commit is contained in:
		
						commit
						3a3de75a68
					
				|  | @ -18,12 +18,12 @@ | |||
| /*
 | ||||
|  * This gives the physical RAM offset. | ||||
|  */ | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| #ifndef PHYS_OFFSET | ||||
| #define PHYS_OFFSET	_UL(0) | ||||
| #endif | ||||
| extern unsigned long vm_map_base; | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #ifndef IO_BASE | ||||
| #define IO_BASE			CSR_DMW0_BASE | ||||
|  | @ -66,7 +66,7 @@ extern unsigned long vm_map_base; | |||
| #define FIXADDR_TOP		((unsigned long)(long)(int)0xfffe0000) | ||||
| #endif | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define _ATYPE_ | ||||
| #define _ATYPE32_ | ||||
| #define _ATYPE64_ | ||||
|  | @ -85,7 +85,7 @@ extern unsigned long vm_map_base; | |||
| /*
 | ||||
|  *  32/64-bit LoongArch address spaces | ||||
|  */ | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define _ACAST32_ | ||||
| #define _ACAST64_ | ||||
| #else | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| #ifndef _ASM_ALTERNATIVE_ASM_H | ||||
| #define _ASM_ALTERNATIVE_ASM_H | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/asm.h> | ||||
| 
 | ||||
|  | @ -77,6 +77,6 @@ | |||
| 	.previous | ||||
| .endm | ||||
| 
 | ||||
| #endif  /*  __ASSEMBLY__  */ | ||||
| #endif  /*  __ASSEMBLER__  */ | ||||
| 
 | ||||
| #endif /* _ASM_ALTERNATIVE_ASM_H */ | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| #ifndef _ASM_ALTERNATIVE_H | ||||
| #define _ASM_ALTERNATIVE_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/types.h> | ||||
| #include <linux/stddef.h> | ||||
|  | @ -106,6 +106,6 @@ extern void apply_alternatives(struct alt_instr *start, struct alt_instr *end); | |||
| #define alternative_2(oldinstr, newinstr1, feature1, newinstr2, feature2) \ | ||||
| 	(asm volatile(ALTERNATIVE_2(oldinstr, newinstr1, feature1, newinstr2, feature2) ::: "memory")) | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_ALTERNATIVE_H */ | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| #define EX_TYPE_UACCESS_ERR_ZERO	2 | ||||
| #define EX_TYPE_BPF			3 | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| #define __ASM_EXTABLE_RAW(insn, fixup, type, data)	\ | ||||
| 	.pushsection	__ex_table, "a";		\ | ||||
|  | @ -22,7 +22,7 @@ | |||
| 	__ASM_EXTABLE_RAW(\insn, \fixup, EX_TYPE_FIXUP, 0) | ||||
| 	.endm | ||||
| 
 | ||||
| #else /* __ASSEMBLY__ */ | ||||
| #else /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #include <linux/bits.h> | ||||
| #include <linux/stringify.h> | ||||
|  | @ -60,6 +60,6 @@ | |||
| #define _ASM_EXTABLE_UACCESS_ERR(insn, fixup, err)			\ | ||||
| 	_ASM_EXTABLE_UACCESS_ERR_ZERO(insn, fixup, err, zero) | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_ASM_EXTABLE_H */ | ||||
|  |  | |||
|  | @ -110,7 +110,7 @@ | |||
| #define LONG_SRA	srai.w | ||||
| #define LONG_SRAV	sra.w | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define LONG		.word | ||||
| #endif | ||||
| #define LONGSIZE	4 | ||||
|  | @ -131,7 +131,7 @@ | |||
| #define LONG_SRA	srai.d | ||||
| #define LONG_SRAV	sra.d | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define LONG		.dword | ||||
| #endif | ||||
| #define LONGSIZE	8 | ||||
|  | @ -158,7 +158,7 @@ | |||
| 
 | ||||
| #define PTR_SCALESHIFT	2 | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define PTR		.word | ||||
| #endif | ||||
| #define PTRSIZE		4 | ||||
|  | @ -181,7 +181,7 @@ | |||
| 
 | ||||
| #define PTR_SCALESHIFT	3 | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define PTR		.dword | ||||
| #endif | ||||
| #define PTRSIZE		8 | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ | |||
| 
 | ||||
| #define PRID_PRODUCT_MASK	0x0fff | ||||
| 
 | ||||
| #if !defined(__ASSEMBLY__) | ||||
| #if !defined(__ASSEMBLER__) | ||||
| 
 | ||||
| enum cpu_type_enum { | ||||
| 	CPU_UNKNOWN, | ||||
|  | @ -55,7 +55,7 @@ enum cpu_type_enum { | |||
| 	CPU_LAST | ||||
| }; | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| /*
 | ||||
|  * ISA Level encodings | ||||
|  |  | |||
|  | @ -14,7 +14,7 @@ | |||
| 
 | ||||
| #define MCOUNT_INSN_SIZE 4		/* sizeof mcount call */ | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #ifndef CONFIG_DYNAMIC_FTRACE | ||||
| 
 | ||||
|  | @ -84,7 +84,7 @@ __arch_ftrace_set_direct_caller(struct pt_regs *regs, unsigned long addr) | |||
| 
 | ||||
| #endif | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* CONFIG_FUNCTION_TRACER */ | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| #ifndef __ASM_GPR_NUM_H | ||||
| #define __ASM_GPR_NUM_H | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| 	.equ	.L__gpr_num_zero, 0 | ||||
| 	.irp	num,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31 | ||||
|  | @ -25,7 +25,7 @@ | |||
| 	.equ	.L__gpr_num_$s\num, 23 + \num | ||||
| 	.endr | ||||
| 
 | ||||
| #else /* __ASSEMBLY__ */ | ||||
| #else /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #define __DEFINE_ASM_GPR_NUMS					\ | ||||
| "	.equ	.L__gpr_num_zero, 0\n"				\ | ||||
|  | @ -47,6 +47,6 @@ | |||
| "	.equ	.L__gpr_num_$s\\num, 23 + \\num\n"		\ | ||||
| "	.endr\n"						\ | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_GPR_NUM_H */ | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ | |||
| #ifndef _ASM_IRQFLAGS_H | ||||
| #define _ASM_IRQFLAGS_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/compiler.h> | ||||
| #include <linux/stringify.h> | ||||
|  | @ -80,6 +80,6 @@ static inline int arch_irqs_disabled(void) | |||
| 	return arch_irqs_disabled_flags(arch_local_save_flags()); | ||||
| } | ||||
| 
 | ||||
| #endif /* #ifndef __ASSEMBLY__ */ | ||||
| #endif /* #ifndef __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_IRQFLAGS_H */ | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| #ifndef __ASM_JUMP_LABEL_H | ||||
| #define __ASM_JUMP_LABEL_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/types.h> | ||||
| 
 | ||||
|  | @ -50,5 +50,5 @@ l_yes: | |||
| 	return true; | ||||
| } | ||||
| 
 | ||||
| #endif  /* __ASSEMBLY__ */ | ||||
| #endif  /* __ASSEMBLER__ */ | ||||
| #endif	/* __ASM_JUMP_LABEL_H */ | ||||
|  |  | |||
|  | @ -2,7 +2,7 @@ | |||
| #ifndef __ASM_KASAN_H | ||||
| #define __ASM_KASAN_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/linkage.h> | ||||
| #include <linux/mmzone.h> | ||||
|  |  | |||
|  | @ -9,15 +9,15 @@ | |||
| #include <linux/linkage.h> | ||||
| #include <linux/types.h> | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| #include <larchintrin.h> | ||||
| 
 | ||||
| /* CPUCFG */ | ||||
| #define read_cpucfg(reg) __cpucfg(reg) | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| /* LoongArch Registers */ | ||||
| #define REG_ZERO	0x0 | ||||
|  | @ -53,7 +53,7 @@ | |||
| #define REG_S7		0x1e | ||||
| #define REG_S8		0x1f | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| /* Bit fields for CPUCFG registers */ | ||||
| #define LOONGARCH_CPUCFG0		0x0 | ||||
|  | @ -171,7 +171,7 @@ | |||
|  * SW emulation for KVM hypervirsor, see arch/loongarch/include/uapi/asm/kvm_para.h | ||||
|  */ | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| /* CSR */ | ||||
| #define csr_read32(reg) __csrrd_w(reg) | ||||
|  | @ -187,7 +187,7 @@ | |||
| #define iocsr_write32(val, reg) __iocsrwr_w(val, reg) | ||||
| #define iocsr_write64(val, reg) __iocsrwr_d(val, reg) | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| /* CSR register number */ | ||||
| 
 | ||||
|  | @ -1195,7 +1195,7 @@ | |||
| #define LOONGARCH_IOCSR_EXTIOI_ROUTE_BASE	0x1c00 | ||||
| #define IOCSR_EXTIOI_VECTOR_NUM			256 | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| static __always_inline u64 drdtime(void) | ||||
| { | ||||
|  | @ -1357,7 +1357,7 @@ __BUILD_CSR_OP(tlbidx) | |||
| #define clear_csr_estat(val)	\ | ||||
| 	csr_xchg32(~(val), val, LOONGARCH_CSR_ESTAT) | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| /* Generic EntryLo bit definitions */ | ||||
| #define ENTRYLO_V		(_ULCAST_(1) << 0) | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ | |||
| #define ORC_TYPE_REGS			3 | ||||
| #define ORC_TYPE_REGS_PARTIAL		4 | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| /*
 | ||||
|  * This struct is more or less a vastly simplified version of the DWARF Call | ||||
|  * Frame Information standard.  It contains only the necessary parts of DWARF | ||||
|  | @ -53,6 +53,6 @@ struct orc_entry { | |||
| 	unsigned int	type:3; | ||||
| 	unsigned int	signal:1; | ||||
| }; | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ORC_TYPES_H */ | ||||
|  |  | |||
|  | @ -15,7 +15,7 @@ | |||
| #define HPAGE_MASK	(~(HPAGE_SIZE - 1)) | ||||
| #define HUGETLB_PAGE_ORDER	(HPAGE_SHIFT - PAGE_SHIFT) | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/pfn.h> | ||||
|  | @ -110,6 +110,6 @@ extern int __virt_addr_valid(volatile void *kaddr); | |||
| #include <asm-generic/memory_model.h> | ||||
| #include <asm-generic/getorder.h> | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_PAGE_H */ | ||||
|  |  | |||
|  | @ -92,7 +92,7 @@ | |||
| #define PAGE_KERNEL_WUC __pgprot(_PAGE_PRESENT | __READABLE | __WRITEABLE | \ | ||||
| 				 _PAGE_GLOBAL | _PAGE_KERN |  _CACHE_WUC) | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #define _PAGE_IOREMAP		pgprot_val(PAGE_KERNEL_SUC) | ||||
| 
 | ||||
|  | @ -127,6 +127,6 @@ static inline pgprot_t pgprot_writecombine(pgprot_t _prot) | |||
| 	return __pgprot(prot); | ||||
| } | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_PGTABLE_BITS_H */ | ||||
|  |  | |||
|  | @ -55,7 +55,7 @@ | |||
| 
 | ||||
| #define USER_PTRS_PER_PGD       ((TASK_SIZE64 / PGDIR_SIZE)?(TASK_SIZE64 / PGDIR_SIZE):1) | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <linux/mm_types.h> | ||||
| #include <linux/mmzone.h> | ||||
|  | @ -618,6 +618,6 @@ static inline long pmd_protnone(pmd_t pmd) | |||
| #define HAVE_ARCH_UNMAPPED_AREA | ||||
| #define HAVE_ARCH_UNMAPPED_AREA_TOPDOWN | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_PGTABLE_H */ | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ | |||
| #define Pref_Load	0 | ||||
| #define Pref_Store	8 | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| 	.macro	__pref hint addr | ||||
| #ifdef CONFIG_CPU_HAS_PREFETCH | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ int loongson_cpu_disable(void); | |||
| void loongson_cpu_die(unsigned int cpu); | ||||
| #endif | ||||
| 
 | ||||
| static inline void plat_smp_setup(void) | ||||
| static inline void __init plat_smp_setup(void) | ||||
| { | ||||
| 	loongson_smp_setup(); | ||||
| } | ||||
|  |  | |||
|  | @ -10,7 +10,7 @@ | |||
| 
 | ||||
| #ifdef __KERNEL__ | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/processor.h> | ||||
| 
 | ||||
|  | @ -53,7 +53,7 @@ static inline struct thread_info *current_thread_info(void) | |||
| 
 | ||||
| register unsigned long current_stack_pointer __asm__("$sp"); | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| /* thread information allocation */ | ||||
| #define THREAD_SIZE		SZ_16K | ||||
|  |  | |||
|  | @ -8,7 +8,7 @@ | |||
| #include <asm-generic/int-ll64.h> | ||||
| #include <uapi/asm/types.h> | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| #define _ULCAST_ | ||||
| #define _U64CAST_ | ||||
| #else | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ | |||
| #include <linux/objtool.h> | ||||
| #include <asm/orc_types.h> | ||||
| 
 | ||||
| #ifdef __ASSEMBLY__ | ||||
| #ifdef __ASSEMBLER__ | ||||
| 
 | ||||
| .macro UNWIND_HINT_UNDEFINED | ||||
| 	UNWIND_HINT type=UNWIND_HINT_TYPE_UNDEFINED | ||||
|  | @ -23,7 +23,7 @@ | |||
| 	UNWIND_HINT sp_reg=ORC_REG_SP type=UNWIND_HINT_TYPE_CALL | ||||
| .endm | ||||
| 
 | ||||
| #else /* !__ASSEMBLY__ */ | ||||
| #else /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #define UNWIND_HINT_SAVE \ | ||||
| 	UNWIND_HINT(UNWIND_HINT_TYPE_SAVE, 0, 0, 0) | ||||
|  | @ -31,6 +31,6 @@ | |||
| #define UNWIND_HINT_RESTORE \ | ||||
| 	UNWIND_HINT(UNWIND_HINT_TYPE_RESTORE, 0, 0, 0) | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ASM_LOONGARCH_UNWIND_HINTS_H */ | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| #ifndef _VDSO_ARCH_DATA_H | ||||
| #define _VDSO_ARCH_DATA_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/asm.h> | ||||
| #include <asm/vdso.h> | ||||
|  | @ -20,6 +20,6 @@ struct vdso_arch_data { | |||
| 	struct vdso_pcpu_data pdata[NR_CPUS]; | ||||
| }; | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -5,7 +5,7 @@ | |||
| #ifndef __ASM_VDSO_GETRANDOM_H | ||||
| #define __ASM_VDSO_GETRANDOM_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/unistd.h> | ||||
| #include <asm/vdso/vdso.h> | ||||
|  | @ -28,6 +28,6 @@ static __always_inline ssize_t getrandom_syscall(void *_buffer, size_t _len, uns | |||
| 	return ret; | ||||
| } | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_VDSO_GETRANDOM_H */ | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| #ifndef __ASM_VDSO_GETTIMEOFDAY_H | ||||
| #define __ASM_VDSO_GETTIMEOFDAY_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/unistd.h> | ||||
| #include <asm/vdso/vdso.h> | ||||
|  | @ -89,6 +89,6 @@ static inline bool loongarch_vdso_hres_capable(void) | |||
| } | ||||
| #define __arch_vdso_hres_capable loongarch_vdso_hres_capable | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_VDSO_GETTIMEOFDAY_H */ | ||||
|  |  | |||
|  | @ -5,10 +5,10 @@ | |||
| #ifndef __ASM_VDSO_PROCESSOR_H | ||||
| #define __ASM_VDSO_PROCESSOR_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #define cpu_relax()	barrier() | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_VDSO_PROCESSOR_H */ | ||||
|  |  | |||
|  | @ -7,7 +7,7 @@ | |||
| #ifndef _ASM_VDSO_VDSO_H | ||||
| #define _ASM_VDSO_VDSO_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <asm/asm.h> | ||||
| #include <asm/page.h> | ||||
|  | @ -16,6 +16,6 @@ | |||
| 
 | ||||
| #define VVAR_SIZE (VDSO_NR_PAGES << PAGE_SHIFT) | ||||
| 
 | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif | ||||
|  |  | |||
|  | @ -2,13 +2,13 @@ | |||
| #ifndef __ASM_VDSO_VSYSCALL_H | ||||
| #define __ASM_VDSO_VSYSCALL_H | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| 
 | ||||
| #include <vdso/datapage.h> | ||||
| 
 | ||||
| /* The asm-generic header needs to be included after the definitions above */ | ||||
| #include <asm-generic/vdso/vsyscall.h> | ||||
| 
 | ||||
| #endif /* !__ASSEMBLY__ */ | ||||
| #endif /* !__ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* __ASM_VDSO_VSYSCALL_H */ | ||||
|  |  | |||
|  | @ -10,6 +10,7 @@ | |||
| #include <linux/init.h> | ||||
| #include <linux/acpi.h> | ||||
| #include <linux/efi-bgrt.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/irq.h> | ||||
| #include <linux/irqdomain.h> | ||||
| #include <linux/memblock.h> | ||||
|  |  | |||
|  | @ -1,4 +1,5 @@ | |||
| // SPDX-License-Identifier: GPL-2.0-only
 | ||||
| #include <linux/export.h> | ||||
| #include <linux/mm.h> | ||||
| #include <linux/module.h> | ||||
| #include <asm/alternative.h> | ||||
|  |  | |||
|  | @ -144,6 +144,18 @@ void __init efi_init(void) | |||
| 		if (efi_memmap_init_early(&data) < 0) | ||||
| 			panic("Unable to map EFI memory map.\n"); | ||||
| 
 | ||||
| 		/*
 | ||||
| 		 * Reserve the physical memory region occupied by the EFI | ||||
| 		 * memory map table (header + descriptors). This is crucial | ||||
| 		 * for kdump, as the kdump kernel relies on this original | ||||
| 		 * memmap passed by the bootloader. Without reservation, | ||||
| 		 * this region could be overwritten by the primary kernel. | ||||
| 		 * Also, set the EFI_PRESERVE_BS_REGIONS flag to indicate that | ||||
| 		 * critical boot services code/data regions like this are preserved. | ||||
| 		 */ | ||||
| 		memblock_reserve((phys_addr_t)boot_memmap, sizeof(*tbl) + data.size); | ||||
| 		set_bit(EFI_PRESERVE_BS_REGIONS, &efi.flags); | ||||
| 
 | ||||
| 		early_memunmap(tbl, sizeof(*tbl)); | ||||
| 	} | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,6 @@ | |||
| 
 | ||||
| #include <linux/binfmts.h> | ||||
| #include <linux/elf.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/sched.h> | ||||
| 
 | ||||
| #include <asm/cpu-features.h> | ||||
|  |  | |||
|  | @ -4,6 +4,7 @@ | |||
|  */ | ||||
| 
 | ||||
| #include <linux/cpu.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/init.h> | ||||
| #include <asm/fpu.h> | ||||
| #include <asm/smp.h> | ||||
|  |  | |||
|  | @ -1,5 +1,4 @@ | |||
| // SPDX-License-Identifier: GPL-2.0
 | ||||
| #include <linux/export.h> | ||||
| #include <linux/types.h> | ||||
| #include <linux/interrupt.h> | ||||
| #include <linux/irq_work.h> | ||||
|  |  | |||
|  | @ -102,7 +102,7 @@ static int constant_timer_next_event(unsigned long delta, struct clock_event_dev | |||
| 	return 0; | ||||
| } | ||||
| 
 | ||||
| static unsigned long __init get_loops_per_jiffy(void) | ||||
| static unsigned long get_loops_per_jiffy(void) | ||||
| { | ||||
| 	unsigned long lpj = (unsigned long)const_clock_freq; | ||||
| 
 | ||||
|  |  | |||
|  | @ -13,6 +13,7 @@ | |||
| #include <linux/kernel.h> | ||||
| #include <linux/kexec.h> | ||||
| #include <linux/module.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/extable.h> | ||||
| #include <linux/mm.h> | ||||
| #include <linux/sched/mm.h> | ||||
|  |  | |||
|  | @ -3,6 +3,7 @@ | |||
|  * Copyright (C) 2022 Loongson Technology Corporation Limited | ||||
|  */ | ||||
| #include <asm/unwind.h> | ||||
| #include <linux/export.h> | ||||
| 
 | ||||
| unsigned long unwind_get_return_address(struct unwind_state *state) | ||||
| { | ||||
|  |  | |||
|  | @ -1,6 +1,7 @@ | |||
| // SPDX-License-Identifier: GPL-2.0-only
 | ||||
| #include <linux/objtool.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/module.h> | ||||
| #include <linux/objtool.h> | ||||
| #include <linux/sort.h> | ||||
| #include <asm/exception.h> | ||||
| #include <asm/orc_header.h> | ||||
|  |  | |||
|  | @ -3,6 +3,7 @@ | |||
|  * Copyright (C) 2022 Loongson Technology Corporation Limited | ||||
|  */ | ||||
| #include <linux/cpumask.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/ftrace.h> | ||||
| #include <linux/kallsyms.h> | ||||
| 
 | ||||
|  |  | |||
|  | @ -9,7 +9,8 @@ | |||
| 
 | ||||
| static void eiointc_set_sw_coreisr(struct loongarch_eiointc *s) | ||||
| { | ||||
| 	int ipnum, cpu, irq_index, irq_mask, irq; | ||||
| 	int ipnum, cpu, cpuid, irq_index, irq_mask, irq; | ||||
| 	struct kvm_vcpu *vcpu; | ||||
| 
 | ||||
| 	for (irq = 0; irq < EIOINTC_IRQS; irq++) { | ||||
| 		ipnum = s->ipmap.reg_u8[irq / 32]; | ||||
|  | @ -20,7 +21,12 @@ static void eiointc_set_sw_coreisr(struct loongarch_eiointc *s) | |||
| 		irq_index = irq / 32; | ||||
| 		irq_mask = BIT(irq & 0x1f); | ||||
| 
 | ||||
| 		cpu = s->coremap.reg_u8[irq]; | ||||
| 		cpuid = s->coremap.reg_u8[irq]; | ||||
| 		vcpu = kvm_get_vcpu_by_cpuid(s->kvm, cpuid); | ||||
| 		if (!vcpu) | ||||
| 			continue; | ||||
| 
 | ||||
| 		cpu = vcpu->vcpu_id; | ||||
| 		if (!!(s->coreisr.reg_u32[cpu][irq_index] & irq_mask)) | ||||
| 			set_bit(irq, s->sw_coreisr[cpu][ipnum]); | ||||
| 		else | ||||
|  | @ -66,20 +72,25 @@ static void eiointc_update_irq(struct loongarch_eiointc *s, int irq, int level) | |||
| } | ||||
| 
 | ||||
| static inline void eiointc_update_sw_coremap(struct loongarch_eiointc *s, | ||||
| 					int irq, void *pvalue, u32 len, bool notify) | ||||
| 					int irq, u64 val, u32 len, bool notify) | ||||
| { | ||||
| 	int i, cpu; | ||||
| 	u64 val = *(u64 *)pvalue; | ||||
| 	int i, cpu, cpuid; | ||||
| 	struct kvm_vcpu *vcpu; | ||||
| 
 | ||||
| 	for (i = 0; i < len; i++) { | ||||
| 		cpu = val & 0xff; | ||||
| 		cpuid = val & 0xff; | ||||
| 		val = val >> 8; | ||||
| 
 | ||||
| 		if (!(s->status & BIT(EIOINTC_ENABLE_CPU_ENCODE))) { | ||||
| 			cpu = ffs(cpu) - 1; | ||||
| 			cpu = (cpu >= 4) ? 0 : cpu; | ||||
| 			cpuid = ffs(cpuid) - 1; | ||||
| 			cpuid = (cpuid >= 4) ? 0 : cpuid; | ||||
| 		} | ||||
| 
 | ||||
| 		vcpu = kvm_get_vcpu_by_cpuid(s->kvm, cpuid); | ||||
| 		if (!vcpu) | ||||
| 			continue; | ||||
| 
 | ||||
| 		cpu = vcpu->vcpu_id; | ||||
| 		if (s->sw_coremap[irq + i] == cpu) | ||||
| 			continue; | ||||
| 
 | ||||
|  | @ -305,6 +316,11 @@ static int kvm_eiointc_read(struct kvm_vcpu *vcpu, | |||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	if (addr & (len - 1)) { | ||||
| 		kvm_err("%s: eiointc not aligned addr %llx len %d\n", __func__, addr, len); | ||||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	vcpu->kvm->stat.eiointc_read_exits++; | ||||
| 	spin_lock_irqsave(&eiointc->lock, flags); | ||||
| 	switch (len) { | ||||
|  | @ -398,7 +414,7 @@ static int loongarch_eiointc_writeb(struct kvm_vcpu *vcpu, | |||
| 		irq = offset - EIOINTC_COREMAP_START; | ||||
| 		index = irq; | ||||
| 		s->coremap.reg_u8[index] = data; | ||||
| 		eiointc_update_sw_coremap(s, irq, (void *)&data, sizeof(data), true); | ||||
| 		eiointc_update_sw_coremap(s, irq, data, sizeof(data), true); | ||||
| 		break; | ||||
| 	default: | ||||
| 		ret = -EINVAL; | ||||
|  | @ -436,17 +452,16 @@ static int loongarch_eiointc_writew(struct kvm_vcpu *vcpu, | |||
| 		break; | ||||
| 	case EIOINTC_ENABLE_START ... EIOINTC_ENABLE_END: | ||||
| 		index = (offset - EIOINTC_ENABLE_START) >> 1; | ||||
| 		old_data = s->enable.reg_u32[index]; | ||||
| 		old_data = s->enable.reg_u16[index]; | ||||
| 		s->enable.reg_u16[index] = data; | ||||
| 		/*
 | ||||
| 		 * 1: enable irq. | ||||
| 		 * update irq when isr is set. | ||||
| 		 */ | ||||
| 		data = s->enable.reg_u16[index] & ~old_data & s->isr.reg_u16[index]; | ||||
| 		index = index << 1; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index + i, mask, 1); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 2 + i, mask, 1); | ||||
| 		} | ||||
| 		/*
 | ||||
| 		 * 0: disable irq. | ||||
|  | @ -455,7 +470,7 @@ static int loongarch_eiointc_writew(struct kvm_vcpu *vcpu, | |||
| 		data = ~s->enable.reg_u16[index] & old_data & s->isr.reg_u16[index]; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index, mask, 0); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 2 + i, mask, 0); | ||||
| 		} | ||||
| 		break; | ||||
| 	case EIOINTC_BOUNCE_START ... EIOINTC_BOUNCE_END: | ||||
|  | @ -484,7 +499,7 @@ static int loongarch_eiointc_writew(struct kvm_vcpu *vcpu, | |||
| 		irq = offset - EIOINTC_COREMAP_START; | ||||
| 		index = irq >> 1; | ||||
| 		s->coremap.reg_u16[index] = data; | ||||
| 		eiointc_update_sw_coremap(s, irq, (void *)&data, sizeof(data), true); | ||||
| 		eiointc_update_sw_coremap(s, irq, data, sizeof(data), true); | ||||
| 		break; | ||||
| 	default: | ||||
| 		ret = -EINVAL; | ||||
|  | @ -529,10 +544,9 @@ static int loongarch_eiointc_writel(struct kvm_vcpu *vcpu, | |||
| 		 * update irq when isr is set. | ||||
| 		 */ | ||||
| 		data = s->enable.reg_u32[index] & ~old_data & s->isr.reg_u32[index]; | ||||
| 		index = index << 2; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index + i, mask, 1); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 4 + i, mask, 1); | ||||
| 		} | ||||
| 		/*
 | ||||
| 		 * 0: disable irq. | ||||
|  | @ -541,7 +555,7 @@ static int loongarch_eiointc_writel(struct kvm_vcpu *vcpu, | |||
| 		data = ~s->enable.reg_u32[index] & old_data & s->isr.reg_u32[index]; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index, mask, 0); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 4 + i, mask, 0); | ||||
| 		} | ||||
| 		break; | ||||
| 	case EIOINTC_BOUNCE_START ... EIOINTC_BOUNCE_END: | ||||
|  | @ -570,7 +584,7 @@ static int loongarch_eiointc_writel(struct kvm_vcpu *vcpu, | |||
| 		irq = offset - EIOINTC_COREMAP_START; | ||||
| 		index = irq >> 2; | ||||
| 		s->coremap.reg_u32[index] = data; | ||||
| 		eiointc_update_sw_coremap(s, irq, (void *)&data, sizeof(data), true); | ||||
| 		eiointc_update_sw_coremap(s, irq, data, sizeof(data), true); | ||||
| 		break; | ||||
| 	default: | ||||
| 		ret = -EINVAL; | ||||
|  | @ -615,10 +629,9 @@ static int loongarch_eiointc_writeq(struct kvm_vcpu *vcpu, | |||
| 		 * update irq when isr is set. | ||||
| 		 */ | ||||
| 		data = s->enable.reg_u64[index] & ~old_data & s->isr.reg_u64[index]; | ||||
| 		index = index << 3; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index + i, mask, 1); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 8 + i, mask, 1); | ||||
| 		} | ||||
| 		/*
 | ||||
| 		 * 0: disable irq. | ||||
|  | @ -627,7 +640,7 @@ static int loongarch_eiointc_writeq(struct kvm_vcpu *vcpu, | |||
| 		data = ~s->enable.reg_u64[index] & old_data & s->isr.reg_u64[index]; | ||||
| 		for (i = 0; i < sizeof(data); i++) { | ||||
| 			u8 mask = (data >> (i * 8)) & 0xff; | ||||
| 			eiointc_enable_irq(vcpu, s, index, mask, 0); | ||||
| 			eiointc_enable_irq(vcpu, s, index * 8 + i, mask, 0); | ||||
| 		} | ||||
| 		break; | ||||
| 	case EIOINTC_BOUNCE_START ... EIOINTC_BOUNCE_END: | ||||
|  | @ -656,7 +669,7 @@ static int loongarch_eiointc_writeq(struct kvm_vcpu *vcpu, | |||
| 		irq = offset - EIOINTC_COREMAP_START; | ||||
| 		index = irq >> 3; | ||||
| 		s->coremap.reg_u64[index] = data; | ||||
| 		eiointc_update_sw_coremap(s, irq, (void *)&data, sizeof(data), true); | ||||
| 		eiointc_update_sw_coremap(s, irq, data, sizeof(data), true); | ||||
| 		break; | ||||
| 	default: | ||||
| 		ret = -EINVAL; | ||||
|  | @ -679,6 +692,11 @@ static int kvm_eiointc_write(struct kvm_vcpu *vcpu, | |||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	if (addr & (len - 1)) { | ||||
| 		kvm_err("%s: eiointc not aligned addr %llx len %d\n", __func__, addr, len); | ||||
| 		return -EINVAL; | ||||
| 	} | ||||
| 
 | ||||
| 	vcpu->kvm->stat.eiointc_write_exits++; | ||||
| 	spin_lock_irqsave(&eiointc->lock, flags); | ||||
| 	switch (len) { | ||||
|  | @ -787,7 +805,7 @@ static int kvm_eiointc_ctrl_access(struct kvm_device *dev, | |||
| 	int ret = 0; | ||||
| 	unsigned long flags; | ||||
| 	unsigned long type = (unsigned long)attr->attr; | ||||
| 	u32 i, start_irq; | ||||
| 	u32 i, start_irq, val; | ||||
| 	void __user *data; | ||||
| 	struct loongarch_eiointc *s = dev->kvm->arch.eiointc; | ||||
| 
 | ||||
|  | @ -795,8 +813,14 @@ static int kvm_eiointc_ctrl_access(struct kvm_device *dev, | |||
| 	spin_lock_irqsave(&s->lock, flags); | ||||
| 	switch (type) { | ||||
| 	case KVM_DEV_LOONGARCH_EXTIOI_CTRL_INIT_NUM_CPU: | ||||
| 		if (copy_from_user(&s->num_cpu, data, 4)) | ||||
| 		if (copy_from_user(&val, data, 4)) | ||||
| 			ret = -EFAULT; | ||||
| 		else { | ||||
| 			if (val >= EIOINTC_ROUTE_MAX_VCPUS) | ||||
| 				ret = -EINVAL; | ||||
| 			else | ||||
| 				s->num_cpu = val; | ||||
| 		} | ||||
| 		break; | ||||
| 	case KVM_DEV_LOONGARCH_EXTIOI_CTRL_INIT_FEATURE: | ||||
| 		if (copy_from_user(&s->features, data, 4)) | ||||
|  | @ -809,7 +833,7 @@ static int kvm_eiointc_ctrl_access(struct kvm_device *dev, | |||
| 		for (i = 0; i < (EIOINTC_IRQS / 4); i++) { | ||||
| 			start_irq = i * 4; | ||||
| 			eiointc_update_sw_coremap(s, start_irq, | ||||
| 					(void *)&s->coremap.reg_u32[i], sizeof(u32), false); | ||||
| 					s->coremap.reg_u32[i], sizeof(u32), false); | ||||
| 		} | ||||
| 		break; | ||||
| 	default: | ||||
|  | @ -824,7 +848,7 @@ static int kvm_eiointc_regs_access(struct kvm_device *dev, | |||
| 					struct kvm_device_attr *attr, | ||||
| 					bool is_write) | ||||
| { | ||||
| 	int addr, cpuid, offset, ret = 0; | ||||
| 	int addr, cpu, offset, ret = 0; | ||||
| 	unsigned long flags; | ||||
| 	void *p = NULL; | ||||
| 	void __user *data; | ||||
|  | @ -832,7 +856,7 @@ static int kvm_eiointc_regs_access(struct kvm_device *dev, | |||
| 
 | ||||
| 	s = dev->kvm->arch.eiointc; | ||||
| 	addr = attr->attr; | ||||
| 	cpuid = addr >> 16; | ||||
| 	cpu = addr >> 16; | ||||
| 	addr &= 0xffff; | ||||
| 	data = (void __user *)attr->addr; | ||||
| 	switch (addr) { | ||||
|  | @ -857,8 +881,11 @@ static int kvm_eiointc_regs_access(struct kvm_device *dev, | |||
| 		p = &s->isr.reg_u32[offset]; | ||||
| 		break; | ||||
| 	case EIOINTC_COREISR_START ... EIOINTC_COREISR_END: | ||||
| 		if (cpu >= s->num_cpu) | ||||
| 			return -EINVAL; | ||||
| 
 | ||||
| 		offset = (addr - EIOINTC_COREISR_START) / 4; | ||||
| 		p = &s->coreisr.reg_u32[cpuid][offset]; | ||||
| 		p = &s->coreisr.reg_u32[cpu][offset]; | ||||
| 		break; | ||||
| 	case EIOINTC_COREMAP_START ... EIOINTC_COREMAP_END: | ||||
| 		offset = (addr - EIOINTC_COREMAP_START) / 4; | ||||
|  | @ -899,9 +926,15 @@ static int kvm_eiointc_sw_status_access(struct kvm_device *dev, | |||
| 	data = (void __user *)attr->addr; | ||||
| 	switch (addr) { | ||||
| 	case KVM_DEV_LOONGARCH_EXTIOI_SW_STATUS_NUM_CPU: | ||||
| 		if (is_write) | ||||
| 			return ret; | ||||
| 
 | ||||
| 		p = &s->num_cpu; | ||||
| 		break; | ||||
| 	case KVM_DEV_LOONGARCH_EXTIOI_SW_STATUS_FEATURE: | ||||
| 		if (is_write) | ||||
| 			return ret; | ||||
| 
 | ||||
| 		p = &s->features; | ||||
| 		break; | ||||
| 	case KVM_DEV_LOONGARCH_EXTIOI_SW_STATUS_STATE: | ||||
|  |  | |||
|  | @ -11,6 +11,7 @@ | |||
| 
 | ||||
| #include <asm/cpu-features.h> | ||||
| #include <linux/crc32.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/module.h> | ||||
| #include <linux/unaligned.h> | ||||
| 
 | ||||
|  |  | |||
|  | @ -2,6 +2,7 @@ | |||
| // Copyright (C) 2019-2020 Arm Ltd.
 | ||||
| 
 | ||||
| #include <linux/compiler.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/kasan-checks.h> | ||||
| #include <linux/kernel.h> | ||||
| 
 | ||||
|  |  | |||
|  | @ -16,12 +16,12 @@ void __init early_iounmap(void __iomem *addr, unsigned long size) | |||
| 
 | ||||
| } | ||||
| 
 | ||||
| void *early_memremap_ro(resource_size_t phys_addr, unsigned long size) | ||||
| void * __init early_memremap_ro(resource_size_t phys_addr, unsigned long size) | ||||
| { | ||||
| 	return early_memremap(phys_addr, size); | ||||
| } | ||||
| 
 | ||||
| void *early_memremap_prot(resource_size_t phys_addr, unsigned long size, | ||||
| void * __init early_memremap_prot(resource_size_t phys_addr, unsigned long size, | ||||
| 		    unsigned long prot_val) | ||||
| { | ||||
| 	return early_memremap(phys_addr, size); | ||||
|  |  | |||
|  | @ -3,7 +3,6 @@ | |||
|  * Copyright (C) 2020-2022 Loongson Technology Corporation Limited | ||||
|  */ | ||||
| #include <linux/kernel.h> | ||||
| #include <linux/export.h> | ||||
| #include <linux/init.h> | ||||
| #include <linux/acpi.h> | ||||
| #include <linux/types.h> | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ | |||
| #define ORC_TYPE_REGS			3 | ||||
| #define ORC_TYPE_REGS_PARTIAL		4 | ||||
| 
 | ||||
| #ifndef __ASSEMBLY__ | ||||
| #ifndef __ASSEMBLER__ | ||||
| /*
 | ||||
|  * This struct is more or less a vastly simplified version of the DWARF Call | ||||
|  * Frame Information standard.  It contains only the necessary parts of DWARF | ||||
|  | @ -53,6 +53,6 @@ struct orc_entry { | |||
| 	unsigned int	type:3; | ||||
| 	unsigned int	signal:1; | ||||
| }; | ||||
| #endif /* __ASSEMBLY__ */ | ||||
| #endif /* __ASSEMBLER__ */ | ||||
| 
 | ||||
| #endif /* _ORC_TYPES_H */ | ||||
|  |  | |||
		Loading…
	
		Reference in New Issue
	
	Block a user
	 Linus Torvalds
						Linus Torvalds