| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061 |
- --- a/arch/mips/ralink/reset.c
- +++ b/arch/mips/ralink/reset.c
- @@ -11,6 +11,7 @@
- #include <linux/of.h>
- #include <linux/delay.h>
- #include <linux/reset-controller.h>
- +#include <linux/platform_device.h>
-
- #include <asm/reboot.h>
-
- @@ -65,21 +66,39 @@ static const struct reset_control_ops re
- .deassert = ralink_deassert_device,
- };
-
- -static struct reset_controller_dev reset_dev = {
- - .ops = &reset_ops,
- - .owner = THIS_MODULE,
- - .nr_resets = 32,
- - .of_reset_n_cells = 1,
- +static int ralink_reset_probe(struct platform_device *pdev)
- +{
- + struct reset_controller_dev *rcdev;
- +
- + rcdev = devm_kzalloc(&pdev->dev, sizeof(*rcdev), GFP_KERNEL);
- + if (!rcdev)
- + return -ENOMEM;
- +
- + rcdev->ops = &reset_ops;
- + rcdev->owner = THIS_MODULE;
- + rcdev->nr_resets = 32;
- + rcdev->of_reset_n_cells = 1;
- + rcdev->of_node = pdev->dev.of_node;
- +
- + return devm_reset_controller_register(&pdev->dev, rcdev);
- +}
- +
- +static const struct of_device_id ralink_reset_dt_ids[] = {
- + { .compatible = "ralink,rt2880-reset" },
- + {}
- +};
- +
- +static struct platform_driver ralink_reset_driver = {
- + .probe = ralink_reset_probe,
- + .driver = {
- + .name = "ralink-reset",
- + .of_match_table = ralink_reset_dt_ids,
- + }
- };
-
- void ralink_rst_init(void)
- {
- - reset_dev.of_node = of_find_compatible_node(NULL, NULL,
- - "ralink,rt2880-reset");
- - if (!reset_dev.of_node)
- - pr_err("Failed to find reset controller node");
- - else
- - reset_controller_register(&reset_dev);
- + platform_driver_register(&ralink_reset_driver);
- }
-
- static void ralink_restart(char *command)
|