OsIf_Timer_System_Internal_Systick.h 7.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163
  1. /*==================================================================================================
  2. * Project : RTD AUTOSAR 4.4
  3. * Platform : CORTEXM
  4. * Peripheral : S32K14X
  5. * Dependencies : none
  6. *
  7. * Autosar Version : 4.4.0
  8. * Autosar Revision : ASR_REL_4_4_REV_0000
  9. * Autosar Conf.Variant :
  10. * SW Version : 1.0.0
  11. * Build Version : S32K1_RTD_1_0_0_D2108_ASR_REL_4_4_REV_0000_20210810
  12. *
  13. * (c) Copyright 2020-2021 NXP Semiconductors
  14. * All Rights Reserved.
  15. *
  16. * NXP Confidential. This software is owned or controlled by NXP and may only be
  17. * used strictly in accordance with the applicable license terms. By expressly
  18. * accepting such terms or by downloading, installing, activating and/or otherwise
  19. * using the software, you are agreeing that you have read, and that you agree to
  20. * comply with and are bound by, such license terms. If you do not agree to be
  21. * bound by the applicable license terms, then you may not retain, install,
  22. * activate or otherwise use the software.
  23. ==================================================================================================*/
  24. #ifndef OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK
  25. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK
  26. /**
  27. * @file
  28. *
  29. * @addtogroup osif_drv
  30. * @{
  31. */
  32. #ifdef __cplusplus
  33. extern "C"{
  34. #endif
  35. /*==================================================================================================
  36. * INCLUDE FILES
  37. * 1) system and project includes
  38. * 2) needed interfaces from external units
  39. * 3) internal and external interfaces from this unit
  40. ==================================================================================================*/
  41. #include "OsIf_DeviceRegisters.h"
  42. /*==================================================================================================
  43. * SOURCE FILE VERSION INFORMATION
  44. ==================================================================================================*/
  45. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_VENDOR_ID 43
  46. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_MAJOR_VERSION 4
  47. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_MINOR_VERSION 4
  48. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_REVISION_VERSION 0
  49. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_MAJOR_VERSION 1
  50. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_MINOR_VERSION 0
  51. #define OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_PATCH_VERSION 0
  52. /*==================================================================================================
  53. * FILE VERSION CHECKS
  54. ==================================================================================================*/
  55. /* Checks against OsIf_DeviceRegisters.h */
  56. #if (OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_VENDOR_ID != OSIF_DEVICE_REGISTERS_VENDOR_ID)
  57. #error "OsIf_Timer_System_Internal_Systick.h and OsIf_DeviceRegisters.h have different vendor ids"
  58. #endif
  59. #if ((OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_MAJOR_VERSION != OSIF_DEVICE_REGISTERS_AR_RELEASE_MAJOR_VERSION) || \
  60. (OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_MINOR_VERSION != OSIF_DEVICE_REGISTERS_AR_RELEASE_MINOR_VERSION) || \
  61. (OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_AR_RELEASE_REVISION_VERSION != OSIF_DEVICE_REGISTERS_AR_RELEASE_REVISION_VERSION))
  62. #error "AUTOSAR Version Numbers of OsIf_Timer_System_Internal_Systick.h and OsIf_DeviceRegisters.h are different"
  63. #endif
  64. #if ((OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_MAJOR_VERSION != OSIF_DEVICE_REGISTERS_SW_MAJOR_VERSION) || \
  65. (OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_MINOR_VERSION != OSIF_DEVICE_REGISTERS_SW_MINOR_VERSION) || \
  66. (OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK_SW_PATCH_VERSION != OSIF_DEVICE_REGISTERS_SW_PATCH_VERSION) \
  67. )
  68. #error "Software Version Numbers of OsIf_Timer_System_Internal_Systick.h and OsIf_DeviceRegisters.h are different"
  69. #endif
  70. /*==================================================================================================
  71. * CONSTANTS
  72. ==================================================================================================*/
  73. /*==================================================================================================
  74. * DEFINES AND MACROS
  75. ==================================================================================================*/
  76. #define SYSTICK_GET_COUNTER() ((S32_SysTick->CVR) & S32_SysTick_CVR_CURRENT_MASK)
  77. #define SYSTICK_DELTA_OUTER(high, low, max) ((max) - ((high) - (low)))
  78. #define SYSTICK_DELTA_INNER(high, low) ((high) - (low))
  79. #define SYSTICK_MAX (0xFFFFFFu)
  80. #define SYSTICK_OVERFLOWED(curr, ref) (curr > ref)
  81. /*==================================================================================================
  82. * ENUMS
  83. ==================================================================================================*/
  84. /*==================================================================================================
  85. * STRUCTURES AND OTHER TYPEDEFS
  86. ==================================================================================================*/
  87. /*==================================================================================================
  88. * GLOBAL VARIABLE DECLARATIONS
  89. ==================================================================================================*/
  90. /*==================================================================================================
  91. * FUNCTION PROTOTYPES
  92. ==================================================================================================*/
  93. #define BASE_START_SEC_CODE
  94. #include "Base_MemMap.h"
  95. static inline void OsIf_Timer_System_Internal_Init(void);
  96. static inline uint32 OsIf_Timer_System_Internal_GetCounter(void);
  97. static inline uint32 OsIf_Timer_System_Internal_GetElapsed(uint32 * const CurrentRef);
  98. #define BASE_STOP_SEC_CODE
  99. #include "Base_MemMap.h"
  100. /*==================================================================================================
  101. * LOCAL FUNCTIONS
  102. ==================================================================================================*/
  103. #define BASE_START_SEC_CODE
  104. #include "Base_MemMap.h"
  105. static inline void OsIf_Timer_System_Internal_Init(void)
  106. {
  107. /* For Cortex-M0 devices the systick counter is initialized with an undefined
  108. value, so make sure to initialize it to 0 before starting */
  109. S32_SysTick->CSRr = S32_SysTick_CSR_ENABLE(0u);
  110. S32_SysTick->RVR = S32_SysTick_RVR_RELOAD(SYSTICK_MAX);
  111. S32_SysTick->CVR = S32_SysTick_CVR_CURRENT(0U);
  112. S32_SysTick->CSRr = S32_SysTick_CSR_ENABLE(1u) | S32_SysTick_CSR_TICKINT(0u) | S32_SysTick_CSR_CLKSOURCE(1u);
  113. }
  114. static inline uint32 OsIf_Timer_System_Internal_GetCounter(void)
  115. {
  116. return SYSTICK_GET_COUNTER();
  117. }
  118. static inline uint32 OsIf_Timer_System_Internal_GetElapsed(uint32 * const CurrentRef)
  119. {
  120. uint32 CurrentVal = SYSTICK_GET_COUNTER();
  121. uint32 dif = 0u;
  122. if (SYSTICK_OVERFLOWED((CurrentVal), (*CurrentRef)))
  123. {
  124. /* overflow occurred */
  125. dif = SYSTICK_DELTA_OUTER(CurrentVal, *CurrentRef, S32_SysTick->RVR);
  126. }
  127. else
  128. {
  129. /* overflow did not occur */
  130. dif = SYSTICK_DELTA_INNER(*CurrentRef, CurrentVal);
  131. }
  132. *CurrentRef = CurrentVal;
  133. return dif;
  134. }
  135. #define BASE_STOP_SEC_CODE
  136. #include "Base_MemMap.h"
  137. #ifdef __cplusplus
  138. }
  139. #endif
  140. /** @} */
  141. #endif /* OSIF_TIMER_SYSTEM_INTERNAL_SYSTICK */