| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * APIC driver for the Unisys ES7000 chipset. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | #define APIC_DEFINITION 1
 | 
					
						
							|  |  |  | #include <linux/threads.h>
 | 
					
						
							|  |  |  | #include <linux/cpumask.h>
 | 
					
						
							|  |  |  | #include <asm/mpspec.h>
 | 
					
						
							|  |  |  | #include <asm/genapic.h>
 | 
					
						
							|  |  |  | #include <asm/fixmap.h>
 | 
					
						
							|  |  |  | #include <asm/apicdef.h>
 | 
					
						
							|  |  |  | #include <linux/kernel.h>
 | 
					
						
							|  |  |  | #include <linux/string.h>
 | 
					
						
							|  |  |  | #include <linux/init.h>
 | 
					
						
							| 
									
										
										
										
											2008-07-25 02:17:33 -07:00
										 |  |  | #include <asm/es7000/apicdef.h>
 | 
					
						
							| 
									
										
										
										
											2008-07-11 18:43:10 -07:00
										 |  |  | #include <linux/smp.h>
 | 
					
						
							| 
									
										
										
										
											2008-07-25 02:17:33 -07:00
										 |  |  | #include <asm/es7000/apic.h>
 | 
					
						
							|  |  |  | #include <asm/es7000/ipi.h>
 | 
					
						
							|  |  |  | #include <asm/es7000/mpparse.h>
 | 
					
						
							|  |  |  | #include <asm/es7000/wakecpu.h>
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-11 01:52:44 +01:00
										 |  |  | static int probe_es7000(void) | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | { | 
					
						
							|  |  |  | 	/* probed later in mptable/ACPI hooks */ | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | extern void es7000_sw_apic(void); | 
					
						
							|  |  |  | static void __init enable_apic_mode(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	es7000_sw_apic(); | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static __init int mps_oem_check(struct mp_config_table *mpc, char *oem, | 
					
						
							|  |  |  | 		char *productid) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (mpc->mpc_oemptr) { | 
					
						
							|  |  |  | 		struct mp_config_oemtable *oem_table = | 
					
						
							|  |  |  | 			(struct mp_config_oemtable *)mpc->mpc_oemptr; | 
					
						
							|  |  |  | 		if (!strncmp(oem, "UNISYS", 6)) | 
					
						
							|  |  |  | 			return parse_unisys_oem((char *)oem_table); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #ifdef CONFIG_ACPI
 | 
					
						
							|  |  |  | /* Hook from generic ACPI tables.c */ | 
					
						
							|  |  |  | static int __init acpi_madt_oem_check(char *oem_id, char *oem_table_id) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2008-09-14 02:33:14 -07:00
										 |  |  | 	unsigned long oem_addr = 0; | 
					
						
							|  |  |  | 	int check_dsdt; | 
					
						
							|  |  |  | 	int ret = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* check dsdt at first to avoid clear fix_map for oem_addr */ | 
					
						
							|  |  |  | 	check_dsdt = es7000_check_dsdt(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | 	if (!find_unisys_acpi_oem_table(&oem_addr)) { | 
					
						
							| 
									
										
										
										
											2008-09-14 02:33:14 -07:00
										 |  |  | 		if (check_dsdt) | 
					
						
							|  |  |  | 			ret = parse_unisys_oem((char *)oem_addr); | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | 		else { | 
					
						
							|  |  |  | 			setup_unisys(); | 
					
						
							| 
									
										
										
										
											2008-09-14 02:33:14 -07:00
										 |  |  | 			ret = 1; | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | 		} | 
					
						
							| 
									
										
										
										
											2008-09-14 02:33:14 -07:00
										 |  |  | 		/*
 | 
					
						
							|  |  |  | 		 * we need to unmap it | 
					
						
							|  |  |  | 		 */ | 
					
						
							|  |  |  | 		unmap_unisys_acpi_oem_table(oem_addr); | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2008-09-14 02:33:14 -07:00
										 |  |  | 	return ret; | 
					
						
							| 
									
										
										
										
											2007-05-02 19:27:08 +02:00
										 |  |  | } | 
					
						
							|  |  |  | #else
 | 
					
						
							|  |  |  | static int __init acpi_madt_oem_check(char *oem_id, char *oem_table_id) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-03 00:05:10 +02:00
										 |  |  | struct genapic __initdata_refok apic_es7000 = APIC_INIT("es7000", probe_es7000); |