summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--zephyr/program/skyrim/winterhold/CMakeLists.txt1
-rw-r--r--zephyr/program/skyrim/winterhold/project.overlay4
-rw-r--r--zephyr/program/skyrim/winterhold/src/thermal.c32
3 files changed, 35 insertions, 2 deletions
diff --git a/zephyr/program/skyrim/winterhold/CMakeLists.txt b/zephyr/program/skyrim/winterhold/CMakeLists.txt
index 70d3882323..0596978c05 100644
--- a/zephyr/program/skyrim/winterhold/CMakeLists.txt
+++ b/zephyr/program/skyrim/winterhold/CMakeLists.txt
@@ -10,4 +10,5 @@ zephyr_library_sources(
"src/sensor.c"
"src/battery_present.c"
"src/alt_charger.c"
+ "src/thermal.c"
)
diff --git a/zephyr/program/skyrim/winterhold/project.overlay b/zephyr/program/skyrim/winterhold/project.overlay
index 6ce9471460..6e36fade79 100644
--- a/zephyr/program/skyrim/winterhold/project.overlay
+++ b/zephyr/program/skyrim/winterhold/project.overlay
@@ -53,7 +53,7 @@
named-temp-sensors {
compatible = "cros-ec,temp-sensors";
- soc-pct2075 {
+ temp_sensor_soc: soc-pct2075 {
temp_host_high = <105>;
temp_host_halt = <110>;
temp_host_release_high = <95>;
@@ -61,7 +61,7 @@
power-good-pin = <&gpio_pg_pwr_s5>;
sensor = <&soc_pct2075>;
};
- amb-pct2075 {
+ temp_sensor_amb: amb-pct2075 {
temp_host_warn = <50>;
temp_host_high = <105>;
temp_host_halt = <110>;
diff --git a/zephyr/program/skyrim/winterhold/src/thermal.c b/zephyr/program/skyrim/winterhold/src/thermal.c
new file mode 100644
index 0000000000..2c9432be09
--- /dev/null
+++ b/zephyr/program/skyrim/winterhold/src/thermal.c
@@ -0,0 +1,32 @@
+/* Copyright 2022 The ChromiumOS Authors
+ * Use of this source code is governed by a BSD-style license that can be
+ * found in the LICENSE file.
+ */
+
+#include "hooks.h"
+#include "host_command.h"
+#include "temp_sensor/temp_sensor.h"
+
+#define CPRINTS(format, args...) cprints(CC_THERMAL, format, ##args)
+#define CPRINTF(format, args...) cprintf(CC_THERMAL, format, ##args)
+
+#define TEMP_AMB TEMP_SENSOR_ID(DT_NODELABEL(temp_sensor_amb))
+
+static int last_amb_temp = -1;
+
+/* Set SCI event to host for temperature change */
+static void detect_temp_change(void)
+{
+ int t, rv;
+
+ rv = temp_sensor_read(TEMP_AMB, &t);
+ if (rv == EC_SUCCESS) {
+ if (last_amb_temp != t) {
+ last_amb_temp = t;
+ host_set_single_event(EC_HOST_EVENT_THERMAL_THRESHOLD);
+ }
+ } else if (rv == EC_ERROR_INVAL) {
+ CPRINTS("Temp sensor: Invalid id");
+ }
+}
+DECLARE_HOOK(HOOK_SECOND, detect_temp_change, HOOK_PRIO_TEMP_SENSOR_DONE);