User story #127
MARTe-EX-F-1.1.13: The framework shall provide portable methods to access the high resolution timer value of any supported CPU.
0%
Description
Implement requirement MARTe-EX-F-1.1.13 based on the original MARTe implementation
Note: One of the most portable ways to measure time with high accuracy is to use the high resolution timer counter.
Source code files modified¶
- Source/Core/L0Portability/HighResolutionTimer.h
- Source/Core/L0Portability/HighResolutionTimer.cpp
- Source/Core/L0Portability/OperatingSystem/Linux/HighResolutionTimerOS.h
- Source/Core/L0Portability/OperatingSystem/Windows/HighResolutionTimerOS.h
- Source/Core/L0Portability/OperatingSystem/Linux/HighResolutionTimerCalibratorOS.h
- Source/Core/L0Portability/OperatingSystem/Linux/HighResolutionTimerCalibratorOS.cpp
- Source/Core/L0Portability/OperatingSystem/Windows/HighResolutionTimerCalibratorOS.h
- Source/Core/L0Portability/OperatingSystem/Windows/HighResolutionTimerCalibratorOS.cpp
- Source/Core/L0Portability/Architecture/x86_gcc/HighResolutionTimerA.h
- Source/Core/L0Portability/Architecture/x86_cl/HighResolutionTimerA.h
Architecture & design review¶
Date of the review: 12/06/2015
Person who did the review: André Neto
Version of architecture & design document: N/A. As per the original MARTe implementation, this is a support function and does not require formal design in UML.
Result of review: N/A
List of non-conformities: N/A
Code and documentation review¶
Date of the review: 01/07/2015
Person who did the review: Ivan Herrero
Result of review: PASS
List of non-conformities: N/A
Unit test review¶
Date of the review: 23/07/2015
Person who did the review: Ivan Herrero
Result of coverage tests review: PASS
Result of functional tests review: PASS
Result of review: PASS
List of non-conformities: N/A
Notes: The class HighResolutionTimerCalibratorOS does not have a counterpart on L0, so it is not directly tested because the target of the unit tests are only the classes on L0. Nevertheless, all its methods has been tested indirectly through HighResolutionTimer, except GetInitialTime and GetInitialTicks.
Note: The tests for TestCounter, TestCounter32, and TestGetTimeStamp, sometimes pass and sometimes fail. The reason is that the operating system dynamically changes the CPU frequency (for power-saving reasons). As a consequence, the frequency retrieved by MARTe when the test starts might not be the same as when the test is executed, generating false errors. This can be resolved by issuing the following command in CentOS: cpupower frequency-set -g performance
Note: The static declaration/definition of calibratedHighResolutionTimer (of type HighResolutionTimerCalibratorOS) will be refactored in next sprints.
Associated revisions
Fixed issues accordingly with revision.
#127
Corrected code accordingly with revision.
#127
#127 Improvement on the documentation
Minor corrections on the function documentation and format.
#127 - Minor formatting corrections (following template rules)
History
#1 Updated by Riccardo Vitelli almost 10 years ago
- Target version changed from Backlog to 0.1
- Start date deleted (
29.05.2015) - Estimated time set to 2.00 h
#2 Updated by Riccardo Vitelli almost 10 years ago
- Status changed from New to Arch: Rev
#3 Updated by Riccardo Vitelli almost 10 years ago
- Assignee set to André Neto
#4 Updated by André Neto almost 10 years ago
- Description updated (diff)
#5 Updated by Giuseppe Ferro almost 10 years ago
- Status changed from Arch: Rev to Code: Impl
#6 Updated by Giuseppe Ferro almost 10 years ago
- Assignee changed from André Neto to Giuseppe Ferro
#7 Updated by Giuseppe Ferro almost 10 years ago
- Status changed from Code: Impl to Arch: Impl
#8 Updated by Giuseppe Ferro almost 10 years ago
- Status changed from Arch: Impl to Arch: Rev
#9 Updated by Giuseppe Ferro almost 10 years ago
- Status changed from Arch: Rev to Code: Impl
#10 Updated by Ivan Herrero almost 10 years ago
- Assignee changed from Giuseppe Ferro to Ivan Herrero
#11 Updated by Ivan Herrero almost 10 years ago
- Status changed from Code: Impl to Code: Rev
#12 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
#13 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
#14 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
#15 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
- Assignee deleted (
Ivan Herrero)
Code and documentation review made. Code and documentation corrections pending.
#16 Updated by Ivan Herrero almost 10 years ago
- Status changed from Code: Rev to Code: Impl
#17 Updated by Riccardo Vitelli almost 10 years ago
- Assignee set to Giuseppe Ferro
#18 Updated by Riccardo Vitelli almost 10 years ago
- Status changed from Code: Impl to Code: Rev
#19 Updated by Riccardo Vitelli almost 10 years ago
- Assignee changed from Giuseppe Ferro to André Neto
#20 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
Code and documentation review made on revision f7b2aa2. Minor documentation correction pending.
#21 Updated by André Neto almost 10 years ago
- Status changed from Code: Rev to Code: Impl
#22 Updated by André Neto almost 10 years ago
- Assignee changed from André Neto to Giuseppe Ferro
#23 Updated by Riccardo Vitelli almost 10 years ago
- Status changed from Code: Impl to Code: Rev
#24 Updated by Riccardo Vitelli almost 10 years ago
- Assignee deleted (
Giuseppe Ferro)
#25 Updated by Ivan Herrero almost 10 years ago
Source/Core/L0Portability/OperatingSystem/Windows/HighResolutionTimerCalibratorOS.h not fixed.
#26 Updated by Ivan Herrero almost 10 years ago
- Status changed from Code: Rev to Code: Impl
#27 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
#28 Updated by Giuseppe Ferro almost 10 years ago
- Assignee set to Giuseppe Ferro
#29 Updated by Riccardo Vitelli almost 10 years ago
- Status changed from Code: Impl to Code: Rev
#30 Updated by Riccardo Vitelli almost 10 years ago
- Assignee deleted (
Giuseppe Ferro)
#31 Updated by Ivan Herrero almost 10 years ago
- Assignee set to Ivan Herrero
#32 Updated by Ivan Herrero almost 10 years ago
- Description updated (diff)
Code and documentation review made on revision 8e15315 [PASS].
#33 Updated by Riccardo Vitelli almost 10 years ago
- Status changed from Code: Rev to Unit: Impl
#34 Updated by Riccardo Vitelli almost 10 years ago
- Assignee deleted (
Ivan Herrero)
#35 Updated by Riccardo Vitelli almost 10 years ago
- Target version changed from 0.1 to 0.2
#36 Updated by Llorenc Capella over 9 years ago
- Assignee set to Llorenc Capella
#37 Updated by Llorenc Capella over 9 years ago
- Status changed from Unit: Impl to Unit: Rev
#38 Updated by Llorenc Capella over 9 years ago
- Assignee deleted (
Llorenc Capella)
#39 Updated by Ivan Herrero over 9 years ago
- Assignee set to Ivan Herrero
#40 Updated by Ivan Herrero over 9 years ago
- Description updated (diff)
- Status changed from Unit: Rev to Closed
- Assignee deleted (
Ivan Herrero)
Unit test review made on revision 5adc9a3.
#41 Updated by André Neto over 9 years ago
- Description updated (diff)
#42 Updated by André Neto over 9 years ago
- Description updated (diff)
#43 Updated by André Neto over 9 years ago
- Description updated (diff)
Added HighResolutionTimer implementation.
#127 #141