Projet voilier 4IRA1 Arnaud Vergnet Marino Benassai Bastien Picco Yohan Simard
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.

Chrono.h 1.9KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107
  1. // RIEN A MODIFIER //
  2. #ifndef CHRONO_H
  3. #define CHRONO_H
  4. /*
  5. Service permettant de chornométrer jusqu'à 59mn 59s 99 1/100
  6. Utilise un timer au choix (TIMER1 à TIMER4).
  7. Utilise la lib MyTimers.h /.c
  8. */
  9. #include "stm32f103xb.h"
  10. /* =====================================================================================
  11. Les fonctions qui gèrent les IO (ajout par rapport à l'activité 1)
  12. =======================================================================================*/
  13. #define PinStart LL_GPIO_PIN_8
  14. #define PinStop LL_GPIO_PIN_6
  15. // à compléter pour la pin reset du chronometre
  16. #define PinLED LL_GPIO_PIN_10
  17. #define GPIO_Pin GPIOC
  18. #define GPIO_LED GPIOC
  19. /**
  20. * @brief polle les 3 entrées et gènère les actions à faire
  21. * @note Fct à lancer en tâche de fond (non bloquante)
  22. * @param None
  23. * @retval None
  24. */
  25. void Chrono_Background(void);
  26. //=======================================================================================//
  27. // Type de donnée utilisé dans le module
  28. typedef struct {
  29. char Hund;
  30. char Sec;
  31. char Min;
  32. } Time;
  33. /**
  34. * @brief Configure le chronomètre.
  35. * @note A lancer avant toute autre fonction.
  36. * @param TIM_TypeDef Timer : indique le timer à utiliser par le chronomètre, TIM1, TIM2, TIM3 ou TIM4
  37. * @retval None
  38. */
  39. void Chrono_Conf(TIM_TypeDef * Timer);
  40. /**
  41. * @brief Démarre le chronomètre.
  42. * @note si la durée dépasse 59mn 59sec 99 cent, elle est remise à zéro et repart
  43. * @param Aucun
  44. * @retval Aucun
  45. */
  46. void Chrono_Start(void);
  47. /**
  48. * @brief Arrête le chronomètre.
  49. * @note
  50. * @param Aucun
  51. * @retval Aucun
  52. */
  53. void Chrono_Stop(void);
  54. /**
  55. * @brief Remet le chronomètre à 0
  56. * @note
  57. * @param Aucun
  58. * @retval Aucun
  59. */
  60. void Chrono_Reset(void);
  61. /**
  62. * @brief Renvoie l'adresse de la variable Time privée gérée dans le module Chrono.c
  63. * @note
  64. * @param Aucun
  65. * @retval adresse de la variable Time
  66. */
  67. Time * Chrono_Read(void);
  68. #endif