blob: 3de816e1dc23fc0ee4466131135946d186a9ad47 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
|
/* 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__7bf(I2C_PORT_THERMAL, SB_TSI_I2C_ADDR__7bf,
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;
}
|