JitIL: Removed ENABLE_JITIL_PROFILING macro and added an entry in setting file.

git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@6443 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
nodchip 2010-11-19 07:48:48 +00:00
parent 13370ca6ca
commit 96cdb1ad07
4 changed files with 53 additions and 27 deletions

View File

@ -282,6 +282,7 @@ void SConfig::LoadSettings()
ini.Get("Core", "SlotB", (int*)&m_EXIDevice[1], EXIDEVICE_MEMORYCARD_B); ini.Get("Core", "SlotB", (int*)&m_EXIDevice[1], EXIDEVICE_MEMORYCARD_B);
ini.Get("Core", "SerialPort1", (int*)&m_EXIDevice[2], EXIDEVICE_NONE); ini.Get("Core", "SerialPort1", (int*)&m_EXIDevice[2], EXIDEVICE_NONE);
ini.Get("Core", "ProfiledReJIT",&m_LocalCoreStartupParameter.bJITProfiledReJIT, false); ini.Get("Core", "ProfiledReJIT",&m_LocalCoreStartupParameter.bJITProfiledReJIT, false);
ini.Get("Core", "TimeProfiling",&m_LocalCoreStartupParameter.bJITILTimeProfiling, false);
char sidevicenum[16]; char sidevicenum[16];
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
{ {

View File

@ -40,6 +40,7 @@ SCoreStartupParameter::SCoreStartupParameter()
bJITFloatingPointOff(false), bJITIntegerOff(false), bJITFloatingPointOff(false), bJITIntegerOff(false),
bJITPairedOff(false), bJITSystemRegistersOff(false), bJITPairedOff(false), bJITSystemRegistersOff(false),
bJITBranchOff(false), bJITProfiledReJIT(false), bJITBranchOff(false), bJITProfiledReJIT(false),
bJITILTimeProfiling(false),
bEnableFPRF(false), bEnableFPRF(false),
bCPUThread(true), bDSPThread(false), bCPUThread(true), bDSPThread(false),
bSkipIdle(true), bNTSC(false), bNTSCJ(false), bSkipIdle(true), bNTSC(false), bNTSCJ(false),

View File

@ -62,6 +62,7 @@ struct SCoreStartupParameter
bool bJITSystemRegistersOff; bool bJITSystemRegistersOff;
bool bJITBranchOff; bool bJITBranchOff;
bool bJITProfiledReJIT; bool bJITProfiledReJIT;
bool bJITILTimeProfiling;
bool bEnableFPRF; bool bEnableFPRF;

View File

@ -25,6 +25,7 @@
#include "../../Core.h" #include "../../Core.h"
#include "../../PatchEngine.h" #include "../../PatchEngine.h"
#include "../../CoreTiming.h" #include "../../CoreTiming.h"
#include "../../ConfigManager.h"
#include "../PowerPC.h" #include "../PowerPC.h"
#include "../Profiler.h" #include "../Profiler.h"
#include "../PPCTables.h" #include "../PPCTables.h"
@ -152,8 +153,7 @@ ps_adds1
*/ */
//#define ENABLE_JITIL_PROFILING #ifdef _WIN32
#ifdef ENABLE_JITIL_PROFILING
// For profiling // For profiling
// FIXME: This is currently for windows only. // FIXME: This is currently for windows only.
#include <unordered_map> #include <unordered_map>
@ -170,13 +170,13 @@ namespace JitILProfiler {
static std::tr1::unordered_map<u64, Performance> profiledData; static std::tr1::unordered_map<u64, Performance> profiledData;
// 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 higher, u32 lower) {
hash = (((u64)higher) << 32) | lower; hash = (((u64)higher) << 32) | lower;
LARGE_INTEGER largeInteger; LARGE_INTEGER largeInteger;
QueryPerformanceCounter(&largeInteger); QueryPerformanceCounter(&largeInteger);
beginTime = largeInteger.QuadPart; beginTime = largeInteger.QuadPart;
} }
static void end() { static void End() {
LARGE_INTEGER largeInteger; LARGE_INTEGER largeInteger;
QueryPerformanceCounter(&largeInteger); QueryPerformanceCounter(&largeInteger);
const u64 endTime = largeInteger.QuadPart; const u64 endTime = largeInteger.QuadPart;
@ -202,7 +202,22 @@ namespace JitILProfiler {
fclose(file); fclose(file);
file = NULL; file = NULL;
} }
} finalizer; // Is this a bad manner? };
std::auto_ptr<JitILProfilerFinalizer> finalizer;
static void Init() {
finalizer = std::auto_ptr<JitILProfilerFinalizer>(new JitILProfilerFinalizer);
}
static void Shutdown() {
finalizer.reset();
}
};
#else
namespace JitILProfiler {
// FIXME: Dummy functions for linux. Please implement them.
static void Begin(u32 higher, u32 lower) { }
static void End() { }
static void Init() { }
static void Shutdown() { }
}; };
#endif #endif
@ -248,6 +263,10 @@ void JitIL::Init()
blocks.Init(); blocks.Init();
asm_routines.Init(); asm_routines.Init();
if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
JitILProfiler::Init();
}
} }
void JitIL::ClearCache() void JitIL::ClearCache()
@ -259,6 +278,10 @@ void JitIL::ClearCache()
void JitIL::Shutdown() void JitIL::Shutdown()
{ {
if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
JitILProfiler::Shutdown();
}
FreeCodeSpace(); FreeCodeSpace();
blocks.Shutdown(); blocks.Shutdown();
@ -346,9 +369,9 @@ void JitIL::Cleanup()
void JitIL::WriteExit(u32 destination, int exit_num) void JitIL::WriteExit(u32 destination, int exit_num)
{ {
Cleanup(); Cleanup();
#ifdef ENABLE_JITIL_PROFILING if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
ABI_CallFunction(JitILProfiler::end); ABI_CallFunction(JitILProfiler::End);
#endif }
SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount)); SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount));
//If nobody has taken care of this yet (this can be removed when all branches are done) //If nobody has taken care of this yet (this can be removed when all branches are done)
@ -375,9 +398,9 @@ void JitIL::WriteExitDestInOpArg(const Gen::OpArg& arg)
{ {
MOV(32, M(&PC), arg); MOV(32, M(&PC), arg);
Cleanup(); Cleanup();
#ifdef ENABLE_JITIL_PROFILING if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
ABI_CallFunction(JitILProfiler::end); ABI_CallFunction(JitILProfiler::End);
#endif }
SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount)); SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount));
JMP(asm_routines.dispatcher, true); JMP(asm_routines.dispatcher, true);
} }
@ -386,9 +409,9 @@ void JitIL::WriteRfiExitDestInOpArg(const Gen::OpArg& arg)
{ {
MOV(32, M(&PC), arg); MOV(32, M(&PC), arg);
Cleanup(); Cleanup();
#ifdef ENABLE_JITIL_PROFILING if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
ABI_CallFunction(JitILProfiler::end); ABI_CallFunction(JitILProfiler::End);
#endif }
SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount)); SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount));
JMP(asm_routines.testExceptions, true); JMP(asm_routines.testExceptions, true);
} }
@ -396,9 +419,9 @@ void JitIL::WriteRfiExitDestInOpArg(const Gen::OpArg& arg)
void JitIL::WriteExceptionExit() void JitIL::WriteExceptionExit()
{ {
Cleanup(); Cleanup();
#ifdef ENABLE_JITIL_PROFILING if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
ABI_CallFunction(JitILProfiler::end); ABI_CallFunction(JitILProfiler::End);
#endif }
SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount)); SUB(32, M(&CoreTiming::downcount), js.downcountAmount > 127 ? Imm32(js.downcountAmount) : Imm8(js.downcountAmount));
JMP(asm_routines.testExceptions, true); JMP(asm_routines.testExceptions, true);
} }
@ -533,17 +556,17 @@ const u8* JitIL::DoJit(u32 em_address, PPCAnalyst::CodeBuffer *code_buf, JitBloc
js.rewriteStart = (u8*)GetCodePtr(); js.rewriteStart = (u8*)GetCodePtr();
#ifdef ENABLE_JITIL_PROFILING if (SConfig::GetInstance().m_LocalCoreStartupParameter.bJITILTimeProfiling) {
// For profiling // For profiling
u64 codeHash = -1; u64 codeHash = -1;
for (int i = 0; i < (int)size; i++) for (int i = 0; i < (int)size; i++)
{ {
const u64 inst = ops[i].inst.hex; const u64 inst = ops[i].inst.hex;
// 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);
} }
ABI_CallFunctionCC(JitILProfiler::begin, (u32)(codeHash >> 32), (u32)codeHash);
#endif
// Start up IR builder (structure that collects the // Start up IR builder (structure that collects the
// instruction processed by the JIT routines) // instruction processed by the JIT routines)