wdg.c 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071
  1. /********************************* (C) РОТЕК ***********************************
  2. * @module wdg
  3. * @file wdg.c
  4. * @version 1.0.0
  5. * @date XX.XX.XXXX
  6. * $brief External watchdog (pin PE11)
  7. *******************************************************************************
  8. * @history Version Author Comment
  9. * XX.XX.XXXX 1.0.0 Telenkov D.A. First release.
  10. *******************************************************************************
  11. */
  12. #include "stm32f4xx.h"
  13. #include "wdg.h"
  14. /**
  15. * @brief
  16. * @retval
  17. */
  18. void WDG_Init(void)
  19. {
  20. // GPIO_InitTypeDef GPIO_InitStructure;
  21. NVIC_InitTypeDef NVIC_InitStructure;
  22. TIM_TimeBaseInitTypeDef TIM_TimeBaseStructure;
  23. // RCC_AHB1PeriphClockCmd(RCC_AHB1Periph_GPIOE, ENABLE);
  24. RCC_APB1PeriphClockCmd(RCC_APB1Periph_TIM13, ENABLE);
  25. /* Port initialization done in "gpio_init" */
  26. /* GPIO_InitStructure.GPIO_Pin = WDT_PIN;
  27. GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
  28. GPIO_InitStructure.GPIO_Mode = GPIO_Mode_OUT;
  29. GPIO_InitStructure.GPIO_OType = GPIO_OType_PP;
  30. GPIO_InitStructure.GPIO_PuPd = GPIO_PuPd_NOPULL;
  31. GPIO_Init(GPIOE, &GPIO_InitStructure);*/
  32. NVIC_InitStructure.NVIC_IRQChannel = TIM8_UP_TIM13_IRQn;
  33. NVIC_InitStructure.NVIC_IRQChannelPreemptionPriority = 0x6;
  34. NVIC_InitStructure.NVIC_IRQChannelSubPriority = 0x0;
  35. NVIC_InitStructure.NVIC_IRQChannelCmd = ENABLE;
  36. NVIC_Init(&NVIC_InitStructure);
  37. NVIC_SetPriority(TIM8_UP_TIM13_IRQn, 2);
  38. /* APB1 Timer clock is 60Mhz, configure timer clock to 10khz (1 update event per 100 us) */
  39. TIM_TimeBaseStructure.TIM_Prescaler = 6000 - 1;
  40. /* Configure timer period to 100ms */
  41. TIM_TimeBaseStructure.TIM_Period = 1000;
  42. TIM_TimeBaseStructure.TIM_ClockDivision = 0;
  43. TIM_TimeBaseStructure.TIM_CounterMode = TIM_CounterMode_Up;
  44. TIM_TimeBaseInit(TIM13, &TIM_TimeBaseStructure);
  45. TIM_Cmd(TIM13, ENABLE);
  46. TIM_ITConfig(TIM13, TIM_IT_Update, ENABLE);
  47. }
  48. /**
  49. * @brief Дергаем пином (сброс внешнего WDT)
  50. * @retval
  51. */
  52. /*void TIM8_UP_TIM13_IRQHandler(void)
  53. {
  54. TIM_ClearITPendingBit(TIM13, TIM_IT_Update);
  55. GPIOC->ODR ^= WDT_PIN;
  56. }*/
  57. /********************************* (C) РОТЕК **********************************/