Lines Matching +full:motor +full:- +full:driver
1 // SPDX-License-Identifier: GPL-2.0+
3 * GPD Pocket fan controller driver
9 #include <linux/devm-helpers.h>
57 if (speed == fan->last_speed) in gpd_pocket_fan_set_speed()
60 gpiod_direction_output(fan->gpio0, !!(speed & 1)); in gpd_pocket_fan_set_speed()
61 gpiod_direction_output(fan->gpio1, !!(speed & 2)); in gpd_pocket_fan_set_speed()
63 fan->last_speed = speed; in gpd_pocket_fan_set_speed()
80 if (thermal_zone_get_temp(fan->dts0, &t0) || in gpd_pocket_fan_worker()
81 thermal_zone_get_temp(fan->dts1, &t1)) { in gpd_pocket_fan_worker()
82 dev_warn(fan->dev, "Error getting temperature\n"); in gpd_pocket_fan_worker()
89 speed = fan->last_speed; in gpd_pocket_fan_worker()
102 if (temp <= (temp_limits[i] - hysteresis)) in gpd_pocket_fan_worker()
108 if (fan->last_speed <= 0 && speed) in gpd_pocket_fan_worker()
109 speed = MAX_SPEED; /* kick start motor */ in gpd_pocket_fan_worker()
115 queue_delayed_work(system_wq, &fan->work, in gpd_pocket_fan_worker()
121 fan->last_speed = -1; in gpd_pocket_fan_force_update()
122 mod_delayed_work(system_wq, &fan->work, 0); in gpd_pocket_fan_force_update()
132 dev_err(&pdev->dev, "Invalid temp-limit %d (must be between 20000 and 90000)\n", in gpd_pocket_fan_probe()
141 dev_err(&pdev->dev, "Invalid hysteresis %d (must be between 1000 and 10000)\n", in gpd_pocket_fan_probe()
146 dev_err(&pdev->dev, "Invalid speed_on_ac %d (must be between 0 and 3)\n", in gpd_pocket_fan_probe()
151 fan = devm_kzalloc(&pdev->dev, sizeof(*fan), GFP_KERNEL); in gpd_pocket_fan_probe()
153 return -ENOMEM; in gpd_pocket_fan_probe()
155 fan->dev = &pdev->dev; in gpd_pocket_fan_probe()
156 ret = devm_delayed_work_autocancel(&pdev->dev, &fan->work, in gpd_pocket_fan_probe()
162 fan->dts0 = thermal_zone_get_zone_by_name("soc_dts0"); in gpd_pocket_fan_probe()
163 if (IS_ERR(fan->dts0)) in gpd_pocket_fan_probe()
164 return -EPROBE_DEFER; in gpd_pocket_fan_probe()
166 fan->dts1 = thermal_zone_get_zone_by_name("soc_dts1"); in gpd_pocket_fan_probe()
167 if (IS_ERR(fan->dts1)) in gpd_pocket_fan_probe()
168 return -EPROBE_DEFER; in gpd_pocket_fan_probe()
170 fan->gpio0 = devm_gpiod_get_index(fan->dev, NULL, 0, GPIOD_ASIS); in gpd_pocket_fan_probe()
171 if (IS_ERR(fan->gpio0)) in gpd_pocket_fan_probe()
172 return PTR_ERR(fan->gpio0); in gpd_pocket_fan_probe()
174 fan->gpio1 = devm_gpiod_get_index(fan->dev, NULL, 1, GPIOD_ASIS); in gpd_pocket_fan_probe()
175 if (IS_ERR(fan->gpio1)) in gpd_pocket_fan_probe()
176 return PTR_ERR(fan->gpio1); in gpd_pocket_fan_probe()
189 cancel_delayed_work_sync(&fan->work); in gpd_pocket_fan_suspend()
214 .driver = {
223 MODULE_DESCRIPTION("GPD pocket fan driver");