mirror of
				https://github.com/dolphin-emu/dolphin.git
				synced 2025-10-25 17:39:09 +00:00 
			
		
		
		
	JitIL: Improved the speed of JitIL time profiler.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@6444 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
		
					parent
					
						
							
								96cdb1ad07
							
						
					
				
			
			
				commit
				
					
						b0c20fe643
					
				
			
		
					 1 changed files with 30 additions and 23 deletions
				
			
		|  | @ -156,34 +156,39 @@ ps_adds1 | ||||||
| #ifdef _WIN32 | #ifdef _WIN32 | ||||||
| // For profiling
 | // For profiling
 | ||||||
| // FIXME: This is currently for windows only.
 | // FIXME: This is currently for windows only.
 | ||||||
| #include <unordered_map> |  | ||||||
| #include <windows.h> | #include <windows.h> | ||||||
|  | #include <intrin.h> | ||||||
| namespace JitILProfiler { | namespace JitILProfiler { | ||||||
| 	struct Performance { | 	struct Block { | ||||||
|  | 		u32 index; | ||||||
|  | 		u64 codeHash; | ||||||
| 		u64 toalElapsed; | 		u64 toalElapsed; | ||||||
| 		u64 numberOfCalls; | 		u64 numberOfCalls; | ||||||
| 		Performance() : toalElapsed(0), numberOfCalls(0) { } | 		Block() : index(0), codeHash(0), toalElapsed(0), numberOfCalls(0) { } | ||||||
| 	}; | 	}; | ||||||
| 	static u64 hash; | 	static std::vector<Block> blocks; | ||||||
|  | 	static u32 blockIndex; | ||||||
| 	static u64 beginTime; | 	static u64 beginTime; | ||||||
| 	// std::map is a bit slow for this purpose.
 | 	static Block& Add(u64 codeHash) { | ||||||
| 	static std::tr1::unordered_map<u64, Performance> profiledData; | 		const u32 blockIndex = blocks.size(); | ||||||
|  | 		blocks.push_back(Block()); | ||||||
|  | 		Block& block = blocks.back(); | ||||||
|  | 		block.index = blockIndex; | ||||||
|  | 		block.codeHash = codeHash; | ||||||
|  | 		return block; | ||||||
|  | 	} | ||||||
| 	// These functions need to be static function
 | 	// These functions need to be static function
 | ||||||
| 	// because they are called with ABI_CallFunction().
 | 	// because they are called with ABI_CallFunction().
 | ||||||
| 	static void Begin(u32 higher, u32 lower) { | 	static void Begin(u32 index) { | ||||||
| 		hash = (((u64)higher) << 32) | lower; | 		blockIndex = index; | ||||||
| 		LARGE_INTEGER largeInteger; | 		beginTime = __rdtsc(); | ||||||
| 		QueryPerformanceCounter(&largeInteger); |  | ||||||
| 		beginTime = largeInteger.QuadPart; |  | ||||||
| 	} | 	} | ||||||
| 	static void End() { | 	static void End() { | ||||||
| 		LARGE_INTEGER largeInteger; | 		const u64 endTime = __rdtsc(); | ||||||
| 		QueryPerformanceCounter(&largeInteger); |  | ||||||
| 		const u64 endTime = largeInteger.QuadPart; |  | ||||||
| 		const u64 duration = endTime - beginTime; | 		const u64 duration = endTime - beginTime; | ||||||
| 		Performance& performance = profiledData[hash]; | 		Block& block = blocks[blockIndex]; | ||||||
| 		performance.toalElapsed += duration; | 		block.toalElapsed += duration; | ||||||
| 		++performance.numberOfCalls; | 		++block.numberOfCalls; | ||||||
| 	} | 	} | ||||||
| 	struct JitILProfilerFinalizer { | 	struct JitILProfilerFinalizer { | ||||||
| 		virtual ~JitILProfilerFinalizer() { | 		virtual ~JitILProfilerFinalizer() { | ||||||
|  | @ -192,10 +197,10 @@ namespace JitILProfiler { | ||||||
| 			FILE* file = fopen(buffer, "w"); | 			FILE* file = fopen(buffer, "w"); | ||||||
| 			setvbuf(file, NULL, _IOFBF, 1024 * 1024); | 			setvbuf(file, NULL, _IOFBF, 1024 * 1024); | ||||||
| 			fprintf(file, "code hash,total elapsed,number of calls,elapsed per call\n"); | 			fprintf(file, "code hash,total elapsed,number of calls,elapsed per call\n"); | ||||||
| 			for (std::tr1::unordered_map<u64, Performance>::iterator it = profiledData.begin(), itEnd = profiledData.end(); it != itEnd; ++it) { | 			for (std::vector<Block>::iterator it = blocks.begin(), itEnd = blocks.end(); it != itEnd; ++it) { | ||||||
| 				const u64 codeHash = it->first; | 				const u64 codeHash = it->codeHash; | ||||||
| 				const u64 totalElapsed = it->second.toalElapsed; | 				const u64 totalElapsed = it->toalElapsed; | ||||||
| 				const u64 numberOfCalls = it->second.numberOfCalls; | 				const u64 numberOfCalls = it->numberOfCalls; | ||||||
| 				const double elapsedPerCall = totalElapsed / (double)numberOfCalls; | 				const double elapsedPerCall = totalElapsed / (double)numberOfCalls; | ||||||
| 				fprintf(file, "%016llx,%lld,%lld,%f\n", codeHash, totalElapsed, numberOfCalls, elapsedPerCall); | 				fprintf(file, "%016llx,%lld,%lld,%f\n", codeHash, totalElapsed, numberOfCalls, elapsedPerCall); | ||||||
| 			} | 			} | ||||||
|  | @ -214,7 +219,8 @@ namespace JitILProfiler { | ||||||
| #else | #else | ||||||
| namespace JitILProfiler { | namespace JitILProfiler { | ||||||
| 	// FIXME: Dummy functions for linux. Please implement them.
 | 	// FIXME: Dummy functions for linux. Please implement them.
 | ||||||
| 	static void Begin(u32 higher, u32 lower) { } | 	static Block& Add(u64 codeHash) { } | ||||||
|  | 	static void Begin(u32 index) { } | ||||||
| 	static void End() { } | 	static void End() { } | ||||||
| 	static void Init() { } | 	static void Init() { } | ||||||
| 	static void Shutdown() { } | 	static void Shutdown() { } | ||||||
|  | @ -565,7 +571,8 @@ const u8* JitIL::DoJit(u32 em_address, PPCAnalyst::CodeBuffer *code_buf, JitBloc | ||||||
| 			// Ported from boost::hash
 | 			// Ported from boost::hash
 | ||||||
| 			codeHash ^= inst + (codeHash << 6) + (codeHash >> 2); | 			codeHash ^= inst + (codeHash << 6) + (codeHash >> 2); | ||||||
| 		} | 		} | ||||||
| 		ABI_CallFunctionCC(JitILProfiler::Begin, (u32)(codeHash >> 32), (u32)codeHash); | 		JitILProfiler::Block& block = JitILProfiler::Add(codeHash); | ||||||
|  | 		ABI_CallFunctionC(JitILProfiler::Begin, block.index); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	// Start up IR builder (structure that collects the
 | 	// Start up IR builder (structure that collects the
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue