110-reset_controller_driver.patch 1.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. --- a/arch/mips/ralink/reset.c
  2. +++ b/arch/mips/ralink/reset.c
  3. @@ -11,6 +11,7 @@
  4. #include <linux/of.h>
  5. #include <linux/delay.h>
  6. #include <linux/reset-controller.h>
  7. +#include <linux/platform_device.h>
  8. #include <asm/reboot.h>
  9. @@ -65,21 +66,39 @@ static const struct reset_control_ops re
  10. .deassert = ralink_deassert_device,
  11. };
  12. -static struct reset_controller_dev reset_dev = {
  13. - .ops = &reset_ops,
  14. - .owner = THIS_MODULE,
  15. - .nr_resets = 32,
  16. - .of_reset_n_cells = 1,
  17. +static int ralink_reset_probe(struct platform_device *pdev)
  18. +{
  19. + struct reset_controller_dev *rcdev;
  20. +
  21. + rcdev = devm_kzalloc(&pdev->dev, sizeof(*rcdev), GFP_KERNEL);
  22. + if (!rcdev)
  23. + return -ENOMEM;
  24. +
  25. + rcdev->ops = &reset_ops;
  26. + rcdev->owner = THIS_MODULE;
  27. + rcdev->nr_resets = 32;
  28. + rcdev->of_reset_n_cells = 1;
  29. + rcdev->of_node = pdev->dev.of_node;
  30. +
  31. + return devm_reset_controller_register(&pdev->dev, rcdev);
  32. +}
  33. +
  34. +static const struct of_device_id ralink_reset_dt_ids[] = {
  35. + { .compatible = "ralink,rt2880-reset" },
  36. + {}
  37. +};
  38. +
  39. +static struct platform_driver ralink_reset_driver = {
  40. + .probe = ralink_reset_probe,
  41. + .driver = {
  42. + .name = "ralink-reset",
  43. + .of_match_table = ralink_reset_dt_ids,
  44. + }
  45. };
  46. void ralink_rst_init(void)
  47. {
  48. - reset_dev.of_node = of_find_compatible_node(NULL, NULL,
  49. - "ralink,rt2880-reset");
  50. - if (!reset_dev.of_node)
  51. - pr_err("Failed to find reset controller node");
  52. - else
  53. - reset_controller_register(&reset_dev);
  54. + platform_driver_register(&ralink_reset_driver);
  55. }
  56. static void ralink_restart(char *command)