Skip to content

Commit feb69bc

Browse files
Ye Zhangdlezcano
authored andcommitted
thermal/drivers/rockchip: Support RK3576 SoC in the thermal driver
The RK3576 SoC has six TS-ADC channels: TOP, BIG_CORE, LITTLE_CORE, DDR, NPU and GPU. Signed-off-by: Ye Zhang <ye.zhang@rock-chips.com> [ported to mainline, reworded commit message] Signed-off-by: Nicolas Frattaroli <nicolas.frattaroli@collabora.com> Reviewed-by: Heiko Stuebner <heiko@sntech.de> Link: https://lore.kernel.org/r/20250610-rk3576-tsadc-upstream-v6-3-b6e9efbf1015@collabora.com Signed-off-by: Daniel Lezcano <daniel.lezcano@linaro.org>
1 parent 83f2ef0 commit feb69bc

1 file changed

Lines changed: 26 additions & 0 deletions

File tree

drivers/thermal/rockchip_thermal.c

Lines changed: 26 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1284,6 +1284,28 @@ static const struct rockchip_tsadc_chip rk3568_tsadc_data = {
12841284
},
12851285
};
12861286

1287+
static const struct rockchip_tsadc_chip rk3576_tsadc_data = {
1288+
/* top, big_core, little_core, ddr, npu, gpu */
1289+
.chn_offset = 0,
1290+
.chn_num = 6, /* six channels for tsadc */
1291+
.tshut_mode = TSHUT_MODE_GPIO, /* default TSHUT via GPIO give PMIC */
1292+
.tshut_polarity = TSHUT_LOW_ACTIVE, /* default TSHUT LOW ACTIVE */
1293+
.tshut_temp = 95000,
1294+
.initialize = rk_tsadcv8_initialize,
1295+
.irq_ack = rk_tsadcv4_irq_ack,
1296+
.control = rk_tsadcv4_control,
1297+
.get_temp = rk_tsadcv4_get_temp,
1298+
.set_alarm_temp = rk_tsadcv3_alarm_temp,
1299+
.set_tshut_temp = rk_tsadcv3_tshut_temp,
1300+
.set_tshut_mode = rk_tsadcv4_tshut_mode,
1301+
.table = {
1302+
.id = rk3588_code_table,
1303+
.length = ARRAY_SIZE(rk3588_code_table),
1304+
.data_mask = TSADCV4_DATA_MASK,
1305+
.mode = ADC_INCREMENT,
1306+
},
1307+
};
1308+
12871309
static const struct rockchip_tsadc_chip rk3588_tsadc_data = {
12881310
/* top, big_core0, big_core1, little_core, center, gpu, npu */
12891311
.chn_offset = 0,
@@ -1342,6 +1364,10 @@ static const struct of_device_id of_rockchip_thermal_match[] = {
13421364
.compatible = "rockchip,rk3568-tsadc",
13431365
.data = (void *)&rk3568_tsadc_data,
13441366
},
1367+
{
1368+
.compatible = "rockchip,rk3576-tsadc",
1369+
.data = (void *)&rk3576_tsadc_data,
1370+
},
13451371
{
13461372
.compatible = "rockchip,rk3588-tsadc",
13471373
.data = (void *)&rk3588_tsadc_data,

0 commit comments

Comments
 (0)