thermal_core.h 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. /*
  2. * thermal_core.h
  3. *
  4. * Copyright (C) 2012 Intel Corp
  5. * Author: Durgadoss R <durgadoss.r@intel.com>
  6. *
  7. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  8. * This program is free software; you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation; version 2 of the License.
  11. *
  12. * This program is distributed in the hope that it will be useful, but
  13. * WITHOUT ANY WARRANTY; without even the implied warranty of
  14. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  15. * General Public License for more details.
  16. *
  17. * You should have received a copy of the GNU General Public License along
  18. * with this program; if not, write to the Free Software Foundation, Inc.,
  19. * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
  20. *
  21. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  22. */
  23. #ifndef __THERMAL_CORE_H__
  24. #define __THERMAL_CORE_H__
  25. #include <linux/device.h>
  26. #include <linux/thermal.h>
  27. /* Initial state of a cooling device during binding */
  28. #define THERMAL_NO_TARGET -1UL
  29. /*
  30. * This structure is used to describe the behavior of
  31. * a certain cooling device on a certain trip point
  32. * in a certain thermal zone
  33. */
  34. struct thermal_instance {
  35. int id;
  36. char name[THERMAL_NAME_LENGTH];
  37. struct thermal_zone_device *tz;
  38. struct thermal_cooling_device *cdev;
  39. int trip;
  40. bool initialized;
  41. unsigned long upper; /* Highest cooling state for this trip point */
  42. unsigned long lower; /* Lowest cooling state for this trip point */
  43. unsigned long target; /* expected cooling state */
  44. char attr_name[THERMAL_NAME_LENGTH];
  45. struct device_attribute attr;
  46. char weight_attr_name[THERMAL_NAME_LENGTH];
  47. struct device_attribute weight_attr;
  48. struct list_head tz_node; /* node in tz->thermal_instances */
  49. struct list_head cdev_node; /* node in cdev->thermal_instances */
  50. unsigned int weight; /* The weight of the cooling device */
  51. };
  52. int thermal_register_governor(struct thermal_governor *);
  53. void thermal_unregister_governor(struct thermal_governor *);
  54. #ifdef CONFIG_THERMAL_GOV_STEP_WISE
  55. int thermal_gov_step_wise_register(void);
  56. void thermal_gov_step_wise_unregister(void);
  57. #else
  58. static inline int thermal_gov_step_wise_register(void) { return 0; }
  59. static inline void thermal_gov_step_wise_unregister(void) {}
  60. #endif /* CONFIG_THERMAL_GOV_STEP_WISE */
  61. #ifdef CONFIG_THERMAL_GOV_FAIR_SHARE
  62. int thermal_gov_fair_share_register(void);
  63. void thermal_gov_fair_share_unregister(void);
  64. #else
  65. static inline int thermal_gov_fair_share_register(void) { return 0; }
  66. static inline void thermal_gov_fair_share_unregister(void) {}
  67. #endif /* CONFIG_THERMAL_GOV_FAIR_SHARE */
  68. #ifdef CONFIG_THERMAL_GOV_BANG_BANG
  69. int thermal_gov_bang_bang_register(void);
  70. void thermal_gov_bang_bang_unregister(void);
  71. #else
  72. static inline int thermal_gov_bang_bang_register(void) { return 0; }
  73. static inline void thermal_gov_bang_bang_unregister(void) {}
  74. #endif /* CONFIG_THERMAL_GOV_BANG_BANG */
  75. #ifdef CONFIG_THERMAL_GOV_USER_SPACE
  76. int thermal_gov_user_space_register(void);
  77. void thermal_gov_user_space_unregister(void);
  78. #else
  79. static inline int thermal_gov_user_space_register(void) { return 0; }
  80. static inline void thermal_gov_user_space_unregister(void) {}
  81. #endif /* CONFIG_THERMAL_GOV_USER_SPACE */
  82. #ifdef CONFIG_THERMAL_GOV_POWER_ALLOCATOR
  83. int thermal_gov_power_allocator_register(void);
  84. void thermal_gov_power_allocator_unregister(void);
  85. #else
  86. static inline int thermal_gov_power_allocator_register(void) { return 0; }
  87. static inline void thermal_gov_power_allocator_unregister(void) {}
  88. #endif /* CONFIG_THERMAL_GOV_POWER_ALLOCATOR */
  89. /* device tree support */
  90. #ifdef CONFIG_THERMAL_OF
  91. int of_parse_thermal_zones(void);
  92. void of_thermal_destroy_zones(void);
  93. int of_thermal_get_ntrips(struct thermal_zone_device *);
  94. bool of_thermal_is_trip_valid(struct thermal_zone_device *, int);
  95. const struct thermal_trip *
  96. of_thermal_get_trip_points(struct thermal_zone_device *);
  97. #else
  98. static inline int of_parse_thermal_zones(void) { return 0; }
  99. static inline void of_thermal_destroy_zones(void) { }
  100. static inline int of_thermal_get_ntrips(struct thermal_zone_device *tz)
  101. {
  102. return 0;
  103. }
  104. static inline bool of_thermal_is_trip_valid(struct thermal_zone_device *tz,
  105. int trip)
  106. {
  107. return false;
  108. }
  109. static inline const struct thermal_trip *
  110. of_thermal_get_trip_points(struct thermal_zone_device *tz)
  111. {
  112. return NULL;
  113. }
  114. #endif
  115. #endif /* __THERMAL_CORE_H__ */