gpio-restart.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. /*
  2. * Copyright (c) 2006-2023, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2023-02-25 GuEe-GUI the first version
  9. */
  10. #include <rtthread.h>
  11. #include <rtdevice.h>
  12. #define DBG_TAG "reset.gpio.restart"
  13. #define DBG_LVL DBG_INFO
  14. #include <rtdbg.h>
  15. struct gpio_restart
  16. {
  17. rt_ubase_t pin;
  18. rt_uint8_t active_value;
  19. rt_uint32_t wait_delay_ms;
  20. rt_uint32_t active_delay_ms;
  21. rt_uint32_t inactive_delay_ms;
  22. };
  23. static rt_err_t gpio_restart_do_restart(struct rt_device *dev)
  24. {
  25. struct gpio_restart *gr = dev->user_data;
  26. rt_pin_mode(gr->pin, PIN_MODE_OUTPUT);
  27. rt_thread_mdelay(gr->active_delay_ms);
  28. rt_pin_write(gr->pin, !gr->active_value);
  29. rt_thread_mdelay(gr->inactive_delay_ms);
  30. rt_pin_write(gr->pin, gr->active_value);
  31. rt_thread_mdelay(gr->wait_delay_ms);
  32. return RT_EOK;
  33. }
  34. static rt_err_t gpio_restart_probe(struct rt_platform_device *pdev)
  35. {
  36. rt_err_t err;
  37. struct rt_device *dev = &pdev->parent;
  38. struct gpio_restart *gr = rt_calloc(1, sizeof(*gr));
  39. if (!gr)
  40. {
  41. return -RT_ENOMEM;
  42. }
  43. gr->pin = rt_pin_get_named_pin(dev, RT_NULL, 0, RT_NULL, &gr->active_value);
  44. if (gr->pin < 0)
  45. {
  46. err = gr->pin;
  47. goto _fail;
  48. }
  49. gr->active_delay_ms = 100;
  50. gr->inactive_delay_ms = 100;
  51. gr->wait_delay_ms = 3000;
  52. rt_dm_dev_prop_read_u32(dev, "active-delay", &gr->active_delay_ms);
  53. rt_dm_dev_prop_read_u32(dev, "inactive-delay", &gr->inactive_delay_ms);
  54. rt_dm_dev_prop_read_u32(dev, "wait-delay", &gr->wait_delay_ms);
  55. dev->user_data = gr;
  56. if ((err = rt_dm_power_off_handler(dev, RT_DM_POWER_OFF_MODE_RESET,
  57. RT_DM_POWER_OFF_PRIO_DEFAULT, gpio_restart_do_restart)))
  58. {
  59. goto _fail;
  60. }
  61. return RT_EOK;
  62. _fail:
  63. rt_free(gr);
  64. return err;
  65. }
  66. static const struct rt_ofw_node_id gpio_restart_ofw_ids[] =
  67. {
  68. { .compatible = "gpio-restart" },
  69. { /* sentinel */ }
  70. };
  71. static struct rt_platform_driver gpio_restart_driver =
  72. {
  73. .name = "reset-gpio-restart",
  74. .ids = gpio_restart_ofw_ids,
  75. .probe = gpio_restart_probe,
  76. };
  77. RT_PLATFORM_DRIVER_EXPORT(gpio_restart_driver);