drv_wdt.c 2.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788
  1. /*
  2. * Copyright (c) 2006-2018, 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. static struct swm_wdt_cfg wdt_cfg =
  18. {
  19. .name = "wdt",
  20. .WDTx = WDT,
  21. };
  22. static struct swm_wdt wdt_drv;
  23. static rt_err_t swm_wdt_init(rt_watchdog_t *wdt_device)
  24. {
  25. return RT_EOK;
  26. }
  27. static rt_err_t swm_wdt_control(rt_watchdog_t *wdt_device, int cmd, void *arg)
  28. {
  29. struct swm_wdt_cfg *cfg;
  30. RT_ASSERT(wdt_device != RT_NULL);
  31. cfg = wdt_device->parent.user_data;
  32. switch (cmd)
  33. {
  34. case RT_DEVICE_CTRL_WDT_KEEPALIVE:
  35. WDT_Feed(cfg->WDTx);
  36. break;
  37. case RT_DEVICE_CTRL_WDT_SET_TIMEOUT:
  38. WDT_Init(cfg->WDTx, (SystemCoreClock * (*(rt_uint32_t *)arg)), WDT_MODE_RESET);
  39. break;
  40. case RT_DEVICE_CTRL_WDT_GET_TIMEOUT:
  41. *(rt_uint32_t *)arg = (cfg->WDTx->LOAD) / SystemCoreClock;
  42. break;
  43. case RT_DEVICE_CTRL_WDT_GET_TIMELEFT:
  44. *(rt_uint32_t *)arg = WDT_GetValue(cfg->WDTx) / SystemCoreClock;
  45. break;
  46. case RT_DEVICE_CTRL_WDT_START:
  47. WDT_Start(cfg->WDTx);
  48. break;
  49. case RT_DEVICE_CTRL_WDT_STOP:
  50. WDT_Stop(cfg->WDTx);
  51. break;
  52. default:
  53. LOG_W("This command is not supported.");
  54. return -RT_ERROR;
  55. }
  56. return RT_EOK;
  57. }
  58. const static struct rt_watchdog_ops swm_wdt_ops =
  59. {
  60. swm_wdt_init,
  61. swm_wdt_control};
  62. int rt_hw_wdt_init(void)
  63. {
  64. wdt_drv.cfg = &wdt_cfg;
  65. wdt_drv.wdt_device.ops = &swm_wdt_ops;
  66. if (rt_hw_watchdog_register(&wdt_drv.wdt_device, wdt_drv.cfg->name, RT_DEVICE_FLAG_RDWR, wdt_drv.cfg) != RT_EOK)
  67. {
  68. LOG_E("wdt device register failed.");
  69. return -RT_ERROR;
  70. }
  71. LOG_D("wdt device register success.");
  72. return RT_EOK;
  73. }
  74. INIT_BOARD_EXPORT(rt_hw_wdt_init);
  75. #endif /* BSP_USING_WDT */
  76. #endif /* RT_USING_WDT */