linux/drivers/thermal/imx_thermal.c

// SPDX-License-Identifier: GPL-2.0
//
// Copyright 2013 Freescale Semiconductor, Inc.

#include <linux/clk.h>
#include <linux/cpufreq.h>
#include <linux/cpu_cooling.h>
#include <linux/delay.h>
#include <linux/interrupt.h>
#include <linux/io.h>
#include <linux/mfd/syscon.h>
#include <linux/module.h>
#include <linux/of.h>
#include <linux/platform_device.h>
#include <linux/regmap.h>
#include <linux/thermal.h>
#include <linux/nvmem-consumer.h>
#include <linux/pm_runtime.h>

#define REG_SET
#define REG_CLR
#define REG_TOG

/* i.MX6 specific */
#define IMX6_MISC0
#define IMX6_MISC0_REFTOP_SELBIASOFF
#define IMX6_MISC1
#define IMX6_MISC1_IRQ_TEMPHIGH
/* Below LOW and PANIC bits are only for TEMPMON_IMX6SX */
#define IMX6_MISC1_IRQ_TEMPLOW
#define IMX6_MISC1_IRQ_TEMPPANIC

#define IMX6_TEMPSENSE0
#define IMX6_TEMPSENSE0_ALARM_VALUE_SHIFT
#define IMX6_TEMPSENSE0_ALARM_VALUE_MASK
#define IMX6_TEMPSENSE0_TEMP_CNT_SHIFT
#define IMX6_TEMPSENSE0_TEMP_CNT_MASK
#define IMX6_TEMPSENSE0_FINISHED
#define IMX6_TEMPSENSE0_MEASURE_TEMP
#define IMX6_TEMPSENSE0_POWER_DOWN

#define IMX6_TEMPSENSE1
#define IMX6_TEMPSENSE1_MEASURE_FREQ
#define IMX6_TEMPSENSE1_MEASURE_FREQ_SHIFT

#define OCOTP_MEM0
#define OCOTP_ANA1

/* Below TEMPSENSE2 is only for TEMPMON_IMX6SX */
#define IMX6_TEMPSENSE2
#define IMX6_TEMPSENSE2_LOW_VALUE_SHIFT
#define IMX6_TEMPSENSE2_LOW_VALUE_MASK
#define IMX6_TEMPSENSE2_PANIC_VALUE_SHIFT
#define IMX6_TEMPSENSE2_PANIC_VALUE_MASK

/* i.MX7 specific */
#define IMX7_ANADIG_DIGPROG
#define IMX7_TEMPSENSE0
#define IMX7_TEMPSENSE0_PANIC_ALARM_SHIFT
#define IMX7_TEMPSENSE0_PANIC_ALARM_MASK
#define IMX7_TEMPSENSE0_HIGH_ALARM_SHIFT
#define IMX7_TEMPSENSE0_HIGH_ALARM_MASK
#define IMX7_TEMPSENSE0_LOW_ALARM_SHIFT
#define IMX7_TEMPSENSE0_LOW_ALARM_MASK

#define IMX7_TEMPSENSE1
#define IMX7_TEMPSENSE1_MEASURE_FREQ_SHIFT
#define IMX7_TEMPSENSE1_MEASURE_FREQ_MASK
#define IMX7_TEMPSENSE1_FINISHED
#define IMX7_TEMPSENSE1_MEASURE_TEMP
#define IMX7_TEMPSENSE1_POWER_DOWN
#define IMX7_TEMPSENSE1_TEMP_VALUE_SHIFT
#define IMX7_TEMPSENSE1_TEMP_VALUE_MASK

/* The driver supports 1 passive trip point and 1 critical trip point */
enum imx_thermal_trip {};

#define IMX_POLLING_DELAY
#define IMX_PASSIVE_DELAY

#define TEMPMON_IMX6Q
#define TEMPMON_IMX6SX
#define TEMPMON_IMX7D

struct thermal_soc_data {};

static struct thermal_trip trips[] =;

static struct thermal_soc_data thermal_imx6q_data =;

static struct thermal_soc_data thermal_imx6sx_data =;

static struct thermal_soc_data thermal_imx7d_data =;

struct imx_thermal_data {};

static void imx_set_panic_temp(struct imx_thermal_data *data,
			       int panic_temp)
{}

static void imx_set_alarm_temp(struct imx_thermal_data *data,
			       int alarm_temp)
{}

static int imx_get_temp(struct thermal_zone_device *tz, int *temp)
{}

static int imx_change_mode(struct thermal_zone_device *tz,
			   enum thermal_device_mode mode)
{}

static int imx_set_trip_temp(struct thermal_zone_device *tz,
			     const struct thermal_trip *trip, int temp)
{}

static bool imx_should_bind(struct thermal_zone_device *tz,
			    const struct thermal_trip *trip,
			    struct thermal_cooling_device *cdev,
			    struct cooling_spec *c)
{}

static struct thermal_zone_device_ops imx_tz_ops =;

static int imx_init_calib(struct platform_device *pdev, u32 ocotp_ana1)
{}

static void imx_init_temp_grade(struct platform_device *pdev, u32 ocotp_mem0)
{}

static int imx_init_from_tempmon_data(struct platform_device *pdev)
{}

static int imx_init_from_nvmem_cells(struct platform_device *pdev)
{}

static irqreturn_t imx_thermal_alarm_irq(int irq, void *dev)
{}

static irqreturn_t imx_thermal_alarm_irq_thread(int irq, void *dev)
{}

static const struct of_device_id of_imx_thermal_match[] =;
MODULE_DEVICE_TABLE(of, of_imx_thermal_match);

#ifdef CONFIG_CPU_FREQ
/*
 * Create cooling device in case no #cooling-cells property is available in
 * CPU node
 */
static int imx_thermal_register_legacy_cooling(struct imx_thermal_data *data)
{}

static void imx_thermal_unregister_legacy_cooling(struct imx_thermal_data *data)
{}

#else

static inline int imx_thermal_register_legacy_cooling(struct imx_thermal_data *data)
{
	return 0;
}

static inline void imx_thermal_unregister_legacy_cooling(struct imx_thermal_data *data)
{
}
#endif

static int imx_thermal_probe(struct platform_device *pdev)
{}

static void imx_thermal_remove(struct platform_device *pdev)
{}

static int imx_thermal_suspend(struct device *dev)
{}

static int imx_thermal_resume(struct device *dev)
{}

static int imx_thermal_runtime_suspend(struct device *dev)
{}

static int imx_thermal_runtime_resume(struct device *dev)
{}

static const struct dev_pm_ops imx_thermal_pm_ops =;

static struct platform_driver imx_thermal =;
module_platform_driver();

MODULE_AUTHOR();
MODULE_DESCRIPTION();
MODULE_LICENSE();
MODULE_ALIAS();