thermal/drivers/sun8i: Add support for H616 THS controller
authorMartin Botka <martin.botka@somainline.org>
Mon, 19 Feb 2024 15:36:38 +0000 (15:36 +0000)
committerDaniel Lezcano <daniel.lezcano@linaro.org>
Mon, 11 Mar 2024 16:14:46 +0000 (17:14 +0100)
Add support for the thermal sensor found in H616 SoCs, is the same as
the H6 thermal sensor controller, but with four sensors.
Also the registers readings are wrong, unless a bit in the first SYS_CFG
register cleared, so set exercise the SRAM regmap to take care of that.

Signed-off-by: Martin Botka <martin.botka@somainline.org>
Signed-off-by: Andre Przywara <andre.przywara@arm.com>
Acked-by: Vasily Khoruzhick <anarsoul@gmail.com>
Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
Link: https://lore.kernel.org/r/20240219153639.179814-7-andre.przywara@arm.com
drivers/thermal/sun8i_thermal.c

index c157e4fbf963b72a33f661b02011682015731c82..63a7d2df3d6ec5ff3bb0e5e330318ec63f09323a 100644 (file)
@@ -684,6 +684,20 @@ static const struct ths_thermal_chip sun20i_d1_ths = {
        .calc_temp = sun8i_ths_calc_temp,
 };
 
+static const struct ths_thermal_chip sun50i_h616_ths = {
+       .sensor_num = 4,
+       .has_bus_clk_reset = true,
+       .needs_sram = true,
+       .ft_deviation = 8000,
+       .offset = 263655,
+       .scale = 810,
+       .temp_data_base = SUN50I_H6_THS_TEMP_DATA,
+       .calibrate = sun50i_h6_ths_calibrate,
+       .init = sun50i_h6_thermal_init,
+       .irq_ack = sun50i_h6_irq_ack,
+       .calc_temp = sun8i_ths_calc_temp,
+};
+
 static const struct of_device_id of_ths_match[] = {
        { .compatible = "allwinner,sun8i-a83t-ths", .data = &sun8i_a83t_ths },
        { .compatible = "allwinner,sun8i-h3-ths", .data = &sun8i_h3_ths },
@@ -693,6 +707,7 @@ static const struct of_device_id of_ths_match[] = {
        { .compatible = "allwinner,sun50i-h5-ths", .data = &sun50i_h5_ths },
        { .compatible = "allwinner,sun50i-h6-ths", .data = &sun50i_h6_ths },
        { .compatible = "allwinner,sun20i-d1-ths", .data = &sun20i_d1_ths },
+       { .compatible = "allwinner,sun50i-h616-ths", .data = &sun50i_h616_ths },
        { /* sentinel */ },
 };
 MODULE_DEVICE_TABLE(of, of_ths_match);