| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * arch/sh/kernel/cpu/sh2a/probe.c | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * CPU Subtype Probing for SH-2A. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  |  * Copyright (C) 2004 - 2007  Paul Mundt | 
					
						
							| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This file is subject to the terms and conditions of the GNU General Public | 
					
						
							|  |  |  |  * License.  See the file "COPYING" in the main directory of this archive | 
					
						
							|  |  |  |  * for more details. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #include <linux/init.h>
 | 
					
						
							|  |  |  | #include <asm/processor.h>
 | 
					
						
							|  |  |  | #include <asm/cache.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-06-18 17:10:12 -04:00
										 |  |  | void cpu_probe(void) | 
					
						
							| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2009-08-15 10:48:13 +09:00
										 |  |  | 	boot_cpu_data.family			= CPU_FAMILY_SH2A; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  | 	/* All SH-2A CPUs have support for 16 and 32-bit opcodes.. */ | 
					
						
							| 
									
										
										
										
											2007-09-27 18:18:39 +09:00
										 |  |  | 	boot_cpu_data.flags			|= CPU_HAS_OP32; | 
					
						
							| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2008-11-28 22:48:20 +09:00
										 |  |  | #if defined(CONFIG_CPU_SUBTYPE_SH7201)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_SH7201; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_FPU; | 
					
						
							|  |  |  | #elif defined(CONFIG_CPU_SUBTYPE_SH7203)
 | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  | 	boot_cpu_data.type			= CPU_SH7203; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_FPU; | 
					
						
							| 
									
										
										
										
											2007-11-26 19:54:02 +09:00
										 |  |  | #elif defined(CONFIG_CPU_SUBTYPE_SH7263)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_SH7263; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_FPU; | 
					
						
							| 
									
										
										
										
											2012-05-09 07:59:27 +01:00
										 |  |  | #elif defined(CONFIG_CPU_SUBTYPE_SH7264)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_SH7264; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_FPU; | 
					
						
							| 
									
										
										
										
											2012-05-10 09:26:52 +01:00
										 |  |  | #elif defined(CONFIG_CPU_SUBTYPE_SH7269)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_SH7269; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_FPU; | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  | #elif defined(CONFIG_CPU_SUBTYPE_SH7206)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_SH7206; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_DSP; | 
					
						
							| 
									
										
										
										
											2008-03-13 12:52:44 +09:00
										 |  |  | #elif defined(CONFIG_CPU_SUBTYPE_MXG)
 | 
					
						
							|  |  |  | 	boot_cpu_data.type			= CPU_MXG; | 
					
						
							|  |  |  | 	boot_cpu_data.flags			|= CPU_HAS_DSP; | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-27 18:18:39 +09:00
										 |  |  | 	boot_cpu_data.dcache.ways		= 4; | 
					
						
							| 
									
										
										
										
											2007-11-26 18:17:21 +09:00
										 |  |  | 	boot_cpu_data.dcache.way_incr		= (1 << 11); | 
					
						
							| 
									
										
										
										
											2007-09-27 18:18:39 +09:00
										 |  |  | 	boot_cpu_data.dcache.sets		= 128; | 
					
						
							|  |  |  | 	boot_cpu_data.dcache.entry_shift	= 4; | 
					
						
							|  |  |  | 	boot_cpu_data.dcache.linesz		= L1_CACHE_BYTES; | 
					
						
							|  |  |  | 	boot_cpu_data.dcache.flags		= 0; | 
					
						
							| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/*
 | 
					
						
							|  |  |  | 	 * The icache is the same as the dcache as far as this setup is | 
					
						
							|  |  |  | 	 * concerned. The only real difference in hardware is that the icache | 
					
						
							|  |  |  | 	 * lacks the U bit that the dcache has, none of this has any bearing | 
					
						
							|  |  |  | 	 * on the cache info. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2007-09-27 18:18:39 +09:00
										 |  |  | 	boot_cpu_data.icache		= boot_cpu_data.dcache; | 
					
						
							| 
									
										
										
										
											2006-11-05 15:40:13 +09:00
										 |  |  | } |