 e0ba94f14f
			
		
	
	
	e0ba94f14f
	
	
	
		
			
			For 4KB pages, x86 CPU has 2 or 1 level TLB, first level is data TLB and instruction TLB, second level is shared TLB for both data and instructions. For hupe page TLB, usually there is just one level and seperated by 2MB/4MB and 1GB. Although each levels TLB size is important for performance tuning, but for genernal and rude optimizing, last level TLB entry number is suitable. And in fact, last level TLB always has the biggest entry number. This patch will get the biggest TLB entry number and use it in furture TLB optimizing. Accroding Borislav's suggestion, except tlb_ll[i/d]_* array, other function and data will be released after system boot up. For all kinds of x86 vendor friendly, vendor specific code was moved to its specific files. Signed-off-by: Alex Shi <alex.shi@intel.com> Link: http://lkml.kernel.org/r/1340845344-27557-2-git-send-email-alex.shi@intel.com Signed-off-by: H. Peter Anvin <hpa@zytor.com>
		
			
				
	
	
		
			46 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
	
		
			1.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef ARCH_X86_CPU_H
 | |
| #define ARCH_X86_CPU_H
 | |
| 
 | |
| struct cpu_model_info {
 | |
| 	int		vendor;
 | |
| 	int		family;
 | |
| 	const char	*model_names[16];
 | |
| };
 | |
| 
 | |
| /* attempt to consolidate cpu attributes */
 | |
| struct cpu_dev {
 | |
| 	const char	*c_vendor;
 | |
| 
 | |
| 	/* some have two possibilities for cpuid string */
 | |
| 	const char	*c_ident[2];
 | |
| 
 | |
| 	struct		cpu_model_info c_models[4];
 | |
| 
 | |
| 	void            (*c_early_init)(struct cpuinfo_x86 *);
 | |
| 	void		(*c_bsp_init)(struct cpuinfo_x86 *);
 | |
| 	void		(*c_init)(struct cpuinfo_x86 *);
 | |
| 	void		(*c_identify)(struct cpuinfo_x86 *);
 | |
| 	void		(*c_detect_tlb)(struct cpuinfo_x86 *);
 | |
| 	unsigned int	(*c_size_cache)(struct cpuinfo_x86 *, unsigned int);
 | |
| 	int		c_x86_vendor;
 | |
| };
 | |
| 
 | |
| struct _tlb_table {
 | |
| 	unsigned char descriptor;
 | |
| 	char tlb_type;
 | |
| 	unsigned int entries;
 | |
| 	/* unsigned int ways; */
 | |
| 	char info[128];
 | |
| };
 | |
| 
 | |
| #define cpu_dev_register(cpu_devX) \
 | |
| 	static const struct cpu_dev *const __cpu_dev_##cpu_devX __used \
 | |
| 	__attribute__((__section__(".x86_cpu_dev.init"))) = \
 | |
| 	&cpu_devX;
 | |
| 
 | |
| extern const struct cpu_dev *const __x86_cpu_dev_start[],
 | |
| 			    *const __x86_cpu_dev_end[];
 | |
| 
 | |
| extern void get_cpu_cap(struct cpuinfo_x86 *c);
 | |
| extern void cpu_detect_cache_sizes(struct cpuinfo_x86 *c);
 | |
| #endif /* ARCH_X86_CPU_H */
 |