mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 38f5bd23de
			
		
	
	
		38f5bd23de
		
			
		
	
	
	
	
		
			
			There are no standard CSR registers to provide cache information, the way for RISC-V is to get this information from DT. Currently, AT_L1I_X, AT_L1D_X and AT_L2_X are present in glibc header, and sysconf syscall could use them to get information of cache through AUX vector. The result of 'getconf -a' as follows: LEVEL1_ICACHE_SIZE 32768 LEVEL1_ICACHE_ASSOC 8 LEVEL1_ICACHE_LINESIZE 64 LEVEL1_DCACHE_SIZE 32768 LEVEL1_DCACHE_ASSOC 8 LEVEL1_DCACHE_LINESIZE 64 LEVEL2_CACHE_SIZE 2097152 LEVEL2_CACHE_ASSOC 32 LEVEL2_CACHE_LINESIZE 64 Signed-off-by: Zong Li <zong.li@sifive.com> Reviewed-by: Palmer Dabbelt <palmerdabbelt@google.com> Reviewed-by: Pekka Enberg <penberg@kernel.org> Signed-off-by: Palmer Dabbelt <palmerdabbelt@google.com>
		
			
				
	
	
		
			85 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0-or-later */
 | |
| /*
 | |
|  * Copyright (C) 2003 Matjaz Breskvar <phoenix@bsemi.com>
 | |
|  * Copyright (C) 2010-2011 Jonas Bonn <jonas@southpole.se>
 | |
|  * Copyright (C) 2012 Regents of the University of California
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_RISCV_ELF_H
 | |
| #define _ASM_RISCV_ELF_H
 | |
| 
 | |
| #include <uapi/asm/elf.h>
 | |
| #include <asm/auxvec.h>
 | |
| #include <asm/byteorder.h>
 | |
| #include <asm/cacheinfo.h>
 | |
| 
 | |
| /*
 | |
|  * These are used to set parameters in the core dumps.
 | |
|  */
 | |
| #define ELF_ARCH	EM_RISCV
 | |
| 
 | |
| #ifdef CONFIG_64BIT
 | |
| #define ELF_CLASS	ELFCLASS64
 | |
| #else
 | |
| #define ELF_CLASS	ELFCLASS32
 | |
| #endif
 | |
| 
 | |
| #define ELF_DATA	ELFDATA2LSB
 | |
| 
 | |
| /*
 | |
|  * This is used to ensure we don't load something for the wrong architecture.
 | |
|  */
 | |
| #define elf_check_arch(x) ((x)->e_machine == EM_RISCV)
 | |
| 
 | |
| #define CORE_DUMP_USE_REGSET
 | |
| #define ELF_EXEC_PAGESIZE	(PAGE_SIZE)
 | |
| 
 | |
| /*
 | |
|  * This is the location that an ET_DYN program is loaded if exec'ed.  Typical
 | |
|  * use of this is to invoke "./ld.so someprog" to test out a new version of
 | |
|  * the loader.  We need to make sure that it is out of the way of the program
 | |
|  * that it will "exec", and that there is sufficient room for the brk.
 | |
|  */
 | |
| #define ELF_ET_DYN_BASE		((TASK_SIZE / 3) * 2)
 | |
| 
 | |
| /*
 | |
|  * This yields a mask that user programs can use to figure out what
 | |
|  * instruction set this CPU supports.  This could be done in user space,
 | |
|  * but it's not easy, and we've already done it here.
 | |
|  */
 | |
| #define ELF_HWCAP	(elf_hwcap)
 | |
| extern unsigned long elf_hwcap;
 | |
| 
 | |
| /*
 | |
|  * This yields a string that ld.so will use to load implementation
 | |
|  * specific libraries for optimization.  This is more specific in
 | |
|  * intent than poking at uname or /proc/cpuinfo.
 | |
|  */
 | |
| #define ELF_PLATFORM	(NULL)
 | |
| 
 | |
| #ifdef CONFIG_MMU
 | |
| #define ARCH_DLINFO						\
 | |
| do {								\
 | |
| 	NEW_AUX_ENT(AT_SYSINFO_EHDR,				\
 | |
| 		(elf_addr_t)current->mm->context.vdso);		\
 | |
| 	NEW_AUX_ENT(AT_L1I_CACHESIZE,				\
 | |
| 		get_cache_size(1, CACHE_TYPE_INST));		\
 | |
| 	NEW_AUX_ENT(AT_L1I_CACHEGEOMETRY,			\
 | |
| 		get_cache_geometry(1, CACHE_TYPE_INST));	\
 | |
| 	NEW_AUX_ENT(AT_L1D_CACHESIZE,				\
 | |
| 		get_cache_size(1, CACHE_TYPE_DATA));		\
 | |
| 	NEW_AUX_ENT(AT_L1D_CACHEGEOMETRY,			\
 | |
| 		get_cache_geometry(1, CACHE_TYPE_DATA));	\
 | |
| 	NEW_AUX_ENT(AT_L2_CACHESIZE,				\
 | |
| 		get_cache_size(2, CACHE_TYPE_UNIFIED));		\
 | |
| 	NEW_AUX_ENT(AT_L2_CACHEGEOMETRY,			\
 | |
| 		get_cache_geometry(2, CACHE_TYPE_UNIFIED));	\
 | |
| } while (0)
 | |
| #define ARCH_HAS_SETUP_ADDITIONAL_PAGES
 | |
| struct linux_binprm;
 | |
| extern int arch_setup_additional_pages(struct linux_binprm *bprm,
 | |
| 	int uses_interp);
 | |
| #endif /* CONFIG_MMU */
 | |
| 
 | |
| #endif /* _ASM_RISCV_ELF_H */
 |