blob: dc762ea786be96bdd0bfb11c05a8967903e71ff6 [file] [log] [blame]
Thomas Gleixner4f190482019-05-27 08:55:14 +02001/* SPDX-License-Identifier: GPL-2.0-only */
Linus Torvalds1da177e2005-04-16 15:20:36 -07002/*
3 * (C) 2002 - 2003 Dominik Brodowski <linux@brodo.de>
4 *
Linus Torvalds1da177e2005-04-16 15:20:36 -07005 * Library for common functions for Intel SpeedStep v.1 and v.2 support
6 *
7 * BIG FAT DISCLAIMER: Work in progress code. Possibly *dangerous*
8 */
9
10
11
12/* processors */
Rusty Russell1cce76c2009-11-17 14:39:53 -080013enum speedstep_processor {
14 SPEEDSTEP_CPU_PIII_C_EARLY = 0x00000001, /* Coppermine core */
15 SPEEDSTEP_CPU_PIII_C = 0x00000002, /* Coppermine core */
16 SPEEDSTEP_CPU_PIII_T = 0x00000003, /* Tualatin core */
17 SPEEDSTEP_CPU_P4M = 0x00000004, /* P4-M */
Linus Torvalds1da177e2005-04-16 15:20:36 -070018/* the following processors are not speedstep-capable and are not auto-detected
19 * in speedstep_detect_processor(). However, their speed can be detected using
Dave Jonesbbfebd62009-01-17 23:55:22 -050020 * the speedstep_get_frequency() call. */
Rusty Russell1cce76c2009-11-17 14:39:53 -080021 SPEEDSTEP_CPU_PM = 0xFFFFFF03, /* Pentium M */
22 SPEEDSTEP_CPU_P4D = 0xFFFFFF04, /* desktop P4 */
23 SPEEDSTEP_CPU_PCORE = 0xFFFFFF05, /* Core */
24};
Linus Torvalds1da177e2005-04-16 15:20:36 -070025
26/* speedstep states -- only two of them */
27
Dave Jones32ee8c32006-02-28 00:43:23 -050028#define SPEEDSTEP_HIGH 0x00000000
29#define SPEEDSTEP_LOW 0x00000001
Linus Torvalds1da177e2005-04-16 15:20:36 -070030
31
32/* detect a speedstep-capable processor */
Rusty Russell1cce76c2009-11-17 14:39:53 -080033extern enum speedstep_processor speedstep_detect_processor(void);
Linus Torvalds1da177e2005-04-16 15:20:36 -070034
35/* detect the current speed (in khz) of the processor */
Rusty Russell1cce76c2009-11-17 14:39:53 -080036extern unsigned int speedstep_get_frequency(enum speedstep_processor processor);
Linus Torvalds1da177e2005-04-16 15:20:36 -070037
38
Dave Jones32ee8c32006-02-28 00:43:23 -050039/* detect the low and high speeds of the processor. The callback
40 * set_state"'s first argument is either SPEEDSTEP_HIGH or
41 * SPEEDSTEP_LOW; the second argument is zero so that no
Linus Torvalds1da177e2005-04-16 15:20:36 -070042 * cpufreq_notify_transition calls are initiated.
43 */
Rusty Russell1cce76c2009-11-17 14:39:53 -080044extern unsigned int speedstep_get_freqs(enum speedstep_processor processor,
Dave Jones32ee8c32006-02-28 00:43:23 -050045 unsigned int *low_speed,
46 unsigned int *high_speed,
47 unsigned int *transition_latency,
48 void (*set_state) (unsigned int state));