Lines Matching +full:irq +full:- +full:polling +full:- +full:delay +full:- +full:passive +full:- +full:ms

1 // SPDX-License-Identifier: GPL-2.0-or-later
7 /* When over-temperature is reached, an interrupt from the device will be
14 * These uevents are intended to indicate non-invasive temperature control
17 * the IRQ is re-enabled so the start of a new over-temperature event can
33 /* Minimum, maximum and default polling millisecond periods are provided
56 int irq; member
66 unsigned long delay; in da9062_thermal_poll_on() local
71 ret = regmap_write(thermal->hw->regmap, in da9062_thermal_poll_on()
75 dev_err(thermal->dev, in da9062_thermal_poll_on()
81 * If over-temperature, then this status will be true. in da9062_thermal_poll_on()
82 * If not over-temperature, this status will be false. in da9062_thermal_poll_on()
84 ret = regmap_read(thermal->hw->regmap, in da9062_thermal_poll_on()
88 dev_err(thermal->dev, in da9062_thermal_poll_on()
94 mutex_lock(&thermal->lock); in da9062_thermal_poll_on()
95 thermal->temperature = DA9062_MILLI_CELSIUS(125); in da9062_thermal_poll_on()
96 mutex_unlock(&thermal->lock); in da9062_thermal_poll_on()
97 thermal_zone_device_update(thermal->zone, in da9062_thermal_poll_on()
103 delay = round_jiffies(msecs_to_jiffies(pp_tmp)); in da9062_thermal_poll_on()
104 queue_delayed_work(system_freezable_wq, &thermal->work, delay); in da9062_thermal_poll_on()
108 mutex_lock(&thermal->lock); in da9062_thermal_poll_on()
109 thermal->temperature = DA9062_MILLI_CELSIUS(0); in da9062_thermal_poll_on()
110 mutex_unlock(&thermal->lock); in da9062_thermal_poll_on()
111 thermal_zone_device_update(thermal->zone, in da9062_thermal_poll_on()
115 enable_irq(thermal->irq); in da9062_thermal_poll_on()
118 static irqreturn_t da9062_thermal_irq_handler(int irq, void *data) in da9062_thermal_irq_handler() argument
122 disable_irq_nosync(thermal->irq); in da9062_thermal_irq_handler()
123 queue_delayed_work(system_freezable_wq, &thermal->work, 0); in da9062_thermal_irq_handler()
133 mutex_lock(&thermal->lock); in da9062_thermal_get_temp()
134 *temp = thermal->temperature; in da9062_thermal_get_temp()
135 mutex_unlock(&thermal->lock); in da9062_thermal_get_temp()
149 .name = "da9062-thermal",
153 { .compatible = "dlg,da9062-thermal", .data = &da9062_config },
161 struct da9062 *chip = dev_get_drvdata(pdev->dev.parent); in da9062_thermal_probe()
167 pdev->dev.of_node); in da9062_thermal_probe()
169 return -ENXIO; in da9062_thermal_probe()
171 if (pdev->dev.of_node) { in da9062_thermal_probe()
172 if (!of_property_read_u32(pdev->dev.of_node, in da9062_thermal_probe()
173 "polling-delay-passive", in da9062_thermal_probe()
177 dev_warn(&pdev->dev, in da9062_thermal_probe()
178 "Out-of-range polling period %d ms\n", in da9062_thermal_probe()
185 thermal = devm_kzalloc(&pdev->dev, sizeof(struct da9062_thermal), in da9062_thermal_probe()
188 ret = -ENOMEM; in da9062_thermal_probe()
192 thermal->config = match->data; in da9062_thermal_probe()
193 thermal->hw = chip; in da9062_thermal_probe()
194 thermal->dev = &pdev->dev; in da9062_thermal_probe()
196 INIT_DELAYED_WORK(&thermal->work, da9062_thermal_poll_on); in da9062_thermal_probe()
197 mutex_init(&thermal->lock); in da9062_thermal_probe()
199 thermal->zone = thermal_zone_device_register_with_trips(thermal->config->name, in da9062_thermal_probe()
203 if (IS_ERR(thermal->zone)) { in da9062_thermal_probe()
204 dev_err(&pdev->dev, "Cannot register thermal zone device\n"); in da9062_thermal_probe()
205 ret = PTR_ERR(thermal->zone); in da9062_thermal_probe()
208 ret = thermal_zone_device_enable(thermal->zone); in da9062_thermal_probe()
210 dev_err(&pdev->dev, "Cannot enable thermal zone device\n"); in da9062_thermal_probe()
214 dev_dbg(&pdev->dev, in da9062_thermal_probe()
215 "TJUNC temperature polling period set at %d ms\n", pp_tmp); in da9062_thermal_probe()
221 thermal->irq = ret; in da9062_thermal_probe()
223 ret = request_threaded_irq(thermal->irq, NULL, in da9062_thermal_probe()
228 dev_err(&pdev->dev, in da9062_thermal_probe()
229 "Failed to request thermal device IRQ.\n"); in da9062_thermal_probe()
237 thermal_zone_device_unregister(thermal->zone); in da9062_thermal_probe()
246 free_irq(thermal->irq, thermal); in da9062_thermal_remove()
247 cancel_delayed_work_sync(&thermal->work); in da9062_thermal_remove()
248 thermal_zone_device_unregister(thermal->zone); in da9062_thermal_remove()
255 .name = "da9062-thermal",
265 MODULE_ALIAS("platform:da9062-thermal");