thermal.h 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208
  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_activation_mode {
  36. THERMAL_TRIP_ACTIVATION_DISABLED = 0,
  37. THERMAL_TRIP_ACTIVATION_ENABLED,
  38. };
  39. enum thermal_trip_type {
  40. THERMAL_TRIP_ACTIVE = 0,
  41. THERMAL_TRIP_PASSIVE,
  42. THERMAL_TRIP_HOT,
  43. THERMAL_TRIP_CRITICAL,
  44. THERMAL_TRIP_CONFIGURABLE_HI,
  45. THERMAL_TRIP_CONFIGURABLE_LOW,
  46. THERMAL_TRIP_CRITICAL_LOW,
  47. };
  48. struct thermal_zone_device_ops {
  49. int (*bind) (struct thermal_zone_device *,
  50. struct thermal_cooling_device *);
  51. int (*unbind) (struct thermal_zone_device *,
  52. struct thermal_cooling_device *);
  53. int (*get_temp) (struct thermal_zone_device *, unsigned long *);
  54. int (*get_mode) (struct thermal_zone_device *,
  55. enum thermal_device_mode *);
  56. int (*set_mode) (struct thermal_zone_device *,
  57. enum thermal_device_mode);
  58. int (*get_trip_type) (struct thermal_zone_device *, int,
  59. enum thermal_trip_type *);
  60. int (*activate_trip_type) (struct thermal_zone_device *, int,
  61. enum thermal_trip_activation_mode);
  62. int (*get_trip_temp) (struct thermal_zone_device *, int,
  63. unsigned long *);
  64. int (*set_trip_temp) (struct thermal_zone_device *, int,
  65. long);
  66. int (*get_crit_temp) (struct thermal_zone_device *, unsigned long *);
  67. int (*notify) (struct thermal_zone_device *, int,
  68. enum thermal_trip_type);
  69. };
  70. struct thermal_cooling_device_ops {
  71. int (*get_max_state) (struct thermal_cooling_device *, unsigned long *);
  72. int (*get_cur_state) (struct thermal_cooling_device *, unsigned long *);
  73. int (*set_cur_state) (struct thermal_cooling_device *, unsigned long);
  74. };
  75. #define THERMAL_TRIPS_NONE -1
  76. #define THERMAL_MAX_TRIPS 12
  77. #define THERMAL_NAME_LENGTH 20
  78. struct thermal_cooling_device {
  79. int id;
  80. char type[THERMAL_NAME_LENGTH];
  81. struct device device;
  82. void *devdata;
  83. const struct thermal_cooling_device_ops *ops;
  84. struct list_head node;
  85. };
  86. #define KELVIN_TO_CELSIUS(t) (long)(((long)t-2732 >= 0) ? \
  87. ((long)t-2732+5)/10 : ((long)t-2732-5)/10)
  88. #define CELSIUS_TO_KELVIN(t) ((t)*10+2732)
  89. struct sensor_threshold {
  90. long temp;
  91. enum thermal_trip_type trip;
  92. int (*notify)(enum thermal_trip_type type, int temp, void *data);
  93. void *data;
  94. uint8_t active;
  95. struct list_head list;
  96. };
  97. struct sensor_info {
  98. uint32_t sensor_id;
  99. struct thermal_zone_device *tz;
  100. long threshold_min;
  101. long threshold_max;
  102. int max_idx;
  103. int min_idx;
  104. struct list_head sensor_list;
  105. struct list_head threshold_list;
  106. struct mutex lock;
  107. struct work_struct work;
  108. };
  109. struct thermal_zone_device {
  110. int id;
  111. char type[THERMAL_NAME_LENGTH];
  112. struct device device;
  113. void *devdata;
  114. int trips;
  115. int tc1;
  116. int tc2;
  117. int passive_delay;
  118. int polling_delay;
  119. int last_temperature;
  120. bool passive;
  121. unsigned int forced_passive;
  122. const struct thermal_zone_device_ops *ops;
  123. struct list_head cooling_devices;
  124. struct idr idr;
  125. struct mutex lock; /* protect cooling devices list */
  126. struct list_head node;
  127. struct delayed_work poll_queue;
  128. struct sensor_threshold tz_threshold[2];
  129. struct sensor_info sensor;
  130. };
  131. /* Adding event notification support elements */
  132. #define THERMAL_GENL_FAMILY_NAME "thermal_event"
  133. #define THERMAL_GENL_VERSION 0x01
  134. #define THERMAL_GENL_MCAST_GROUP_NAME "thermal_mc_grp"
  135. enum events {
  136. THERMAL_AUX0,
  137. THERMAL_AUX1,
  138. THERMAL_CRITICAL,
  139. THERMAL_DEV_FAULT,
  140. };
  141. struct thermal_genl_event {
  142. u32 orig;
  143. enum events event;
  144. };
  145. /* attributes of thermal_genl_family */
  146. enum {
  147. THERMAL_GENL_ATTR_UNSPEC,
  148. THERMAL_GENL_ATTR_EVENT,
  149. __THERMAL_GENL_ATTR_MAX,
  150. };
  151. #define THERMAL_GENL_ATTR_MAX (__THERMAL_GENL_ATTR_MAX - 1)
  152. /* commands supported by the thermal_genl_family */
  153. enum {
  154. THERMAL_GENL_CMD_UNSPEC,
  155. THERMAL_GENL_CMD_EVENT,
  156. __THERMAL_GENL_CMD_MAX,
  157. };
  158. #define THERMAL_GENL_CMD_MAX (__THERMAL_GENL_CMD_MAX - 1)
  159. struct thermal_zone_device *thermal_zone_device_register(char *, int, void *,
  160. const struct thermal_zone_device_ops *, int tc1, int tc2,
  161. int passive_freq, int polling_freq);
  162. void thermal_zone_device_unregister(struct thermal_zone_device *);
  163. int thermal_zone_bind_cooling_device(struct thermal_zone_device *, int,
  164. struct thermal_cooling_device *);
  165. int thermal_zone_unbind_cooling_device(struct thermal_zone_device *, int,
  166. struct thermal_cooling_device *);
  167. void thermal_zone_device_update(struct thermal_zone_device *);
  168. struct thermal_cooling_device *thermal_cooling_device_register(char *, void *,
  169. const struct thermal_cooling_device_ops *);
  170. void thermal_cooling_device_unregister(struct thermal_cooling_device *);
  171. int sensor_get_id(char *name);
  172. int sensor_set_trip(uint32_t sensor_id, struct sensor_threshold *threshold);
  173. int sensor_cancel_trip(uint32_t sensor_id, struct sensor_threshold *threshold);
  174. int sensor_activate_trip(uint32_t sensor_id, struct sensor_threshold *threshold,
  175. bool enable);
  176. int thermal_sensor_trip(struct thermal_zone_device *tz,
  177. enum thermal_trip_type trip, long temp);
  178. #ifdef CONFIG_NET
  179. extern int thermal_generate_netlink_event(u32 orig, enum events event);
  180. #else
  181. static inline int thermal_generate_netlink_event(u32 orig, enum events event)
  182. {
  183. return 0;
  184. }
  185. #endif
  186. #endif /* __THERMAL_H__ */