Functions/GenXdev.Helpers/HiPerfTimer.cs
// ################################################################################
// Part of PowerShell module : GenXdev.Helpers // Original cmdlet filename : HiPerfTimer.cs // Original author : René Vaessen / GenXdev // Version : 1.300.2025 // ################################################################################ // Copyright (c) René Vaessen / GenXdev // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. // ################################################################################ namespace GenXdev.Additional.HiPerfTimer { public class NativeMethods { [System.Runtime.InteropServices.DllImport("Kernel32.dll")] [System.Security.SuppressUnmanagedCodeSecurity()] private static extern bool QueryPerformanceCounter(out long lpPerformanceCount); [System.Runtime.InteropServices.DllImport("Kernel32.dll")] [System.Security.SuppressUnmanagedCodeSecurity()] private static extern bool QueryPerformanceFrequency(out long lpFrequency); private long startTime; private long stopTime; public bool stopped = true; private long freq; public NativeMethods(bool StartNow = false) { Interlocked.Exchange(ref startTime, 0); Interlocked.Exchange(ref stopTime, 0); freq = 0; if (QueryPerformanceFrequency(out freq) == false) { throw new Exception("Timer not supported"); } if (StartNow) Start(); } /// <summary> /// Start the timer /// </summary> /// <returns>long - tick count</returns> public long Start() { stopped = false; //startTime2 = DateTime.Now; QueryPerformanceCounter(out long startTimeTmp); Interlocked.Exchange(ref startTime, startTimeTmp); return startTimeTmp; } /// <summary> /// Stop timer /// </summary> /// <returns>long - tick count</returns> public long Stop() { stopped = true; //stopTime2 = DateTime.Now; QueryPerformanceCounter(out long stopTimeTmp); Interlocked.Exchange(ref stopTime, stopTimeTmp); return stopTimeTmp; } /// <summary> /// Return the duration of the timer (in seconds) /// </summary> /// <returns>double - duration</returns> public double Duration { get { if (stopped) { return Convert.ToDouble(Interlocked.Read(ref stopTime) - Interlocked.Read(ref startTime)) / freq; } QueryPerformanceCounter(out long now); return Convert.ToDouble(now - Interlocked.Read(ref startTime)) / freq; } } /// <summary> /// Frequency of timer (no counts in one second on this machine) /// </summary> ///<returns>long - Frequency</returns> public long Frequency { get { return freq; } } public void Reset() { QueryPerformanceCounter(out long now); Interlocked.Exchange(ref startTime, now); } } } |