kernel_samsung_a53x/drivers/thermal/samsung/exynos_tmu.h
2024-06-15 16:02:09 -03:00

212 lines
6 KiB
C
Executable file

/*
* exynos_tmu.h - Samsung EXYNOS TMU (Thermal Management Unit)
*
* Copyright (C) 2011 Samsung Electronics
* Donggeun Kim <dg77.kim@samsung.com>
* Amit Daniel Kachhap <amit.daniel@samsung.com>
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program; if not, write to the Free Software
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
#ifndef _EXYNOS_TMU_H
#define _EXYNOS_TMU_H
#include <soc/samsung/cpu_cooling.h>
#include <soc/samsung/gpu_cooling.h>
#include <soc/samsung/isp_cooling.h>
#include <soc/samsung/exynos_pm_qos.h>
#include <soc/samsung/exynos-cpuhp.h>
#include <linux/kthread.h>
#define MCELSIUS 1000
#define EMERGENCY_THROTTLE_STAT 0x10
#define EMERGENCY_THROTTLE_STAT_1 0x10
#define EMERGENCY_THROTTLE_STAT_2 0x20
#define EMERGENCY_THROTTLE_STAT_3 0x40
enum exynos_tmu_boost_mode {
STANDBY_MODE,
BOOST_MODE,
THROTTLE_MODE,
BOOT_MODE,
AMBIENT_MODE,
AMBIENT_BOOT_MODE,
MODE_END
};
/* boost mode params */
struct exynos_boost_param {
bool use_boost;
s32 boost_mode_threshold;
s32 boost_mode_exit_threshold;
s32 throttle_mode_threshold;
ktime_t boost_mode_duration;
ktime_t throttle_mode_duration;
ktime_t last_boost_mode_updated;
ktime_t last_boost_time;
ktime_t sum_boost_time;
s32 throttle_mode_control_temp;
s32 throttle_mode_switch_on;
s32 throttle_mode_sustainable_power;
s32 boost_mode_control_temp;
s32 boost_mode_switch_on;
s32 boost_mode_sustainable_power;
s32 boost_mode_hp_in_threshold;
s32 boost_mode_hp_out_threshold;
s32 throttle_mode_dfs_temp;
s32 throttle_mode_hp_in_threshold;
s32 throttle_mode_hp_out_threshold;
s32 boost_threshold_cnt;
bool use_boost_sync;
s32 throttle_mode_trip_2_temp;
s32 throttle_mode_trip_3_temp;
s32 throttle_mode_trip_4_temp;
s32 boost_mode_trip_2_temp;
s32 boost_mode_trip_3_temp;
s32 boost_mode_trip_4_temp;
enum exynos_tmu_boost_mode boost_mode;
};
struct exynos_pi_param {
s64 err_integral;
int trip_switch_on;
int trip_control_temp;
u32 sustainable_power;
s32 k_po;
s32 k_pu;
s32 k_i;
s32 k_d;
s32 i_max;
s32 integral_cutoff;
s32 prev_err;
int polling_delay_on;
int polling_delay_off;
bool switched_on;
};
/**
* struct exynos_tmu_data : A structure to hold the private data of the TMU
driver
* @id: identifier of the one instance of the TMU controller.
* @base: base address of the single instance of the TMU controller.
* @irq: irq number of the TMU controller.
* @soc: id of the SOC type.
* @irq_work: pointer to the irq work structure.
* @lock: lock to implement synchronization.
* @regulator: pointer to the TMU regulator structure.
* @reg_conf: pointer to structure to register with core thermal.
* @ntrip: number of supported trip points.
* @tmu_initialize: SoC specific TMU initialization method
* @tmu_control: SoC specific TMU control method
* @tmu_read: SoC specific TMU temperature read method
* @tmu_set_emulation: SoC specific TMU emulation setting method
* @tmu_clear_irqs: SoC specific TMU interrupts clearing method
*/
struct exynos_tmu_data {
int id;
/* Throttle hotplug related variables */
bool hotplug_enable;
int hotplug_in_threshold;
int hotplug_out_threshold;
int limited_frequency;
int limited_threshold;
int limited_threshold_release;
int limited_frequency_2;
int limited_threshold_2;
int limited_threshold_release_2;
struct cpufreq_policy *policy;
struct freq_qos_request thermal_limit_request;
unsigned int limited;
void __iomem *base;
int irq;
struct kthread_worker thermal_worker;
struct kthread_work irq_work;
struct kthread_work hotplug_work;
struct mutex lock;
struct thermal_zone_device *tzd;
unsigned int ntrip;
bool enabled;
struct thermal_cooling_device *cool_dev;
struct list_head node;
char tmu_name[THERMAL_NAME_LENGTH + 1];
struct device_node *np;
struct cpumask cpu_domain;
bool is_cpu_hotplugged_out;
char cpuhp_name[THERMAL_NAME_LENGTH + 1];
int temperature;
bool use_pi_thermal;
bool use_sync_pi_thermal;
struct kthread_delayed_work pi_work;
struct exynos_pi_param *pi_param;
struct exynos_boost_param boost_param;
struct notifier_block nb;
atomic_t in_suspend;
int use_emergency_throttle;
int emergency_throttle;
int emergency_frequency;
int emergency_frequency_1;
int emergency_frequency_2;
int emergency_frequency_3;
struct freq_qos_request emergency_throttle_request;
ktime_t last_thermal_status_updated;
ktime_t thermal_status[3];
};
extern int exynos_build_static_power_table(struct device_node *np, int **var_table,
unsigned int *var_volt_size, unsigned int *var_temp_size, char *tz_name);
extern void exynos_tmu_set_boost_mode(struct exynos_tmu_data *data, enum exynos_tmu_boost_mode new_mode, bool from_amb);
extern struct exynos_tmu_data *exynos_tmu_get_data_from_tz(struct thermal_zone_device *tz);
#if IS_ENABLED(CONFIG_EXYNOS_ACPM_THERMAL)
#if defined(CONFIG_SOC_EXYNOS991) || defined(CONFIG_SOC_EXYNOS2100)
#define PMUREG_AUD_STATUS 0x1884
#define PMUREG_AUD_STATUS_MASK 0x1
#endif
#endif
#if IS_ENABLED(CONFIG_SND_SOC_SAMSUNG_ABOX)
extern bool abox_is_on(void);
#else
static inline bool abox_is_on(void)
{
return 0;
}
#endif
#if IS_ENABLED(CONFIG_ISP_THERMAL)
int exynos_isp_cooling_init(void);
#else
static inline int exynos_isp_cooling_init(void)
{
return 0;
}
#endif
#if IS_ENABLED(CONFIG_EXYNOS_ADV_TRACER)
int adv_tracer_s2d_get_enable(void);
int adv_tracer_s2d_set_enable(int en);
#else
#define adv_tracer_s2d_get_enable() do { } while (0)
#define adv_tracer_s2d_set_enable(a) do { } while (0)
#endif
#endif /* _EXYNOS_TMU_H */