drv_wdt.c 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104
  1. /*
  2. * Copyright (c) 2006-2022, Synwit Technology Co.,Ltd.
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. *
  6. * Change Logs:
  7. * Date Author Notes
  8. * 2021-07-01 lik first version
  9. */
  10. #include "drv_wdt.h"
  11. #ifdef RT_USING_WDT
  12. #ifdef BSP_USING_WDT
  13. //#define DRV_DEBUG
  14. #define LOG_TAG "drv.wdt"
  15. #include <drv_log.h>
  16. struct swm_wdt_cfg
  17. {
  18. const char *name;
  19. WDT_TypeDef *WDTx;
  20. };
  21. struct swm_wdt_device
  22. {
  23. struct swm_wdt_cfg *wdt_cfg;
  24. struct rt_watchdog_device wdt_device;
  25. };
  26. static struct swm_wdt_cfg swm_wdt_cfg =
  27. {
  28. .name = "wdt",
  29. .WDTx = WDT,
  30. };
  31. static struct swm_wdt_device wdt_obj;
  32. static rt_err_t swm_wdt_configure(rt_watchdog_t *wdt_device)
  33. {
  34. return RT_EOK;
  35. }
  36. static rt_err_t swm_wdt_control(rt_watchdog_t *wdt_device, int cmd, void *arg)
  37. {
  38. struct swm_wdt_cfg *wdt_cfg;
  39. RT_ASSERT(wdt_device != RT_NULL);
  40. wdt_cfg = wdt_device->parent.user_data;
  41. switch (cmd)
  42. {
  43. case RT_DEVICE_CTRL_WDT_KEEPALIVE:
  44. WDT_Feed(wdt_cfg->WDTx);
  45. break;
  46. case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
  47. WDT_Init(wdt_cfg->WDTx, 0, (1024 * (*(rt_uint32_t *)arg)));
  48. break;
  49. case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
  50. *(rt_uint32_t *)arg = (wdt_cfg->WDTx->RSTVAL) / 1024;
  51. break;
  52. case RT_DEVICE_CTRL_WDT_GET_TIMELEFT:
  53. // not support
  54. break;
  55. case RT_DEVICE_CTRL_WDT_START:
  56. WDT_Start(wdt_cfg->WDTx);
  57. break;
  58. case RT_DEVICE_CTRL_WDT_STOP:
  59. WDT_Stop(wdt_cfg->WDTx);
  60. break;
  61. default:
  62. LOG_W("This command is not supported.");
  63. return -RT_ERROR;
  64. }
  65. return RT_EOK;
  66. }
  67. static const struct rt_watchdog_ops swm_wdt_ops =
  68. {
  69. .init = swm_wdt_configure,
  70. .control = swm_wdt_control};
  71. int swm_wdt_init(void)
  72. {
  73. int result = RT_EOK;
  74. wdt_obj.wdt_cfg = &swm_wdt_cfg;
  75. wdt_obj.wdt_device.ops = &swm_wdt_ops;
  76. result = rt_hw_watchdog_register(&wdt_obj.wdt_device, wdt_obj.wdt_cfg->name, RT_DEVICE_FLAG_RDWR, wdt_obj.wdt_cfg);
  77. if(result != RT_EOK)
  78. {
  79. LOG_E("wdt device register fail.");
  80. }
  81. else
  82. {
  83. LOG_D("wdt device register success.");
  84. }
  85. return result;
  86. }
  87. INIT_BOARD_EXPORT(swm_wdt_init);
  88. #endif /* BSP_USING_WDT */
  89. #endif /* RT_USING_WDT */