My Marlin configs for Fabrikator Mini and CTC i3 Pro B
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

watchdog.cpp 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. /**
  2. * Marlin 3D Printer Firmware
  3. * Copyright (c) 2020 MarlinFirmware [https://github.com/MarlinFirmware/Marlin]
  4. *
  5. * Based on Sprinter and grbl.
  6. * Copyright (c) 2011 Camiel Gubbels / Erik van der Zalm
  7. *
  8. * This program is free software: you can redistribute it and/or modify
  9. * it under the terms of the GNU General Public License as published by
  10. * the Free Software Foundation, either version 3 of the License, or
  11. * (at your option) any later version.
  12. *
  13. * This program is distributed in the hope that it will be useful,
  14. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  15. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  16. * GNU General Public License for more details.
  17. *
  18. * You should have received a copy of the GNU General Public License
  19. * along with this program. If not, see <https://www.gnu.org/licenses/>.
  20. *
  21. */
  22. /**
  23. * HAL for stm32duino.com based on Libmaple and compatible (STM32F1)
  24. */
  25. #ifdef __STM32F1__
  26. #include "../../inc/MarlinConfig.h"
  27. #if ENABLED(USE_WATCHDOG)
  28. #include <libmaple/iwdg.h>
  29. #include "watchdog.h"
  30. /**
  31. * The watchdog clock is 40Khz. So for a 4s or 8s interval use a /256 preescaler and 625 or 1250 reload value (counts down to 0).
  32. */
  33. #define STM32F1_WD_RELOAD TERN(WATCHDOG_DURATION_8S, 1250, 625) // 4 or 8 second timeout
  34. void HAL_watchdog_refresh() {
  35. #if DISABLED(PINS_DEBUGGING) && PIN_EXISTS(LED)
  36. TOGGLE(LED_PIN); // heartbeat indicator
  37. #endif
  38. iwdg_feed();
  39. }
  40. void watchdogSetup() {
  41. // do whatever. don't remove this function.
  42. }
  43. /**
  44. * @brief Initialized the independent hardware watchdog.
  45. *
  46. * @return No return
  47. *
  48. * @details The watchdog clock is 40Khz. So for a 4s or 8s interval use a /256 preescaler and 625 or 1250 reload value (counts down to 0).
  49. */
  50. void watchdog_init() {
  51. #if DISABLED(DISABLE_WATCHDOG_INIT)
  52. iwdg_init(IWDG_PRE_256, STM32F1_WD_RELOAD);
  53. #endif
  54. }
  55. #endif // USE_WATCHDOG
  56. #endif // __STM32F1__