File: timer.cpp

package info (click to toggle)
sight 25.1.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 43,252 kB
  • sloc: cpp: 310,629; xml: 17,622; ansic: 9,960; python: 1,379; sh: 144; makefile: 33
file content (62 lines) | stat: -rw-r--r-- 2,038 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
/************************************************************************
 *
 * Copyright (C) 2009-2024 IRCAD France
 * Copyright (C) 2012-2015 IHU Strasbourg
 *
 * This file is part of Sight.
 *
 * Sight is free software: you can redistribute it and/or modify it under
 * the terms of the GNU Lesser General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * Sight is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General Public
 * License along with Sight. If not, see <https://www.gnu.org/licenses/>.
 *
 ***********************************************************************/

#include "core/thread/timer.hpp"

#ifdef _WIN32
// for timeBeginPeriod and timeEndPeriod
#include <Windows.h>
#endif

namespace sight::core::thread
{

#ifdef _WIN32
/**
 * @brief Set the Windows timer precision.
 *
 * This is absolutely needed to have precise std::this_thread::sleep_for (indeed, all "timed" functions), otherwise the
 * windows scheduler resolution (1/64 seconds or ~15.62 ms) will be used. This would implicitly limit timers frequency
 * to 64 Hz, which can be too low.
 *
 * @note This is a process wide settings
 *
 * @see https://learn.microsoft.com/en-us/windows/win32/api/timeapi/nf-timeapi-timebeginperiod
 */
const static struct timer_precision
{
    timer_precision()
    {
        // Set the timer precision to 1 ms on windows for the current process
        timeBeginPeriod(1);
    }

    ~timer_precision()
    {
        // Restore the timer precision. An application must match each call to timeBeginPeriod and timeEndPeriod
        // The parameter must match the one used for timeBeginPeriod
        timeEndPeriod(1);
    }
} timer_precision;
#endif

} //namespace sight::core::thread