mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2025-12-28 10:45:22 +00:00
This removes the need for a separate method to check sensor power, and gets rid of temp_sensor.c knowledge of what powers each sensor. BUG=chrome-os-partner:15174 BRANCH=link TEST=manual - reboot - within a second, type 'temps'; I2C sensors should return error 1 - type 'temps' again; all sensors should return data - power off system - type 'temps' again; I2C sensors and PECI should return error 8 - 'gpioset enable_vs 1' - type 'temps' again; I2C sensors should return valid data; PECI should still return error 8. Change-Id: I17c353b3c483bc320769307c7715008ec729089b Signed-off-by: Randall Spangler <rspangler@chromium.org> Reviewed-on: https://gerrit.chromium.org/gerrit/35287 Reviewed-by: Bill Richardson <wfrichar@chromium.org>
55 lines
1.4 KiB
C
55 lines
1.4 KiB
C
/* Copyright (c) 2012 The Chromium OS Authors. All rights reserved.
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
* found in the LICENSE file.
|
|
*/
|
|
|
|
/* Temperature sensor module for Chrome EC */
|
|
|
|
#ifndef __CROS_EC_TEMP_SENSOR_H
|
|
#define __CROS_EC_TEMP_SENSOR_H
|
|
|
|
#include "common.h"
|
|
#include "board.h"
|
|
|
|
/* "enum temp_sensor_id" must be defined for each board in board.h. */
|
|
enum temp_sensor_id;
|
|
|
|
/* Type of temperature sensors. */
|
|
enum temp_sensor_type {
|
|
/* Ignore this temperature sensor. */
|
|
TEMP_SENSOR_TYPE_IGNORED = -1,
|
|
/* CPU temperature sensors. */
|
|
TEMP_SENSOR_TYPE_CPU = 0,
|
|
/* Other on-board temperature sensors. */
|
|
TEMP_SENSOR_TYPE_BOARD,
|
|
/* Case temperature sensors. */
|
|
TEMP_SENSOR_TYPE_CASE,
|
|
|
|
TEMP_SENSOR_TYPE_COUNT
|
|
};
|
|
|
|
struct temp_sensor_t {
|
|
const char* name;
|
|
/* Temperature sensor type. */
|
|
enum temp_sensor_type type;
|
|
/* Read sensor value in K into temp_ptr; return non-zero if error. */
|
|
int (*read)(int idx, int *temp_ptr);
|
|
/* Index among the same kind of sensors. */
|
|
int idx;
|
|
/* Delay between reading temperature and taking action about it,
|
|
* in seconds. */
|
|
int action_delay_sec;
|
|
};
|
|
|
|
/**
|
|
* Get the most recently measured temperature for the sensor.
|
|
*
|
|
* @param id Sensor ID
|
|
* @param temp_ptr Destination for temperature
|
|
*
|
|
* @return EC_SUCCESS, or non-zero if error.
|
|
*/
|
|
int temp_sensor_read(enum temp_sensor_id id, int *temp_ptr);
|
|
|
|
#endif /* __CROS_EC_TEMP_SENSOR_H */
|