dev_get_drvdata() and device_get_match_data() can already deal with both OF and non-OF match data, so at91_pinctrl_get_driver_data only adds some unneeded complexity. Remove it and while at it switch to the less error-prone device_get_match_data.
Signed-off-by: Ahmad Fatoum <a.fat...@pengutronix.de> --- drivers/pinctrl/pinctrl-at91.c | 27 +++------------------------ 1 file changed, 3 insertions(+), 24 deletions(-) diff --git a/drivers/pinctrl/pinctrl-at91.c b/drivers/pinctrl/pinctrl-at91.c index 25b4d084ed6d..eb0ce648095d 100644 --- a/drivers/pinctrl/pinctrl-at91.c +++ b/drivers/pinctrl/pinctrl-at91.c @@ -26,13 +26,13 @@ struct at91_pinctrl { struct pinctrl_device pctl; - struct at91_pinctrl_mux_ops *ops; + const struct at91_pinctrl_mux_ops *ops; }; struct at91_gpio_chip { struct gpio_chip chip; void __iomem *regbase; /* PIO bank virtual address */ - struct at91_pinctrl_mux_ops *ops; /* ops */ + const struct at91_pinctrl_mux_ops *ops; /* ops */ }; #define MAX_GPIO_BANKS 5 @@ -384,27 +384,6 @@ static struct of_device_id at91_pinctrl_dt_ids[] = { }; MODULE_DEVICE_TABLE(of, at91_pinctrl_dt_ids); -static struct at91_pinctrl_mux_ops *at91_pinctrl_get_driver_data(struct device *dev) -{ - struct at91_pinctrl_mux_ops *ops_data = NULL; - int rc; - - if (dev->of_node) { - const struct of_device_id *match; - match = of_match_node(at91_pinctrl_dt_ids, dev->of_node); - if (!match) - ops_data = NULL; - else - ops_data = (struct at91_pinctrl_mux_ops *)match->data; - } else { - rc = dev_get_drvdata(dev, (const void **)&ops_data); - if (rc) - ops_data = NULL; - } - - return ops_data; -} - static int at91_pinctrl_set_conf(struct at91_pinctrl *info, unsigned int pin_num, unsigned int mux, unsigned int conf) { unsigned int mask; @@ -492,7 +471,7 @@ static int at91_pinctrl_probe(struct device *dev) info = xzalloc(sizeof(struct at91_pinctrl)); - info->ops = at91_pinctrl_get_driver_data(dev); + info->ops = device_get_match_data(dev); if (!info->ops) { dev_err(dev, "failed to retrieve driver data\n"); return -ENODEV; -- 2.39.5