drv_wdt.h 2.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273
  1. /*
  2. * Copyright (c) 2006-2025, RT-Thread Development Team
  3. *
  4. * SPDX-License-Identifier: Apache-2.0
  5. */
  6. #ifndef DRV_WDT_H_
  7. #define DRV_WDT_H_
  8. #include <drivers/dev_watchdog.h>
  9. #include <sys/ioctl.h>
  10. #define DEFUALT_TIMEOUT 30*1000 /* ms */
  11. #define KD_WDT_NUM_TOPS 16
  12. #define KD_WDT_FIX_TOP(_idx) (1U << (16 + _idx))
  13. #define KD_WDT_RMOD_RESET 1
  14. #define KD_WDT_RMOD_IRQ 2
  15. #define KD_DEVICE_CTRL_WDT_GET_TIMEOUT _IOW('W', 1, int) /* get timeout(in seconds) */
  16. #define KD_DEVICE_CTRL_WDT_SET_TIMEOUT _IOW('W', 2, int) /* set timeout(in seconds) */
  17. #define KD_DEVICE_CTRL_WDT_GET_TIMELEFT _IOW('W', 3, int) /* get the left time before reboot(in seconds) */
  18. #define KD_DEVICE_CTRL_WDT_KEEPALIVE _IOW('W', 4, int) /* refresh watchdog */
  19. #define KD_DEVICE_CTRL_WDT_START _IOW('W', 5, int) /* start watchdog */
  20. #define KD_DEVICE_CTRL_WDT_STOP _IOW('W', 6, int) /* stop watchdog */
  21. struct k230_wdt_timeout {
  22. rt_uint32_t top_val;
  23. rt_uint32_t sec;
  24. rt_uint32_t msec;
  25. };
  26. #define swap(a, b) \
  27. do { struct k230_wdt_timeout __tmp = (a); (a) = (b); (b) = __tmp; } while (0)
  28. /* wdt register map */
  29. typedef struct _wdt
  30. {
  31. /* WDT Control Register (0x00) */
  32. volatile uint32_t cr;
  33. /* WDT Timeout Range Register (0x04) */
  34. volatile uint32_t torr;
  35. /* WDT Current Counter Value Register (0x08) */
  36. volatile uint32_t ccvr;
  37. /* WDT Counter Restart Register (0x0c) */
  38. volatile uint32_t crr;
  39. /* WDT Interrupt Status Register (0x10) */
  40. volatile uint32_t stat;
  41. /* WDT Interrupt Clear Register (0x14) */
  42. volatile uint32_t eoi;
  43. /* reserverd (0x18) */
  44. volatile uint32_t resv1;
  45. /* WDT Protection level Register (0x1c) */
  46. volatile uint32_t prot_level;
  47. /* reserved (0x20-0xe0) */
  48. volatile uint32_t resv4[49];
  49. /* WDT Component Parameters Register 5 (0xe4) */
  50. volatile uint32_t comp_param_5;
  51. /* WDT Component Parameters Register 4 (0xe8) */
  52. volatile uint32_t comp_param_4;
  53. /* WDT Component Parameters Register 3 (0xec) */
  54. volatile uint32_t comp_param_3;
  55. /* WDT Component Parameters Register 2 (0xf0) */
  56. volatile uint32_t comp_param_2;
  57. /* WDT Component Parameters Register 1 (0xf4) */
  58. volatile uint32_t comp_param_1;
  59. /* WDT Component Version Register (0xf8) */
  60. volatile uint32_t comp_version;
  61. /* WDT Component Type Register (0xfc) */
  62. volatile uint32_t comp_type;
  63. } __attribute__((packed, aligned(4))) k230_wdt_t;
  64. #endif /* DRV_WDT_H_ */