speedstep-lib.h 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  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. #define SPEEDSTEP_PROCESSOR_PIII_C_EARLY 0x00000001 /* Coppermine core */
  12. #define SPEEDSTEP_PROCESSOR_PIII_C 0x00000002 /* Coppermine core */
  13. #define SPEEDSTEP_PROCESSOR_PIII_T 0x00000003 /* Tualatin core */
  14. #define SPEEDSTEP_PROCESSOR_P4M 0x00000004 /* P4-M */
  15. /* the following processors are not speedstep-capable and are not auto-detected
  16. * in speedstep_detect_processor(). However, their speed can be detected using
  17. * the speedstep_get_processor_frequency() call. */
  18. #define SPEEDSTEP_PROCESSOR_PM 0xFFFFFF03 /* Pentium M */
  19. #define SPEEDSTEP_PROCESSOR_P4D 0xFFFFFF04 /* desktop P4 */
  20. /* speedstep states -- only two of them */
  21. #define SPEEDSTEP_HIGH 0x00000000
  22. #define SPEEDSTEP_LOW 0x00000001
  23. /* detect a speedstep-capable processor */
  24. extern unsigned int speedstep_detect_processor (void);
  25. /* detect the current speed (in khz) of the processor */
  26. extern unsigned int speedstep_get_processor_frequency(unsigned int processor);
  27. /* detect the low and high speeds of the processor. The callback
  28. * set_state"'s first argument is either SPEEDSTEP_HIGH or
  29. * SPEEDSTEP_LOW; the second argument is zero so that no
  30. * cpufreq_notify_transition calls are initiated.
  31. */
  32. extern unsigned int speedstep_get_freqs(unsigned int processor,
  33. unsigned int *low_speed,
  34. unsigned int *high_speed,
  35. void (*set_state) (unsigned int state));