Commit 7b4c7c56 authored by Andre Przywara's avatar Andre Przywara Committed by Thierry Reding

pwm: sun4i: Simplify controller mapping

At the moment we assign our supported compatible strings to a respective
instance of our sun4i_pwm_data structure, even though some of them
are the same.
To avoid further clutter, split out the three different combinations of
features we have at the moment and name them accordingly.
This should make it more obvious which compatible string to use for new
SoCs.
Signed-off-by: default avatarAndre Przywara <andre.przywara@arm.com>
Acked-by: default avatarMaxime Ripard <maxime.ripard@bootlin.com>
Signed-off-by: default avatarThierry Reding <thierry.reding@gmail.com>
parent 6a89bb6c
...@@ -312,27 +312,17 @@ static const struct pwm_ops sun4i_pwm_ops = { ...@@ -312,27 +312,17 @@ static const struct pwm_ops sun4i_pwm_ops = {
.owner = THIS_MODULE, .owner = THIS_MODULE,
}; };
static const struct sun4i_pwm_data sun4i_pwm_data_a10 = { static const struct sun4i_pwm_data sun4i_pwm_dual_nobypass = {
.has_prescaler_bypass = false, .has_prescaler_bypass = false,
.npwm = 2, .npwm = 2,
}; };
static const struct sun4i_pwm_data sun4i_pwm_data_a10s = { static const struct sun4i_pwm_data sun4i_pwm_dual_bypass = {
.has_prescaler_bypass = true, .has_prescaler_bypass = true,
.npwm = 2, .npwm = 2,
}; };
static const struct sun4i_pwm_data sun4i_pwm_data_a13 = { static const struct sun4i_pwm_data sun4i_pwm_single_bypass = {
.has_prescaler_bypass = true,
.npwm = 1,
};
static const struct sun4i_pwm_data sun4i_pwm_data_a20 = {
.has_prescaler_bypass = true,
.npwm = 2,
};
static const struct sun4i_pwm_data sun4i_pwm_data_h3 = {
.has_prescaler_bypass = true, .has_prescaler_bypass = true,
.npwm = 1, .npwm = 1,
}; };
...@@ -340,19 +330,19 @@ static const struct sun4i_pwm_data sun4i_pwm_data_h3 = { ...@@ -340,19 +330,19 @@ static const struct sun4i_pwm_data sun4i_pwm_data_h3 = {
static const struct of_device_id sun4i_pwm_dt_ids[] = { static const struct of_device_id sun4i_pwm_dt_ids[] = {
{ {
.compatible = "allwinner,sun4i-a10-pwm", .compatible = "allwinner,sun4i-a10-pwm",
.data = &sun4i_pwm_data_a10, .data = &sun4i_pwm_dual_nobypass,
}, { }, {
.compatible = "allwinner,sun5i-a10s-pwm", .compatible = "allwinner,sun5i-a10s-pwm",
.data = &sun4i_pwm_data_a10s, .data = &sun4i_pwm_dual_bypass,
}, { }, {
.compatible = "allwinner,sun5i-a13-pwm", .compatible = "allwinner,sun5i-a13-pwm",
.data = &sun4i_pwm_data_a13, .data = &sun4i_pwm_single_bypass,
}, { }, {
.compatible = "allwinner,sun7i-a20-pwm", .compatible = "allwinner,sun7i-a20-pwm",
.data = &sun4i_pwm_data_a20, .data = &sun4i_pwm_dual_bypass,
}, { }, {
.compatible = "allwinner,sun8i-h3-pwm", .compatible = "allwinner,sun8i-h3-pwm",
.data = &sun4i_pwm_data_h3, .data = &sun4i_pwm_single_bypass,
}, { }, {
/* sentinel */ /* sentinel */
}, },
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment