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. unsigned long upper; /* Highest cooling state for this trip point */
  41. unsigned long lower; /* Lowest cooling state for this trip point */
  42. unsigned long target; /* expected cooling state */
  43. char attr_name[THERMAL_NAME_LENGTH];
  44. struct device_attribute attr;
  45. char weight_attr_name[THERMAL_NAME_LENGTH];
  46. struct device_attribute weight_attr;
  47. struct list_head tz_node; /* node in tz->thermal_instances */
  48. struct list_head cdev_node; /* node in cdev->thermal_instances */
  49. unsigned int weight; /* The weight of the cooling device */
  50. };
  51. int thermal_register_governor(struct thermal_governor *);
  52. void thermal_unregister_governor(struct thermal_governor *);
  53. #ifdef CONFIG_THERMAL_GOV_STEP_WISE
  54. int thermal_gov_step_wise_register(void);
  55. void thermal_gov_step_wise_unregister(void);
  56. #else
  57. static inline int thermal_gov_step_wise_register(void) { return 0; }
  58. static inline void thermal_gov_step_wise_unregister(void) {}
  59. #endif /* CONFIG_THERMAL_GOV_STEP_WISE */
  60. #ifdef CONFIG_THERMAL_GOV_FAIR_SHARE
  61. int thermal_gov_fair_share_register(void);
  62. void thermal_gov_fair_share_unregister(void);
  63. #else
  64. static inline int thermal_gov_fair_share_register(void) { return 0; }
  65. static inline void thermal_gov_fair_share_unregister(void) {}
  66. #endif /* CONFIG_THERMAL_GOV_FAIR_SHARE */
  67. #ifdef CONFIG_THERMAL_GOV_BANG_BANG
  68. int thermal_gov_bang_bang_register(void);
  69. void thermal_gov_bang_bang_unregister(void);
  70. #else
  71. static inline int thermal_gov_bang_bang_register(void) { return 0; }
  72. static inline void thermal_gov_bang_bang_unregister(void) {}
  73. #endif /* CONFIG_THERMAL_GOV_BANG_BANG */
  74. #ifdef CONFIG_THERMAL_GOV_USER_SPACE
  75. int thermal_gov_user_space_register(void);
  76. void thermal_gov_user_space_unregister(void);
  77. #else
  78. static inline int thermal_gov_user_space_register(void) { return 0; }
  79. static inline void thermal_gov_user_space_unregister(void) {}
  80. #endif /* CONFIG_THERMAL_GOV_USER_SPACE */
  81. #ifdef CONFIG_THERMAL_GOV_POWER_ALLOCATOR
  82. int thermal_gov_power_allocator_register(void);
  83. void thermal_gov_power_allocator_unregister(void);
  84. #else
  85. static inline int thermal_gov_power_allocator_register(void) { return 0; }
  86. static inline void thermal_gov_power_allocator_unregister(void) {}
  87. #endif /* CONFIG_THERMAL_GOV_POWER_ALLOCATOR */
  88. /* device tree support */
  89. #ifdef CONFIG_THERMAL_OF
  90. int of_parse_thermal_zones(void);
  91. void of_thermal_destroy_zones(void);
  92. int of_thermal_get_ntrips(struct thermal_zone_device *);
  93. bool of_thermal_is_trip_valid(struct thermal_zone_device *, int);
  94. const struct thermal_trip *
  95. of_thermal_get_trip_points(struct thermal_zone_device *);
  96. #else
  97. static inline int of_parse_thermal_zones(void) { return 0; }
  98. static inline void of_thermal_destroy_zones(void) { }
  99. static inline int of_thermal_get_ntrips(struct thermal_zone_device *tz)
  100. {
  101. return 0;
  102. }
  103. static inline bool of_thermal_is_trip_valid(struct thermal_zone_device *tz,
  104. int trip)
  105. {
  106. return false;
  107. }
  108. static inline const struct thermal_trip *
  109. of_thermal_get_trip_points(struct thermal_zone_device *tz)
  110. {
  111. return NULL;
  112. }
  113. #endif
  114. #endif /* __THERMAL_CORE_H__ */