speedstep-lib.h 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  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. /* processors */
  11. enum speedstep_processor {
  12. SPEEDSTEP_CPU_PIII_C_EARLY = 0x00000001, /* Coppermine core */
  13. SPEEDSTEP_CPU_PIII_C = 0x00000002, /* Coppermine core */
  14. SPEEDSTEP_CPU_PIII_T = 0x00000003, /* Tualatin core */
  15. SPEEDSTEP_CPU_P4M = 0x00000004, /* P4-M */
  16. /* the following processors are not speedstep-capable and are not auto-detected
  17. * in speedstep_detect_processor(). However, their speed can be detected using
  18. * the speedstep_get_frequency() call. */
  19. SPEEDSTEP_CPU_PM = 0xFFFFFF03, /* Pentium M */
  20. SPEEDSTEP_CPU_P4D = 0xFFFFFF04, /* desktop P4 */
  21. SPEEDSTEP_CPU_PCORE = 0xFFFFFF05, /* Core */
  22. };
  23. /* speedstep states -- only two of them */
  24. #define SPEEDSTEP_HIGH 0x00000000
  25. #define SPEEDSTEP_LOW 0x00000001
  26. /* detect a speedstep-capable processor */
  27. extern enum speedstep_processor speedstep_detect_processor(void);
  28. /* detect the current speed (in khz) of the processor */
  29. extern unsigned int speedstep_get_frequency(enum speedstep_processor processor);
  30. /* detect the low and high speeds of the processor. The callback
  31. * set_state"'s first argument is either SPEEDSTEP_HIGH or
  32. * SPEEDSTEP_LOW; the second argument is zero so that no
  33. * cpufreq_notify_transition calls are initiated.
  34. */
  35. extern unsigned int speedstep_get_freqs(enum speedstep_processor processor,
  36. unsigned int *low_speed,
  37. unsigned int *high_speed,
  38. unsigned int *transition_latency,
  39. void (*set_state) (unsigned int state));