 e82da214d2
			
		
	
	
	e82da214d2
	
	
	
		
			
			This adds a family member to struct sh_cpuinfo, which allows us to fall back more on the probe routines to work out what sort of subtype we are running on. This will be used by the CPU cache initialization code in order to first do family-level initialization, followed by subtype-level optimizations. Signed-off-by: Paul Mundt <lethal@linux-sh.org>
		
			
				
	
	
		
			73 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			73 lines
		
	
	
	
		
			1.3 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef __ASM_SH_BUGS_H
 | |
| #define __ASM_SH_BUGS_H
 | |
| 
 | |
| /*
 | |
|  * This is included by init/main.c to check for architecture-dependent bugs.
 | |
|  *
 | |
|  * Needs:
 | |
|  *	void check_bugs(void);
 | |
|  */
 | |
| 
 | |
| /*
 | |
|  * I don't know of any Super-H bugs yet.
 | |
|  */
 | |
| 
 | |
| #include <asm/processor.h>
 | |
| 
 | |
| static void __init check_bugs(void)
 | |
| {
 | |
| 	extern unsigned long loops_per_jiffy;
 | |
| 	char *p = &init_utsname()->machine[2]; /* "sh" */
 | |
| 
 | |
| 	current_cpu_data.loops_per_jiffy = loops_per_jiffy;
 | |
| 
 | |
| 	switch (current_cpu_data.family) {
 | |
| 	case CPU_FAMILY_SH2:
 | |
| 		*p++ = '2';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH2A:
 | |
| 		*p++ = '2';
 | |
| 		*p++ = 'a';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH3:
 | |
| 		*p++ = '3';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH4:
 | |
| 		*p++ = '4';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH4A:
 | |
| 		*p++ = '4';
 | |
| 		*p++ = 'a';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH4AL_DSP:
 | |
| 		*p++ = '4';
 | |
| 		*p++ = 'a';
 | |
| 		*p++ = 'l';
 | |
| 		*p++ = '-';
 | |
| 		*p++ = 'd';
 | |
| 		*p++ = 's';
 | |
| 		*p++ = 'p';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_SH5:
 | |
| 		*p++ = '6';
 | |
| 		*p++ = '4';
 | |
| 		break;
 | |
| 	case CPU_FAMILY_UNKNOWN:
 | |
| 		/*
 | |
| 		 * Specifically use CPU_FAMILY_UNKNOWN rather than
 | |
| 		 * default:, so we're able to have the compiler whine
 | |
| 		 * about unhandled enumerations.
 | |
| 		 */
 | |
| 		break;
 | |
| 	}
 | |
| 
 | |
| 	printk("CPU: %s\n", get_cpu_subtype(¤t_cpu_data));
 | |
| 
 | |
| #ifndef __LITTLE_ENDIAN__
 | |
| 	/* 'eb' means 'Endian Big' */
 | |
| 	*p++ = 'e';
 | |
| 	*p++ = 'b';
 | |
| #endif
 | |
| 	*p = '\0';
 | |
| }
 | |
| #endif /* __ASM_SH_BUGS_H */
 |