Commit 1865913d authored by Uwe Kleine-König's avatar Uwe Kleine-König Committed by Hans Verkuil

media: meson-ir-tx: Drop usage of platform_driver_probe()

The benefit of platform_driver_probe() here is only that the probe
function can be discarded after the driver is loaded. For an ARCH=arm
allmodconfig that's 952 bytes, for an allnoconfig + IR_MESON_TX=y it's
only 452 bytes. The downside is that the driver isn't dynamically
bindable and unbindable.

There are considerations to drop platform_driver_probe() as a concept
that isn't relevant any more today. It comes with an added complexity
that makes many users hold it wrong. (E.g. this driver didn't benefit
as much as it could as of v6.6-rc1 as meson_irtx_remove() could have
been marked with __exit.)

The advantages are not that relevant any more today, so convert this
driver to an ordinary platform driver.
Signed-off-by: default avatarUwe Kleine-König <u.kleine-koenig@pengutronix.de>
Signed-off-by: default avatarSean Young <sean@mess.org>
Signed-off-by: default avatarHans Verkuil <hverkuil-cisco@xs4all.nl>
parent 9af7c980
...@@ -305,7 +305,7 @@ static int meson_irtx_mod_clock_probe(struct meson_irtx *ir, ...@@ -305,7 +305,7 @@ static int meson_irtx_mod_clock_probe(struct meson_irtx *ir,
return 0; return 0;
} }
static int __init meson_irtx_probe(struct platform_device *pdev) static int meson_irtx_probe(struct platform_device *pdev)
{ {
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct meson_irtx *ir; struct meson_irtx *ir;
...@@ -375,13 +375,13 @@ static const struct of_device_id meson_irtx_dt_match[] = { ...@@ -375,13 +375,13 @@ static const struct of_device_id meson_irtx_dt_match[] = {
MODULE_DEVICE_TABLE(of, meson_irtx_dt_match); MODULE_DEVICE_TABLE(of, meson_irtx_dt_match);
static struct platform_driver meson_irtx_pd = { static struct platform_driver meson_irtx_pd = {
.probe = meson_irtx_probe,
.driver = { .driver = {
.name = DRIVER_NAME, .name = DRIVER_NAME,
.of_match_table = meson_irtx_dt_match, .of_match_table = meson_irtx_dt_match,
}, },
}; };
module_platform_driver(meson_irtx_pd);
module_platform_driver_probe(meson_irtx_pd, meson_irtx_probe);
MODULE_DESCRIPTION("Meson IR TX driver"); MODULE_DESCRIPTION("Meson IR TX driver");
MODULE_AUTHOR("Viktor Prutyanov <viktor.prutyanov@phystech.edu>"); MODULE_AUTHOR("Viktor Prutyanov <viktor.prutyanov@phystech.edu>");
......
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