summaryrefslogtreecommitdiff
path: root/driver/temp_sensor/g78x.h
diff options
context:
space:
mode:
Diffstat (limited to 'driver/temp_sensor/g78x.h')
-rw-r--r--driver/temp_sensor/g78x.h140
1 files changed, 140 insertions, 0 deletions
diff --git a/driver/temp_sensor/g78x.h b/driver/temp_sensor/g78x.h
new file mode 100644
index 0000000000..8fa78ffa83
--- /dev/null
+++ b/driver/temp_sensor/g78x.h
@@ -0,0 +1,140 @@
+/* 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.
+ */
+
+/* G781/G782 temperature sensor module for Chrome EC */
+
+#ifndef __CROS_EC_G78X_H
+#define __CROS_EC_G78X_H
+
+#if defined(CONFIG_TEMP_SENSOR_G781) && defined(CONFIG_TEMP_SENSOR_G782)
+#error Cannot support both G781 and G782 together!
+#endif
+
+#define G78X_I2C_ADDR 0x98 /* 7-bit address is 0x4C */
+
+#define G78X_IDX_INTERNAL 0
+#define G78X_IDX_EXTERNAL1 1
+#define G78X_IDX_EXTERNAL2 2
+
+#if defined(CONFIG_TEMP_SENSOR_G781)
+/* G781 register */
+#define G78X_TEMP_LOCAL 0x00
+#define G78X_TEMP_REMOTE1 0x01
+#define G78X_STATUS 0x02
+#define G78X_CONFIGURATION_R 0x03
+#define G78X_CONVERSION_RATE_R 0x04
+#define G78X_LOCAL_TEMP_HIGH_LIMIT_R 0x05
+#define G78X_LOCAL_TEMP_LOW_LIMIT_R 0x06
+#define G78X_REMOTE1_TEMP_HIGH_LIMIT_R 0x07
+#define G78X_REMOTE1_TEMP_LOW_LIMIT_R 0x08
+#define G78X_CONFIGURATION_W 0x09
+#define G78X_CONVERSION_RATE_W 0x0a
+#define G78X_LOCAL_TEMP_HIGH_LIMIT_W 0x0b
+#define G78X_LOCAL_TEMP_LOW_LIMIT_W 0x0c
+#define G78X_REMOTE1_TEMP_HIGH_LIMIT_W 0x0d
+#define G78X_REMOTE1_TEMP_LOW_LIMIT_W 0x0e
+#define G78X_ONESHOT 0x0f
+#define G78X_REMOTE1_TEMP_EXTENDED 0x10
+#define G78X_REMOTE1_TEMP_OFFSET_HIGH 0x11
+#define G78X_REMOTE1_TEMP_OFFSET_EXTD 0x12
+#define G78X_REMOTE1_T_HIGH_LIMIT_EXTD 0x13
+#define G78X_REMOTE1_T_LOW_LIMIT_EXTD 0x14
+#define G78X_REMOTE1_TEMP_THERM_LIMIT 0x19
+#define G78X_LOCAL_TEMP_THERM_LIMIT 0x20
+#define G78X_THERM_HYSTERESIS 0x21
+#define G78X_ALERT_FAULT_QUEUE_CODE 0x22
+#define G78X_MANUFACTURER_ID 0xFE
+#define G78X_DEVICE_ID 0xFF
+
+/* Config register bits */
+#define G78X_CONFIGURATION_STANDBY (1 << 6)
+#define G78X_CONFIGURATION_ALERT_MASK (1 << 7)
+
+/* Status register bits */
+#define G78X_STATUS_LOCAL_TEMP_THERM_ALARM (1 << 0)
+#define G78X_STATUS_REMOTE1_TEMP_THERM_ALARM (1 << 1)
+#define G78X_STATUS_REMOTE1_TEMP_FAULT (1 << 2)
+#define G78X_STATUS_REMOTE1_TEMP_LOW_ALARM (1 << 3)
+#define G78X_STATUS_REMOTE1_TEMP_HIGH_ALARM (1 << 4)
+#define G78X_STATUS_LOCAL_TEMP_LOW_ALARM (1 << 5)
+#define G78X_STATUS_LOCAL_TEMP_HIGH_ALARM (1 << 6)
+#define G78X_STATUS_BUSY (1 << 7)
+
+#elif defined(CONFIG_TEMP_SENSOR_G782)
+/* G782 register */
+#define G78X_TEMP_LOCAL 0x00
+#define G78X_TEMP_REMOTE1 0x01
+#define G78X_TEMP_REMOTE2 0x02
+#define G78X_STATUS 0x03
+#define G78X_CONFIGURATION_R 0x04
+#define G78X_CONFIGURATION_W 0x04
+#define G78X_CONVERSION_RATE_R 0x05
+#define G78X_CONVERSION_RATE_W 0x05
+#define G78X_LOCAL_TEMP_HIGH_LIMIT_R 0x06
+#define G78X_LOCAL_TEMP_HIGH_LIMIT_W 0x06
+#define G78X_LOCAL_TEMP_LOW_LIMIT_R 0x07
+#define G78X_LOCAL_TEMP_LOW_LIMIT_W 0x07
+#define G78X_REMOTE1_TEMP_HIGH_LIMIT_R 0x08
+#define G78X_REMOTE1_TEMP_HIGH_LIMIT_W 0x08
+#define G78X_REMOTE1_TEMP_LOW_LIMIT_R 0x09
+#define G78X_REMOTE1_TEMP_LOW_LIMIT_W 0x09
+#define G78X_REMOTE2_TEMP_HIGH_LIMIT_R 0x0a
+#define G78X_REMOTE2_TEMP_HIGH_LIMIT_W 0x0a
+#define G78X_REMOTE2_TEMP_LOW_LIMIT_R 0x0b
+#define G78X_REMOTE2_TEMP_LOW_LIMIT_W 0x0b
+#define G78X_ONESHOT 0x0c
+#define G78X_REMOTE1_TEMP_EXTENDED 0x0d
+#define G78X_REMOTE1_TEMP_OFFSET_HIGH 0x0e
+#define G78X_REMOTE1_TEMP_OFFSET_EXTD 0x0f
+#define G78X_REMOTE1_T_HIGH_LIMIT_EXTD 0x10
+#define G78X_REMOTE1_T_LOW_LIMIT_EXTD 0x11
+#define G78X_REMOTE1_TEMP_THERM_LIMIT 0x12
+#define G78X_REMOTE2_TEMP_EXTENDED 0x13
+#define G78X_REMOTE2_TEMP_OFFSET_HIGH 0x14
+#define G78X_REMOTE2_TEMP_OFFSET_EXTD 0x15
+#define G78X_REMOTE2_T_HIGH_LIMIT_EXTD 0x16
+#define G78X_REMOTE2_T_LOW_LIMIT_EXTD 0x17
+#define G78X_REMOTE2_TEMP_THERM_LIMIT 0x18
+#define G78X_STATUS1 0x19
+#define G78X_LOCAL_TEMP_THERM_LIMIT 0x20
+#define G78X_THERM_HYSTERESIS 0x21
+#define G78X_ALERT_FAULT_QUEUE_CODE 0x22
+#define G78X_MANUFACTURER_ID 0xFE
+#define G78X_DEVICE_ID 0xFF
+
+/* Config register bits */
+#define G78X_CONFIGURATION_REMOTE2_DIS (1 << 5)
+#define G78X_CONFIGURATION_STANDBY (1 << 6)
+#define G78X_CONFIGURATION_ALERT_MASK (1 << 7)
+
+/* Status register bits */
+#define G78X_STATUS_LOCAL_TEMP_LOW_ALARM (1 << 0)
+#define G78X_STATUS_LOCAL_TEMP_HIGH_ALARM (1 << 1)
+#define G78X_STATUS_LOCAL_TEMP_THERM_ALARM (1 << 2)
+#define G78X_STATUS_REMOTE2_TEMP_THERM_ALARM (1 << 3)
+#define G78X_STATUS_REMOTE1_TEMP_THERM_ALARM (1 << 4)
+#define G78X_STATUS_REMOTE2_TEMP_FAULT (1 << 5)
+#define G78X_STATUS_REMOTE1_TEMP_FAULT (1 << 6)
+#define G78X_STATUS_BUSY (1 << 7)
+
+/* Status1 register bits */
+#define G78X_STATUS_REMOTE2_TEMP_LOW_ALARM (1 << 4)
+#define G78X_STATUS_REMOTE2_TEMP_HIGH_ALARM (1 << 5)
+#define G78X_STATUS_REMOTE1_TEMP_LOW_ALARM (1 << 6)
+#define G78X_STATUS_REMOTE1_TEMP_HIGH_ALARM (1 << 7)
+#endif
+
+/**
+ * Get the last polled value of a sensor.
+ *
+ * @param idx Index to read. Idx indicates whether to read die
+ * temperature or external temperature.
+ * @param temp_ptr Destination for temperature in K.
+ *
+ * @return EC_SUCCESS if successful, non-zero if error.
+ */
+int g78x_get_val(int idx, int *temp_ptr);
+
+#endif /* __CROS_EC_G78X_H */