Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 1 | /* |
| 2 | * (C) 2002 - 2003 Dominik Brodowski <linux@brodo.de> |
| 3 | * |
| 4 | * Licensed under the terms of the GNU GPL License version 2. |
| 5 | * |
| 6 | * Library for common functions for Intel SpeedStep v.1 and v.2 support |
| 7 | * |
| 8 | * BIG FAT DISCLAIMER: Work in progress code. Possibly *dangerous* |
| 9 | */ |
| 10 | |
| 11 | |
| 12 | |
| 13 | /* processors */ |
Rusty Russell | 1cce76c | 2009-11-17 14:39:53 -0800 | [diff] [blame] | 14 | enum speedstep_processor { |
| 15 | SPEEDSTEP_CPU_PIII_C_EARLY = 0x00000001, /* Coppermine core */ |
| 16 | SPEEDSTEP_CPU_PIII_C = 0x00000002, /* Coppermine core */ |
| 17 | SPEEDSTEP_CPU_PIII_T = 0x00000003, /* Tualatin core */ |
| 18 | SPEEDSTEP_CPU_P4M = 0x00000004, /* P4-M */ |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 19 | /* the following processors are not speedstep-capable and are not auto-detected |
| 20 | * in speedstep_detect_processor(). However, their speed can be detected using |
Dave Jones | bbfebd6 | 2009-01-17 23:55:22 -0500 | [diff] [blame] | 21 | * the speedstep_get_frequency() call. */ |
Rusty Russell | 1cce76c | 2009-11-17 14:39:53 -0800 | [diff] [blame] | 22 | SPEEDSTEP_CPU_PM = 0xFFFFFF03, /* Pentium M */ |
| 23 | SPEEDSTEP_CPU_P4D = 0xFFFFFF04, /* desktop P4 */ |
| 24 | SPEEDSTEP_CPU_PCORE = 0xFFFFFF05, /* Core */ |
| 25 | }; |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | |
| 27 | /* speedstep states -- only two of them */ |
| 28 | |
Dave Jones | 32ee8c3 | 2006-02-28 00:43:23 -0500 | [diff] [blame] | 29 | #define SPEEDSTEP_HIGH 0x00000000 |
| 30 | #define SPEEDSTEP_LOW 0x00000001 |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 31 | |
| 32 | |
| 33 | /* detect a speedstep-capable processor */ |
Rusty Russell | 1cce76c | 2009-11-17 14:39:53 -0800 | [diff] [blame] | 34 | extern enum speedstep_processor speedstep_detect_processor(void); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 35 | |
| 36 | /* detect the current speed (in khz) of the processor */ |
Rusty Russell | 1cce76c | 2009-11-17 14:39:53 -0800 | [diff] [blame] | 37 | extern unsigned int speedstep_get_frequency(enum speedstep_processor processor); |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 38 | |
| 39 | |
Dave Jones | 32ee8c3 | 2006-02-28 00:43:23 -0500 | [diff] [blame] | 40 | /* detect the low and high speeds of the processor. The callback |
| 41 | * set_state"'s first argument is either SPEEDSTEP_HIGH or |
| 42 | * SPEEDSTEP_LOW; the second argument is zero so that no |
Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 43 | * cpufreq_notify_transition calls are initiated. |
| 44 | */ |
Rusty Russell | 1cce76c | 2009-11-17 14:39:53 -0800 | [diff] [blame] | 45 | extern unsigned int speedstep_get_freqs(enum speedstep_processor processor, |
Dave Jones | 32ee8c3 | 2006-02-28 00:43:23 -0500 | [diff] [blame] | 46 | unsigned int *low_speed, |
| 47 | unsigned int *high_speed, |
| 48 | unsigned int *transition_latency, |
| 49 | void (*set_state) (unsigned int state)); |