drv_wdt.c 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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. * 2018-12-10 Zohar_Lee first version
  9. * 2020-07-10 lik format file
  10. */
  11. #include "drv_wdt.h"
  12. #ifdef RT_USING_WDT
  13. #ifdef BSP_USING_WDT
  14. //#define DRV_DEBUG
  15. #define LOG_TAG "drv.wdt"
  16. #include <drv_log.h>
  17. struct swm_wdt_cfg
  18. {
  19. const char *name;
  20. WDT_TypeDef *WDTx;
  21. };
  22. struct swm_wdt_device
  23. {
  24. struct swm_wdt_cfg *wdt_cfg;
  25. struct rt_watchdog_device wdt_device;
  26. };
  27. static struct swm_wdt_cfg swm_wdt_cfg =
  28. {
  29. .name = "wdt",
  30. .WDTx = WDT,
  31. };
  32. static struct swm_wdt_device wdt_obj;
  33. static rt_err_t swm_wdt_configure(rt_watchdog_t *wdt_device)
  34. {
  35. return RT_EOK;
  36. }
  37. static rt_err_t swm_wdt_control(rt_watchdog_t *wdt_device, int cmd, void *arg)
  38. {
  39. struct swm_wdt_cfg *wdt_cfg;
  40. RT_ASSERT(wdt_device != RT_NULL);
  41. wdt_cfg = wdt_device->parent.user_data;
  42. switch (cmd)
  43. {
  44. case RT_DEVICE_CTRL_WDT_KEEPALIVE:
  45. WDT_Feed(wdt_cfg->WDTx);
  46. break;
  47. case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
  48. WDT_Init(wdt_cfg->WDTx, (SystemCoreClock * (*(rt_uint32_t *)arg)), WDT_MODE_RESET);
  49. break;
  50. case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
  51. *(rt_uint32_t *)arg = (wdt_cfg->WDTx->LOAD) / SystemCoreClock;
  52. break;
  53. case RT_DEVICE_CTRL_WDT_GET_TIMELEFT:
  54. *(rt_uint32_t *)arg = WDT_GetValue(wdt_cfg->WDTx) / SystemCoreClock;
  55. break;
  56. case RT_DEVICE_CTRL_WDT_START:
  57. WDT_Start(wdt_cfg->WDTx);
  58. break;
  59. case RT_DEVICE_CTRL_WDT_STOP:
  60. WDT_Stop(wdt_cfg->WDTx);
  61. break;
  62. default:
  63. LOG_W("This command is not supported.");
  64. return -RT_ERROR;
  65. }
  66. return RT_EOK;
  67. }
  68. static const struct rt_watchdog_ops swm_wdt_ops =
  69. {
  70. .init = swm_wdt_configure,
  71. .control = swm_wdt_control};
  72. int swm_wdt_init(void)
  73. {
  74. int result = RT_EOK;
  75. wdt_obj.wdt_cfg = &swm_wdt_cfg;
  76. wdt_obj.wdt_device.ops = &swm_wdt_ops;
  77. result = rt_hw_watchdog_register(&wdt_obj.wdt_device, wdt_obj.wdt_cfg->name, RT_DEVICE_FLAG_RDWR, wdt_obj.wdt_cfg);
  78. if(result != RT_EOK)
  79. {
  80. LOG_E("wdt device register fail.");
  81. }
  82. else
  83. {
  84. LOG_D("wdt device register success.");
  85. }
  86. return RT_EOK;
  87. }
  88. INIT_BOARD_EXPORT(swm_wdt_init);
  89. #endif /* BSP_USING_WDT */
  90. #endif /* RT_USING_WDT */