thermal.h 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150
  1. /*
  2. * thermal.h ($Revision: 0 $)
  3. *
  4. * Copyright (C) 2008 Intel Corp
  5. * Copyright (C) 2008 Zhang Rui <rui.zhang@intel.com>
  6. * Copyright (C) 2008 Sujith Thomas <sujith.thomas@intel.com>
  7. *
  8. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  9. * This program is free software; you can redistribute it and/or modify
  10. * it under the terms of the GNU General Public License as published by
  11. * the Free Software Foundation; version 2 of the License.
  12. *
  13. * This program is distributed in the hope that it will be useful, but
  14. * WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  16. * General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License along
  19. * with this program; if not, write to the Free Software Foundation, Inc.,
  20. * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
  21. *
  22. * ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
  23. */
  24. #ifndef __THERMAL_H__
  25. #define __THERMAL_H__
  26. #include <linux/idr.h>
  27. #include <linux/device.h>
  28. #include <linux/workqueue.h>
  29. struct thermal_zone_device;
  30. struct thermal_cooling_device;
  31. enum thermal_device_mode {
  32. THERMAL_DEVICE_DISABLED = 0,
  33. THERMAL_DEVICE_ENABLED,
  34. };
  35. enum thermal_trip_type {
  36. THERMAL_TRIP_ACTIVE = 0,
  37. THERMAL_TRIP_PASSIVE,
  38. THERMAL_TRIP_HOT,
  39. THERMAL_TRIP_CRITICAL,
  40. };
  41. struct thermal_zone_device_ops {
  42. int (*bind) (struct thermal_zone_device *,
  43. struct thermal_cooling_device *);
  44. int (*unbind) (struct thermal_zone_device *,
  45. struct thermal_cooling_device *);
  46. int (*get_temp) (struct thermal_zone_device *, unsigned long *);
  47. int (*get_mode) (struct thermal_zone_device *,
  48. enum thermal_device_mode *);
  49. int (*set_mode) (struct thermal_zone_device *,
  50. enum thermal_device_mode);
  51. int (*get_trip_type) (struct thermal_zone_device *, int,
  52. enum thermal_trip_type *);
  53. int (*get_trip_temp) (struct thermal_zone_device *, int,
  54. unsigned long *);
  55. int (*get_crit_temp) (struct thermal_zone_device *, unsigned long *);
  56. int (*notify) (struct thermal_zone_device *, int,
  57. enum thermal_trip_type);
  58. };
  59. struct thermal_cooling_device_ops {
  60. int (*get_max_state) (struct thermal_cooling_device *, unsigned long *);
  61. int (*get_cur_state) (struct thermal_cooling_device *, unsigned long *);
  62. int (*set_cur_state) (struct thermal_cooling_device *, unsigned long);
  63. };
  64. #define THERMAL_TRIPS_NONE -1
  65. #define THERMAL_MAX_TRIPS 12
  66. #define THERMAL_NAME_LENGTH 20
  67. struct thermal_cooling_device {
  68. int id;
  69. char type[THERMAL_NAME_LENGTH];
  70. struct device device;
  71. void *devdata;
  72. struct thermal_cooling_device_ops *ops;
  73. struct list_head node;
  74. };
  75. #define KELVIN_TO_CELSIUS(t) (long)(((long)t-2732 >= 0) ? \
  76. ((long)t-2732+5)/10 : ((long)t-2732-5)/10)
  77. #define CELSIUS_TO_KELVIN(t) ((t)*10+2732)
  78. #if defined(CONFIG_THERMAL_HWMON)
  79. /* thermal zone devices with the same type share one hwmon device */
  80. struct thermal_hwmon_device {
  81. char type[THERMAL_NAME_LENGTH];
  82. struct device *device;
  83. int count;
  84. struct list_head tz_list;
  85. struct list_head node;
  86. };
  87. struct thermal_hwmon_attr {
  88. struct device_attribute attr;
  89. char name[16];
  90. };
  91. #endif
  92. struct thermal_zone_device {
  93. int id;
  94. char type[THERMAL_NAME_LENGTH];
  95. struct device device;
  96. void *devdata;
  97. int trips;
  98. int tc1;
  99. int tc2;
  100. int passive_delay;
  101. int polling_delay;
  102. int last_temperature;
  103. bool passive;
  104. unsigned int forced_passive;
  105. struct thermal_zone_device_ops *ops;
  106. struct list_head cooling_devices;
  107. struct idr idr;
  108. struct mutex lock; /* protect cooling devices list */
  109. struct list_head node;
  110. struct delayed_work poll_queue;
  111. #if defined(CONFIG_THERMAL_HWMON)
  112. struct list_head hwmon_node;
  113. struct thermal_hwmon_device *hwmon;
  114. struct thermal_hwmon_attr temp_input; /* hwmon sys attr */
  115. struct thermal_hwmon_attr temp_crit; /* hwmon sys attr */
  116. #endif
  117. };
  118. struct thermal_zone_device *thermal_zone_device_register(char *, int, void *,
  119. struct
  120. thermal_zone_device_ops
  121. *, int tc1, int tc2,
  122. int passive_freq,
  123. int polling_freq);
  124. void thermal_zone_device_unregister(struct thermal_zone_device *);
  125. int thermal_zone_bind_cooling_device(struct thermal_zone_device *, int,
  126. struct thermal_cooling_device *);
  127. int thermal_zone_unbind_cooling_device(struct thermal_zone_device *, int,
  128. struct thermal_cooling_device *);
  129. void thermal_zone_device_update(struct thermal_zone_device *);
  130. struct thermal_cooling_device *thermal_cooling_device_register(char *, void *,
  131. struct
  132. thermal_cooling_device_ops
  133. *);
  134. void thermal_cooling_device_unregister(struct thermal_cooling_device *);
  135. #endif /* __THERMAL_H__ */