2008-01-17 08:51:08 +01:00
|
|
|
/*
|
|
|
|
* thermal.h ($Revision: 0 $)
|
|
|
|
*
|
|
|
|
* Copyright (C) 2008 Intel Corp
|
|
|
|
* Copyright (C) 2008 Zhang Rui <rui.zhang@intel.com>
|
|
|
|
* Copyright (C) 2008 Sujith Thomas <sujith.thomas@intel.com>
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; version 2 of the License.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License along
|
|
|
|
* with this program; if not, write to the Free Software Foundation, Inc.,
|
|
|
|
* 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
|
|
|
|
*
|
|
|
|
* ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __THERMAL_H__
|
|
|
|
#define __THERMAL_H__
|
|
|
|
|
|
|
|
#include <linux/idr.h>
|
|
|
|
#include <linux/device.h>
|
2008-12-03 18:55:32 +01:00
|
|
|
#include <linux/workqueue.h>
|
2008-01-17 08:51:08 +01:00
|
|
|
|
2012-09-18 07:34:52 +02:00
|
|
|
#define THERMAL_TRIPS_NONE -1
|
|
|
|
#define THERMAL_MAX_TRIPS 12
|
|
|
|
#define THERMAL_NAME_LENGTH 20
|
|
|
|
|
|
|
|
/* No upper/lower limit requirement */
|
|
|
|
#define THERMAL_NO_LIMIT -1UL
|
|
|
|
|
|
|
|
/* Unit conversion macros */
|
|
|
|
#define KELVIN_TO_CELSIUS(t) (long)(((long)t-2732 >= 0) ? \
|
|
|
|
((long)t-2732+5)/10 : ((long)t-2732-5)/10)
|
|
|
|
#define CELSIUS_TO_KELVIN(t) ((t)*10+2732)
|
|
|
|
|
|
|
|
/* Adding event notification support elements */
|
|
|
|
#define THERMAL_GENL_FAMILY_NAME "thermal_event"
|
|
|
|
#define THERMAL_GENL_VERSION 0x01
|
|
|
|
#define THERMAL_GENL_MCAST_GROUP_NAME "thermal_mc_group"
|
|
|
|
|
2008-01-17 08:51:08 +01:00
|
|
|
struct thermal_zone_device;
|
|
|
|
struct thermal_cooling_device;
|
|
|
|
|
2008-11-27 18:48:13 +01:00
|
|
|
enum thermal_device_mode {
|
|
|
|
THERMAL_DEVICE_DISABLED = 0,
|
|
|
|
THERMAL_DEVICE_ENABLED,
|
|
|
|
};
|
|
|
|
|
|
|
|
enum thermal_trip_type {
|
|
|
|
THERMAL_TRIP_ACTIVE = 0,
|
|
|
|
THERMAL_TRIP_PASSIVE,
|
|
|
|
THERMAL_TRIP_HOT,
|
|
|
|
THERMAL_TRIP_CRITICAL,
|
|
|
|
};
|
|
|
|
|
2012-06-27 03:54:33 +02:00
|
|
|
enum thermal_trend {
|
|
|
|
THERMAL_TREND_STABLE, /* temperature is stable */
|
|
|
|
THERMAL_TREND_RAISING, /* temperature is raising */
|
|
|
|
THERMAL_TREND_DROPPING, /* temperature is dropping */
|
|
|
|
};
|
|
|
|
|
2012-09-18 07:34:52 +02:00
|
|
|
/* Events supported by Thermal Netlink */
|
|
|
|
enum events {
|
|
|
|
THERMAL_AUX0,
|
|
|
|
THERMAL_AUX1,
|
|
|
|
THERMAL_CRITICAL,
|
|
|
|
THERMAL_DEV_FAULT,
|
|
|
|
};
|
|
|
|
|
|
|
|
/* attributes of thermal_genl_family */
|
|
|
|
enum {
|
|
|
|
THERMAL_GENL_ATTR_UNSPEC,
|
|
|
|
THERMAL_GENL_ATTR_EVENT,
|
|
|
|
__THERMAL_GENL_ATTR_MAX,
|
|
|
|
};
|
|
|
|
#define THERMAL_GENL_ATTR_MAX (__THERMAL_GENL_ATTR_MAX - 1)
|
|
|
|
|
|
|
|
/* commands supported by the thermal_genl_family */
|
|
|
|
enum {
|
|
|
|
THERMAL_GENL_CMD_UNSPEC,
|
|
|
|
THERMAL_GENL_CMD_EVENT,
|
|
|
|
__THERMAL_GENL_CMD_MAX,
|
|
|
|
};
|
|
|
|
#define THERMAL_GENL_CMD_MAX (__THERMAL_GENL_CMD_MAX - 1)
|
|
|
|
|
2008-01-17 08:51:08 +01:00
|
|
|
struct thermal_zone_device_ops {
|
|
|
|
int (*bind) (struct thermal_zone_device *,
|
|
|
|
struct thermal_cooling_device *);
|
|
|
|
int (*unbind) (struct thermal_zone_device *,
|
|
|
|
struct thermal_cooling_device *);
|
2008-11-27 18:48:13 +01:00
|
|
|
int (*get_temp) (struct thermal_zone_device *, unsigned long *);
|
|
|
|
int (*get_mode) (struct thermal_zone_device *,
|
|
|
|
enum thermal_device_mode *);
|
|
|
|
int (*set_mode) (struct thermal_zone_device *,
|
|
|
|
enum thermal_device_mode);
|
|
|
|
int (*get_trip_type) (struct thermal_zone_device *, int,
|
|
|
|
enum thermal_trip_type *);
|
|
|
|
int (*get_trip_temp) (struct thermal_zone_device *, int,
|
|
|
|
unsigned long *);
|
2012-07-25 04:10:58 +02:00
|
|
|
int (*set_trip_temp) (struct thermal_zone_device *, int,
|
|
|
|
unsigned long);
|
2012-07-25 04:10:59 +02:00
|
|
|
int (*get_trip_hyst) (struct thermal_zone_device *, int,
|
|
|
|
unsigned long *);
|
|
|
|
int (*set_trip_hyst) (struct thermal_zone_device *, int,
|
|
|
|
unsigned long);
|
2008-04-10 10:13:10 +02:00
|
|
|
int (*get_crit_temp) (struct thermal_zone_device *, unsigned long *);
|
2012-06-27 03:54:33 +02:00
|
|
|
int (*get_trend) (struct thermal_zone_device *, int,
|
|
|
|
enum thermal_trend *);
|
2008-12-03 18:55:32 +01:00
|
|
|
int (*notify) (struct thermal_zone_device *, int,
|
|
|
|
enum thermal_trip_type);
|
2008-01-17 08:51:08 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
struct thermal_cooling_device_ops {
|
2008-11-27 18:48:13 +01:00
|
|
|
int (*get_max_state) (struct thermal_cooling_device *, unsigned long *);
|
|
|
|
int (*get_cur_state) (struct thermal_cooling_device *, unsigned long *);
|
|
|
|
int (*set_cur_state) (struct thermal_cooling_device *, unsigned long);
|
2008-01-17 08:51:08 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
struct thermal_cooling_device {
|
|
|
|
int id;
|
|
|
|
char type[THERMAL_NAME_LENGTH];
|
|
|
|
struct device device;
|
|
|
|
void *devdata;
|
2010-11-11 16:27:29 +01:00
|
|
|
const struct thermal_cooling_device_ops *ops;
|
2012-06-27 08:13:04 +02:00
|
|
|
bool updated; /* true if the cooling device does not need update */
|
2012-07-24 10:56:21 +02:00
|
|
|
struct mutex lock; /* protect thermal_instances list */
|
2012-06-27 08:11:52 +02:00
|
|
|
struct list_head thermal_instances;
|
2008-01-17 08:51:08 +01:00
|
|
|
struct list_head node;
|
|
|
|
};
|
|
|
|
|
2012-07-25 04:10:58 +02:00
|
|
|
struct thermal_attr {
|
|
|
|
struct device_attribute attr;
|
|
|
|
char name[THERMAL_NAME_LENGTH];
|
|
|
|
};
|
|
|
|
|
2008-01-17 08:51:08 +01:00
|
|
|
struct thermal_zone_device {
|
|
|
|
int id;
|
|
|
|
char type[THERMAL_NAME_LENGTH];
|
|
|
|
struct device device;
|
2012-07-25 04:10:58 +02:00
|
|
|
struct thermal_attr *trip_temp_attrs;
|
|
|
|
struct thermal_attr *trip_type_attrs;
|
2012-07-25 04:10:59 +02:00
|
|
|
struct thermal_attr *trip_hyst_attrs;
|
2008-01-17 08:51:08 +01:00
|
|
|
void *devdata;
|
|
|
|
int trips;
|
2008-12-03 18:55:32 +01:00
|
|
|
int passive_delay;
|
|
|
|
int polling_delay;
|
2012-06-27 03:54:33 +02:00
|
|
|
int temperature;
|
2008-12-03 18:55:32 +01:00
|
|
|
int last_temperature;
|
2012-06-27 08:14:05 +02:00
|
|
|
int passive;
|
2008-12-03 19:00:38 +01:00
|
|
|
unsigned int forced_passive;
|
2010-11-11 16:27:29 +01:00
|
|
|
const struct thermal_zone_device_ops *ops;
|
2012-06-27 04:09:00 +02:00
|
|
|
struct list_head thermal_instances;
|
2008-01-17 08:51:08 +01:00
|
|
|
struct idr idr;
|
2012-06-27 04:09:00 +02:00
|
|
|
struct mutex lock; /* protect thermal_instances list */
|
2008-01-17 08:51:08 +01:00
|
|
|
struct list_head node;
|
2008-12-03 18:55:32 +01:00
|
|
|
struct delayed_work poll_queue;
|
2008-01-17 08:51:08 +01:00
|
|
|
};
|
2010-10-27 00:03:29 +02:00
|
|
|
|
|
|
|
struct thermal_genl_event {
|
|
|
|
u32 orig;
|
|
|
|
enum events event;
|
|
|
|
};
|
2008-01-17 08:51:08 +01:00
|
|
|
|
2012-09-18 07:34:52 +02:00
|
|
|
/* Function declarations */
|
2012-07-31 13:39:30 +02:00
|
|
|
struct thermal_zone_device *thermal_zone_device_register(const char *, int, int,
|
2012-06-27 03:51:12 +02:00
|
|
|
void *, const struct thermal_zone_device_ops *, int, int);
|
2008-01-17 08:51:08 +01:00
|
|
|
void thermal_zone_device_unregister(struct thermal_zone_device *);
|
|
|
|
|
|
|
|
int thermal_zone_bind_cooling_device(struct thermal_zone_device *, int,
|
2012-06-26 10:35:57 +02:00
|
|
|
struct thermal_cooling_device *,
|
|
|
|
unsigned long, unsigned long);
|
2008-01-17 08:51:08 +01:00
|
|
|
int thermal_zone_unbind_cooling_device(struct thermal_zone_device *, int,
|
|
|
|
struct thermal_cooling_device *);
|
2008-12-03 18:55:32 +01:00
|
|
|
void thermal_zone_device_update(struct thermal_zone_device *);
|
2012-09-18 07:34:52 +02:00
|
|
|
|
2008-01-17 08:51:08 +01:00
|
|
|
struct thermal_cooling_device *thermal_cooling_device_register(char *, void *,
|
2010-11-11 16:27:29 +01:00
|
|
|
const struct thermal_cooling_device_ops *);
|
2008-01-17 08:51:08 +01:00
|
|
|
void thermal_cooling_device_unregister(struct thermal_cooling_device *);
|
2011-03-01 01:12:19 +01:00
|
|
|
|
2012-09-18 07:34:54 +02:00
|
|
|
int get_tz_trend(struct thermal_zone_device *, int);
|
|
|
|
struct thermal_instance *get_thermal_instance(struct thermal_zone_device *,
|
|
|
|
struct thermal_cooling_device *, int);
|
|
|
|
|
2011-03-01 01:12:19 +01:00
|
|
|
#ifdef CONFIG_NET
|
2011-11-04 10:31:04 +01:00
|
|
|
extern int thermal_generate_netlink_event(u32 orig, enum events event);
|
2011-03-01 01:12:19 +01:00
|
|
|
#else
|
2011-11-04 10:31:04 +01:00
|
|
|
static inline int thermal_generate_netlink_event(u32 orig, enum events event)
|
2011-03-01 01:12:19 +01:00
|
|
|
{
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
#endif
|
2008-01-17 08:51:08 +01:00
|
|
|
|
2008-02-09 10:01:48 +01:00
|
|
|
#endif /* __THERMAL_H__ */
|