mirror of
				https://github.com/RGBCube/serenity
				synced 2025-10-31 17:12:43 +00:00 
			
		
		
		
	 04b9dc2d30
			
		
	
	
		04b9dc2d30
		
	
	
	
	
		
			
			Things were getting a little crowded in the project root, so this patch moves the Lib*/ directories into Libraries/.
		
			
				
	
	
		
			37 lines
		
	
	
	
		
			647 B
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			647 B
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <stdio.h>
 | |
| #include <unistd.h>
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| 
 | |
| struct Stopwatch {
 | |
|     union SplitQword {
 | |
|         struct {
 | |
|             uint32_t lsw;
 | |
|             uint32_t msw;
 | |
|         };
 | |
|         uint64_t qw { 0 };
 | |
|     };
 | |
| 
 | |
| public:
 | |
|     Stopwatch(const char* name)
 | |
|         : m_name(name)
 | |
|     {
 | |
|         read_tsc(&m_start.lsw, &m_start.msw);
 | |
|     }
 | |
| 
 | |
|     ~Stopwatch()
 | |
|     {
 | |
|         SplitQword end;
 | |
|         read_tsc(&end.lsw, &end.msw);
 | |
|         uint64_t diff = end.qw - m_start.qw;
 | |
|         dbgprintf("Stopwatch(%s): %Q ticks\n", m_name, diff);
 | |
|     }
 | |
| 
 | |
| private:
 | |
|     const char* m_name { nullptr };
 | |
|     SplitQword m_start;
 | |
| };
 | |
| 
 | |
| #endif // __cplusplus
 |