mirror of
https://github.com/Telecominfraproject/OpenCellular.git
synced 2026-01-08 00:21:46 +00:00
This adds the driver for the SB-TSI temp sensor. This is a sensor on the AMD AP SOC (Stoney Ridege FT2) that acts like an 8-pin temp sensor with an I2C interface. BUG=b:69379715 BRANCH=None TEST=Build Change-Id: Iaafe6c7beb3e02e4e341617e8f117c03c0a882a2 Signed-off-by: Alec Thilenius <athilenius@chromium.org> Reviewed-on: https://chromium-review.googlesource.com/833346 Commit-Ready: Alec Thilenius <athilenius@google.com> Tested-by: Alec Thilenius <athilenius@google.com> Reviewed-by: Edward Hill <ecgh@chromium.org>
41 lines
992 B
C
41 lines
992 B
C
/* Copyright 2016 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.
|
|
*/
|
|
|
|
/*
|
|
* SB-TSI: SB Temperature Sensor Interface.
|
|
* This is an I2C slave temp sensor on the AMD Stony Ridge FT4 SOC.
|
|
*/
|
|
|
|
#include "chipset.h"
|
|
#include "common.h"
|
|
#include "console.h"
|
|
#include "gpio.h"
|
|
#include "hooks.h"
|
|
#include "i2c.h"
|
|
#include "sb_tsi.h"
|
|
#include "util.h"
|
|
|
|
static int raw_read8(const int offset, int *data_ptr)
|
|
{
|
|
return i2c_read8(I2C_PORT_THERMAL, SB_TSI_I2C_ADDR, offset, data_ptr);
|
|
}
|
|
|
|
int sb_tsi_get_val(int idx, int *temp_ptr)
|
|
{
|
|
int ret;
|
|
/* There is only one temp sensor on the FT4 */
|
|
if (idx != 0)
|
|
return EC_ERROR_PARAM1;
|
|
/* FT4 SB-TSI sensor only powered in S0 */
|
|
if (!chipset_in_state(CHIPSET_STATE_ON))
|
|
return EC_ERROR_NOT_POWERED;
|
|
/* Read the value over I2C */
|
|
ret = raw_read8(SB_TSI_TEMP_H, temp_ptr);
|
|
if (ret)
|
|
return ret;
|
|
*temp_ptr = C_TO_K(*temp_ptr);
|
|
return EC_SUCCESS;
|
|
}
|