| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | #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>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-16 17:20:58 +09:00
										 |  |  | extern void select_idle_routine(void); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | static void __init check_bugs(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	extern unsigned long loops_per_jiffy; | 
					
						
							| 
									
										
										
										
											2006-12-11 20:28:03 +09:00
										 |  |  | 	char *p = &init_utsname()->machine[2]; /* "sh" */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-10-16 17:20:58 +09:00
										 |  |  | 	select_idle_routine(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-25 10:19:56 +09:00
										 |  |  | 	current_cpu_data.loops_per_jiffy = loops_per_jiffy; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	switch (current_cpu_data.family) { | 
					
						
							|  |  |  | 	case CPU_FAMILY_SH2: | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		*p++ = '2'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH2A: | 
					
						
							| 
									
										
										
										
											2006-11-05 16:18:08 +09:00
										 |  |  | 		*p++ = '2'; | 
					
						
							|  |  |  | 		*p++ = 'a'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH3: | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		*p++ = '3'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH4: | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		*p++ = '4'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH4A: | 
					
						
							| 
									
										
										
										
											2006-09-27 14:31:40 +09:00
										 |  |  | 		*p++ = '4'; | 
					
						
							|  |  |  | 		*p++ = 'a'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH4AL_DSP: | 
					
						
							| 
									
										
										
										
											2006-12-11 20:28:03 +09:00
										 |  |  | 		*p++ = '4'; | 
					
						
							|  |  |  | 		*p++ = 'a'; | 
					
						
							|  |  |  | 		*p++ = 'l'; | 
					
						
							|  |  |  | 		*p++ = '-'; | 
					
						
							|  |  |  | 		*p++ = 'd'; | 
					
						
							|  |  |  | 		*p++ = 's'; | 
					
						
							|  |  |  | 		*p++ = 'p'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_SH5: | 
					
						
							| 
									
										
										
										
											2007-11-22 13:11:39 +09:00
										 |  |  | 		*p++ = '6'; | 
					
						
							|  |  |  | 		*p++ = '4'; | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	case CPU_FAMILY_UNKNOWN: | 
					
						
							| 
									
										
										
										
											2007-11-22 13:11:39 +09:00
										 |  |  | 		/*
 | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 		 * Specifically use CPU_FAMILY_UNKNOWN rather than | 
					
						
							|  |  |  | 		 * default:, so we're able to have the compiler whine | 
					
						
							|  |  |  | 		 * about unhandled enumerations. | 
					
						
							| 
									
										
										
										
											2007-11-22 13:11:39 +09:00
										 |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 		break; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-12-25 10:19:56 +09:00
										 |  |  | 	printk("CPU: %s\n", get_cpu_subtype(¤t_cpu_data)); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #ifndef __LITTLE_ENDIAN__
 | 
					
						
							|  |  |  | 	/* 'eb' means 'Endian Big' */ | 
					
						
							|  |  |  | 	*p++ = 'e'; | 
					
						
							|  |  |  | 	*p++ = 'b'; | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 	*p = '\0'; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif /* __ASM_SH_BUGS_H */
 |