Project

General

Profile

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.

Added by André Neto almost 10 years ago. Updated over 9 years ago.

Status:
Closed
Priority:
Normal
Assignee:
-
Target version:
Start date:
Due date:
% Done:

0%

Estimated time:
2.00 h
Git branch (link):
Git merge to develop (link):
SVN commit (link/?p=rev):

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

Revision 8f273cc8 (diff)
Added by Giuseppe Ferrò almost 10 years ago

Added HighResolutionTimer implementation.
#127 #141

Revision db3f4d0f (diff)
Added by Giuseppe Ferrò almost 10 years ago

Solved minor issues
#127 #141

Revision f3cf8733 (diff)
Added by Giuseppe Ferrò almost 10 years ago

Avoided backward include in HighResolutionTimerCalibratorOS.h for windows.
#127 #141

Revision f7b2aa2c (diff)
Added by Giuseppe Ferrò almost 10 years ago

Fixed HighResolutionTimer files accordingly with revision.
#127 #141

Revision 56d3ac79 (diff)
Added by Giuseppe Ferrò almost 10 years ago

Fixed issues accordingly with revision.
#127

Revision 4ef9ffe5 (diff)
Added by Giuseppe Ferrò almost 10 years ago

Corrected code accordingly with revision.
#127

Revision 2857fa72 (diff)
Added by Giuseppe Ferrò almost 10 years ago

Added HighResolutionTimer tests.
#127 #141

Revision 6072de01 (diff)
Added by Llorenc Capella over 9 years ago

#127 Improvement on the documentation

Minor corrections on the function documentation and format.

Revision 5adc9a34 (diff)
Added by Ivan Herrero over 9 years ago

#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)

Also available in: Atom PDF