mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-09-18 22:14:16 +00:00
pwm: sophgo-sg2042: Reorganize the code structure
As the driver logic can be used in both SG2042 and SG2044, it will be better to reorganize the code structure. Reviewed-by: Chen Wang <unicorn_wang@outlook.com> Tested-by: Chen Wang <unicorn_wang@outlook.com> Signed-off-by: Longbin Li <looong.bin@gmail.com> Link: https://lore.kernel.org/r/20250528101139.28702-3-looong.bin@gmail.com Signed-off-by: Uwe Kleine-König <ukleinek@kernel.org>
This commit is contained in:
parent
2b66b67530
commit
8c805dfafd
1 changed files with 37 additions and 15 deletions
|
@ -53,6 +53,10 @@ struct sg2042_pwm_ddata {
|
||||||
unsigned long clk_rate_hz;
|
unsigned long clk_rate_hz;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct sg2042_chip_data {
|
||||||
|
const struct pwm_ops ops;
|
||||||
|
};
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* period_ticks: PERIOD
|
* period_ticks: PERIOD
|
||||||
* hlperiod_ticks: HLPERIOD
|
* hlperiod_ticks: HLPERIOD
|
||||||
|
@ -66,21 +70,13 @@ static void pwm_sg2042_config(struct sg2042_pwm_ddata *ddata, unsigned int chan,
|
||||||
writel(hlperiod_ticks, base + SG2042_PWM_HLPERIOD(chan));
|
writel(hlperiod_ticks, base + SG2042_PWM_HLPERIOD(chan));
|
||||||
}
|
}
|
||||||
|
|
||||||
static int pwm_sg2042_apply(struct pwm_chip *chip, struct pwm_device *pwm,
|
static void pwm_sg2042_set_dutycycle(struct pwm_chip *chip, struct pwm_device *pwm,
|
||||||
const struct pwm_state *state)
|
const struct pwm_state *state)
|
||||||
{
|
{
|
||||||
struct sg2042_pwm_ddata *ddata = pwmchip_get_drvdata(chip);
|
struct sg2042_pwm_ddata *ddata = pwmchip_get_drvdata(chip);
|
||||||
u32 hlperiod_ticks;
|
u32 hlperiod_ticks;
|
||||||
u32 period_ticks;
|
u32 period_ticks;
|
||||||
|
|
||||||
if (state->polarity == PWM_POLARITY_INVERSED)
|
|
||||||
return -EINVAL;
|
|
||||||
|
|
||||||
if (!state->enabled) {
|
|
||||||
pwm_sg2042_config(ddata, pwm->hwpwm, 0, 0);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Duration of High level (duty_cycle) = HLPERIOD x Period_of_input_clk
|
* Duration of High level (duty_cycle) = HLPERIOD x Period_of_input_clk
|
||||||
* Duration of One Cycle (period) = PERIOD x Period_of_input_clk
|
* Duration of One Cycle (period) = PERIOD x Period_of_input_clk
|
||||||
|
@ -92,6 +88,22 @@ static int pwm_sg2042_apply(struct pwm_chip *chip, struct pwm_device *pwm,
|
||||||
pwm->hwpwm, period_ticks, hlperiod_ticks);
|
pwm->hwpwm, period_ticks, hlperiod_ticks);
|
||||||
|
|
||||||
pwm_sg2042_config(ddata, pwm->hwpwm, period_ticks, hlperiod_ticks);
|
pwm_sg2042_config(ddata, pwm->hwpwm, period_ticks, hlperiod_ticks);
|
||||||
|
}
|
||||||
|
|
||||||
|
static int pwm_sg2042_apply(struct pwm_chip *chip, struct pwm_device *pwm,
|
||||||
|
const struct pwm_state *state)
|
||||||
|
{
|
||||||
|
struct sg2042_pwm_ddata *ddata = pwmchip_get_drvdata(chip);
|
||||||
|
|
||||||
|
if (state->polarity == PWM_POLARITY_INVERSED)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (!state->enabled) {
|
||||||
|
pwm_sg2042_config(ddata, pwm->hwpwm, 0, 0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
pwm_sg2042_set_dutycycle(chip, pwm, state);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -123,13 +135,18 @@ static int pwm_sg2042_get_state(struct pwm_chip *chip, struct pwm_device *pwm,
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static const struct pwm_ops pwm_sg2042_ops = {
|
static const struct sg2042_chip_data sg2042_chip_data = {
|
||||||
.apply = pwm_sg2042_apply,
|
.ops = {
|
||||||
.get_state = pwm_sg2042_get_state,
|
.apply = pwm_sg2042_apply,
|
||||||
|
.get_state = pwm_sg2042_get_state,
|
||||||
|
},
|
||||||
};
|
};
|
||||||
|
|
||||||
static const struct of_device_id sg2042_pwm_ids[] = {
|
static const struct of_device_id sg2042_pwm_ids[] = {
|
||||||
{ .compatible = "sophgo,sg2042-pwm" },
|
{
|
||||||
|
.compatible = "sophgo,sg2042-pwm",
|
||||||
|
.data = &sg2042_chip_data
|
||||||
|
},
|
||||||
{ }
|
{ }
|
||||||
};
|
};
|
||||||
MODULE_DEVICE_TABLE(of, sg2042_pwm_ids);
|
MODULE_DEVICE_TABLE(of, sg2042_pwm_ids);
|
||||||
|
@ -137,12 +154,17 @@ MODULE_DEVICE_TABLE(of, sg2042_pwm_ids);
|
||||||
static int pwm_sg2042_probe(struct platform_device *pdev)
|
static int pwm_sg2042_probe(struct platform_device *pdev)
|
||||||
{
|
{
|
||||||
struct device *dev = &pdev->dev;
|
struct device *dev = &pdev->dev;
|
||||||
|
const struct sg2042_chip_data *chip_data;
|
||||||
struct sg2042_pwm_ddata *ddata;
|
struct sg2042_pwm_ddata *ddata;
|
||||||
struct reset_control *rst;
|
struct reset_control *rst;
|
||||||
struct pwm_chip *chip;
|
struct pwm_chip *chip;
|
||||||
struct clk *clk;
|
struct clk *clk;
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
chip_data = device_get_match_data(dev);
|
||||||
|
if (!chip_data)
|
||||||
|
return -ENODEV;
|
||||||
|
|
||||||
chip = devm_pwmchip_alloc(dev, SG2042_PWM_CHANNELNUM, sizeof(*ddata));
|
chip = devm_pwmchip_alloc(dev, SG2042_PWM_CHANNELNUM, sizeof(*ddata));
|
||||||
if (IS_ERR(chip))
|
if (IS_ERR(chip))
|
||||||
return PTR_ERR(chip);
|
return PTR_ERR(chip);
|
||||||
|
@ -170,7 +192,7 @@ static int pwm_sg2042_probe(struct platform_device *pdev)
|
||||||
if (IS_ERR(rst))
|
if (IS_ERR(rst))
|
||||||
return dev_err_probe(dev, PTR_ERR(rst), "Failed to get reset\n");
|
return dev_err_probe(dev, PTR_ERR(rst), "Failed to get reset\n");
|
||||||
|
|
||||||
chip->ops = &pwm_sg2042_ops;
|
chip->ops = &chip_data->ops;
|
||||||
chip->atomic = true;
|
chip->atomic = true;
|
||||||
|
|
||||||
ret = devm_pwmchip_add(dev, chip);
|
ret = devm_pwmchip_add(dev, chip);
|
||||||
|
|
Loading…
Add table
Reference in a new issue