| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * (C) 2002 - 2003 Dominik Brodowski <linux@brodo.de> | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Licensed under the terms of the GNU GPL License version 2. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  Library for common functions for Intel SpeedStep v.1 and v.2 support | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *  BIG FAT DISCLAIMER: Work in progress code. Possibly *dangerous* | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* processors */ | 
					
						
							| 
									
										
										
										
											2009-11-17 14:39:53 -08:00
										 |  |  | enum speedstep_processor { | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_PIII_C_EARLY = 0x00000001,  /* Coppermine core */ | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_PIII_C	   = 0x00000002,  /* Coppermine core */ | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_PIII_T	   = 0x00000003,  /* Tualatin core */ | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_P4M	   = 0x00000004,  /* P4-M  */ | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | /* the following processors are not speedstep-capable and are not auto-detected
 | 
					
						
							|  |  |  |  * in speedstep_detect_processor(). However, their speed can be detected using | 
					
						
							| 
									
										
										
										
											2009-01-17 23:55:22 -05:00
										 |  |  |  * the speedstep_get_frequency() call. */ | 
					
						
							| 
									
										
										
										
											2009-11-17 14:39:53 -08:00
										 |  |  | 	SPEEDSTEP_CPU_PM	   = 0xFFFFFF03,  /* Pentium M  */ | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_P4D	   = 0xFFFFFF04,  /* desktop P4  */ | 
					
						
							|  |  |  | 	SPEEDSTEP_CPU_PCORE	   = 0xFFFFFF05,  /* Core */ | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* speedstep states -- only two of them */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-28 00:43:23 -05:00
										 |  |  | #define SPEEDSTEP_HIGH	0x00000000
 | 
					
						
							|  |  |  | #define SPEEDSTEP_LOW	0x00000001
 | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* detect a speedstep-capable processor */ | 
					
						
							| 
									
										
										
										
											2009-11-17 14:39:53 -08:00
										 |  |  | extern enum speedstep_processor speedstep_detect_processor(void); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* detect the current speed (in khz) of the processor */ | 
					
						
							| 
									
										
										
										
											2009-11-17 14:39:53 -08:00
										 |  |  | extern unsigned int speedstep_get_frequency(enum speedstep_processor processor); | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-02-28 00:43:23 -05:00
										 |  |  | /* detect the low and high speeds of the processor. The callback
 | 
					
						
							|  |  |  |  * set_state"'s first argument is either SPEEDSTEP_HIGH or | 
					
						
							|  |  |  |  * SPEEDSTEP_LOW; the second argument is zero so that no | 
					
						
							| 
									
										
										
										
											2005-04-16 15:20:36 -07:00
										 |  |  |  * cpufreq_notify_transition calls are initiated. | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2009-11-17 14:39:53 -08:00
										 |  |  | extern unsigned int speedstep_get_freqs(enum speedstep_processor processor, | 
					
						
							| 
									
										
										
										
											2006-02-28 00:43:23 -05:00
										 |  |  | 	unsigned int *low_speed, | 
					
						
							|  |  |  | 	unsigned int *high_speed, | 
					
						
							|  |  |  | 	unsigned int *transition_latency, | 
					
						
							|  |  |  | 	void (*set_state) (unsigned int state)); |