Lines Matching +full:lgm +full:- +full:clk

1 // SPDX-License-Identifier: GPL-2.0
6 * - The hardware supports fixed period & configures only 2-wire mode.
7 * - Supports normal polarity. Does not support changing polarity.
8 * - When PWM is disabled, output of PWM will become 0(inactive). It doesn't
10 * - When duty cycle is changed, PWM output may be a mix of previous setting
13 * - It is a dedicated PWM fan controller. There are no other consumers for
17 #include <linux/clk.h>
36 #define LGM_PWM_MAX_RPM (BIT(16) - 1)
38 #define LGM_PWM_MAX_DUTY_CYCLE (BIT(8) - 1)
58 struct regmap *regmap = pc->regmap; in lgm_pwm_enable()
72 if (state->polarity != PWM_POLARITY_NORMAL || state->period < pc->period) in lgm_pwm_apply()
73 return -EINVAL; in lgm_pwm_apply()
75 if (!state->enabled) in lgm_pwm_apply()
78 duty_cycle = min_t(u64, state->duty_cycle, pc->period); in lgm_pwm_apply()
79 val = duty_cycle * LGM_PWM_MAX_DUTY_CYCLE / pc->period; in lgm_pwm_apply()
81 ret = regmap_update_bits(pc->regmap, LGM_PWM_FAN_CON0, LGM_PWM_FAN_DC_MSK, in lgm_pwm_apply()
95 state->enabled = regmap_test_bits(pc->regmap, LGM_PWM_FAN_CON0, in lgm_pwm_get_state()
97 state->polarity = PWM_POLARITY_NORMAL; in lgm_pwm_get_state()
98 state->period = pc->period; /* fixed period */ in lgm_pwm_get_state()
100 regmap_read(pc->regmap, LGM_PWM_FAN_CON0, &val); in lgm_pwm_get_state()
102 state->duty_cycle = DIV_ROUND_UP(duty * pc->period, LGM_PWM_MAX_DUTY_CYCLE); in lgm_pwm_get_state()
113 struct regmap *regmap = pc->regmap; in lgm_pwm_init()
117 pc->period = LGM_PWM_PERIOD_2WIRE_NS; in lgm_pwm_init()
132 struct clk *clk = data; in lgm_clk_release() local
134 clk_disable_unprepare(clk); in lgm_clk_release()
137 static int lgm_clk_enable(struct device *dev, struct clk *clk) in lgm_clk_enable() argument
141 ret = clk_prepare_enable(clk); in lgm_clk_enable()
145 return devm_add_action_or_reset(dev, lgm_clk_release, clk); in lgm_clk_enable()
168 struct device *dev = &pdev->dev; in lgm_pwm_probe()
172 struct clk *clk; in lgm_pwm_probe() local
177 return -ENOMEM; in lgm_pwm_probe()
183 pc->regmap = devm_regmap_init_mmio(dev, io_base, &lgm_pwm_regmap_config); in lgm_pwm_probe()
184 if (IS_ERR(pc->regmap)) in lgm_pwm_probe()
185 return dev_err_probe(dev, PTR_ERR(pc->regmap), in lgm_pwm_probe()
188 clk = devm_clk_get(dev, NULL); in lgm_pwm_probe()
189 if (IS_ERR(clk)) in lgm_pwm_probe()
190 return dev_err_probe(dev, PTR_ERR(clk), "failed to get clock\n"); in lgm_pwm_probe()
192 ret = lgm_clk_enable(dev, clk); in lgm_pwm_probe()
205 pc->chip.dev = dev; in lgm_pwm_probe()
206 pc->chip.ops = &lgm_pwm_ops; in lgm_pwm_probe()
207 pc->chip.npwm = 1; in lgm_pwm_probe()
211 ret = devm_pwmchip_add(dev, &pc->chip); in lgm_pwm_probe()
219 { .compatible = "intel,lgm-pwm" },
226 .name = "intel-pwm",