Skip to content

Commit db410b2

Browse files
dgerlachrafaeljw
authored andcommitted
cpufreq: ti-cpufreq: Convert to module_platform_driver
ti-cpufreq will be responsible for calling dev_pm_opp_set_regulators on platforms that require AVS and ABB regulator support so we must be able to defer probe if regulators are not yet available, so change ti-cpufreq to be a module_platform_driver to allow for probe defer. Acked-by: Viresh Kumar <viresh.kumar@linaro.org> Signed-off-by: Dave Gerlach <d-gerlach@ti.com> Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
1 parent 92ce45f commit db410b2

File tree

1 file changed

+21
-2
lines changed

1 file changed

+21
-2
lines changed

drivers/cpufreq/ti-cpufreq.c

Lines changed: 21 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@
1717
#include <linux/cpu.h>
1818
#include <linux/io.h>
1919
#include <linux/mfd/syscon.h>
20+
#include <linux/module.h>
2021
#include <linux/init.h>
2122
#include <linux/of.h>
2223
#include <linux/of_platform.h>
@@ -195,7 +196,7 @@ static const struct of_device_id ti_cpufreq_of_match[] = {
195196
{},
196197
};
197198

198-
static int ti_cpufreq_init(void)
199+
static int ti_cpufreq_probe(struct platform_device *pdev)
199200
{
200201
u32 version[VERSION_COUNT];
201202
struct device_node *np;
@@ -269,4 +270,22 @@ static int ti_cpufreq_init(void)
269270

270271
return ret;
271272
}
272-
device_initcall(ti_cpufreq_init);
273+
274+
static int ti_cpufreq_init(void)
275+
{
276+
platform_device_register_simple("ti-cpufreq", -1, NULL, 0);
277+
return 0;
278+
}
279+
module_init(ti_cpufreq_init);
280+
281+
static struct platform_driver ti_cpufreq_driver = {
282+
.probe = ti_cpufreq_probe,
283+
.driver = {
284+
.name = "ti-cpufreq",
285+
},
286+
};
287+
module_platform_driver(ti_cpufreq_driver);
288+
289+
MODULE_DESCRIPTION("TI CPUFreq/OPP hw-supported driver");
290+
MODULE_AUTHOR("Dave Gerlach <d-gerlach@ti.com>");
291+
MODULE_LICENSE("GPL v2");

0 commit comments

Comments
 (0)