main.c 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. /*!
  2. \file main.c
  3. \brief TIMER2 input capture demo
  4. */
  5. /*
  6. Copyright (C) 2017 GigaDevice
  7. 2017-06-06, V1.0.0, firmware for GD32F3x0
  8. */
  9. #include "gd32f3x0.h"
  10. #include <stdio.h>
  11. #include "gd32f3x0_eval.h"
  12. void gpio_configuration(void);
  13. void timer_configuration(void);
  14. void nvic_configuration(void);
  15. int fputc(int ch, FILE *f);
  16. /* retarget the C library printf function to the USART */
  17. int fputc(int ch, FILE *f)
  18. {
  19. usart_data_transmit(EVAL_COM1, (uint8_t) ch);
  20. while (RESET == usart_flag_get(EVAL_COM1,USART_FLAG_TC));
  21. return ch;
  22. }
  23. /*!
  24. \brief configure the GPIO ports
  25. \param[in] none
  26. \param[out] none
  27. \retval none
  28. */
  29. void gpio_configuration(void)
  30. {
  31. rcu_periph_clock_enable(RCU_GPIOB);
  32. /*configure PB4 (TIMER2 CH0) as alternate function*/
  33. gpio_mode_set(GPIOB, GPIO_MODE_AF, GPIO_PUPD_NONE, GPIO_PIN_4);
  34. gpio_output_options_set(GPIOB, GPIO_OTYPE_PP, GPIO_OSPEED_50MHZ,GPIO_PIN_4);
  35. gpio_af_set(GPIOB, GPIO_AF_1, GPIO_PIN_4);
  36. }
  37. /*!
  38. \brief configure the nested vectored interrupt controller
  39. \param[in] none
  40. \param[out] none
  41. \retval none
  42. */
  43. void nvic_configuration(void)
  44. {
  45. nvic_priority_group_set(NVIC_PRIGROUP_PRE1_SUB3);
  46. nvic_irq_enable(TIMER2_IRQn, 1, 1);
  47. }
  48. /*!
  49. \brief configure the TIMER peripheral
  50. \param[in] none
  51. \param[out] none
  52. \retval none
  53. */
  54. void timer_configuration(void)
  55. {
  56. /* TIMER2 configuration: input capture mode -------------------
  57. the external signal is connected to TIMER2 CH0 pin (PB4)
  58. the rising edge is used as active edge
  59. the TIMER2 CH0CV is used to compute the frequency value
  60. ------------------------------------------------------------ */
  61. timer_ic_parameter_struct timer_icinitpara;
  62. timer_parameter_struct timer_initpara;
  63. rcu_periph_clock_enable(RCU_TIMER2);
  64. timer_deinit(TIMER2);
  65. /* TIMER2 configuration */
  66. #ifdef GD32F330
  67. timer_initpara.prescaler = 41999;
  68. #endif /* GD32F330 */
  69. #ifdef GD32F350
  70. timer_initpara.prescaler = 53999;
  71. #endif /* GD32F350 */
  72. timer_initpara.alignedmode = TIMER_COUNTER_EDGE;
  73. timer_initpara.counterdirection = TIMER_COUNTER_UP;
  74. timer_initpara.period = 65535;
  75. timer_initpara.clockdivision = TIMER_CKDIV_DIV1;
  76. timer_initpara.repetitioncounter = 0;
  77. timer_init(TIMER2,&timer_initpara);
  78. /* TIMER2 configuration */
  79. /* TIMER2 CH0 input capture configuration */
  80. timer_icinitpara.icpolarity = TIMER_IC_POLARITY_RISING;
  81. timer_icinitpara.icselection = TIMER_IC_SELECTION_DIRECTTI;
  82. timer_icinitpara.icprescaler = TIMER_IC_PSC_DIV1;
  83. timer_icinitpara.icfilter = 0x0;
  84. timer_input_capture_config(TIMER2,TIMER_CH_0,&timer_icinitpara);
  85. /* auto-reload preload enable */
  86. timer_auto_reload_shadow_enable(TIMER2);
  87. /* clear channel 0 interrupt bit */
  88. timer_interrupt_flag_clear(TIMER2,TIMER_INT_CH0);
  89. /* channel 0 interrupt enable */
  90. timer_interrupt_enable(TIMER2,TIMER_INT_CH0);
  91. /* TIMER2 counter enable */
  92. timer_enable(TIMER2);
  93. }
  94. /*!
  95. \brief main function
  96. \param[in] none
  97. \param[out] none
  98. \retval none
  99. */
  100. int main(void)
  101. {
  102. gpio_configuration();
  103. gd_eval_com_init(EVAL_COM1);
  104. nvic_configuration();
  105. timer_configuration();
  106. while (1);
  107. }