x64 Code Cache: Notify Intel VTune of generated functions.
This commit is contained in:
parent
78433f70bd
commit
5ed086f03f
|
@ -19,6 +19,11 @@ project("xenia-cpu-backend-x64")
|
||||||
"CAPSTONE_USE_SYS_DYN_MEM",
|
"CAPSTONE_USE_SYS_DYN_MEM",
|
||||||
"XBYAK_NO_OP_NAMES",
|
"XBYAK_NO_OP_NAMES",
|
||||||
})
|
})
|
||||||
|
-- Enable VTune, if it's installed.
|
||||||
|
if os.isdir(project_root.."/third_party/vtune") then
|
||||||
|
defines { "ENABLE_VTUNE=1" }
|
||||||
|
end
|
||||||
|
|
||||||
includedirs({
|
includedirs({
|
||||||
project_root.."/third_party/capstone/include",
|
project_root.."/third_party/capstone/include",
|
||||||
project_root.."/third_party/gflags/src",
|
project_root.."/third_party/gflags/src",
|
||||||
|
|
|
@ -12,12 +12,18 @@
|
||||||
#include <cstdlib>
|
#include <cstdlib>
|
||||||
#include <cstring>
|
#include <cstring>
|
||||||
|
|
||||||
|
#if ENABLE_VTUNE
|
||||||
|
#include "third_party/vtune/include/jitprofiling.h"
|
||||||
|
#pragma comment(lib, "../third_party/vtune/lib64/jitprofiling.lib")
|
||||||
|
#endif
|
||||||
|
|
||||||
#include "xenia/base/assert.h"
|
#include "xenia/base/assert.h"
|
||||||
#include "xenia/base/clock.h"
|
#include "xenia/base/clock.h"
|
||||||
#include "xenia/base/logging.h"
|
#include "xenia/base/logging.h"
|
||||||
#include "xenia/base/math.h"
|
#include "xenia/base/math.h"
|
||||||
#include "xenia/base/memory.h"
|
#include "xenia/base/memory.h"
|
||||||
#include "xenia/cpu/function.h"
|
#include "xenia/cpu/function.h"
|
||||||
|
#include "xenia/cpu/module.h"
|
||||||
|
|
||||||
namespace xe {
|
namespace xe {
|
||||||
namespace cpu {
|
namespace cpu {
|
||||||
|
@ -190,6 +196,27 @@ void* X64CodeCache::PlaceGuestCode(uint32_t guest_address, void* machine_code,
|
||||||
unwind_reservation);
|
unwind_reservation);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#if ENABLE_VTUNE
|
||||||
|
if (iJIT_IsProfilingActive() == iJIT_SAMPLING_ON) {
|
||||||
|
std::string method_name;
|
||||||
|
if (function_info && function_info->name().size() != 0) {
|
||||||
|
method_name = function_info->name();
|
||||||
|
} else {
|
||||||
|
method_name = xe::format_string("sub_%.8X", guest_address);
|
||||||
|
}
|
||||||
|
|
||||||
|
iJIT_Method_Load_V2 method = {0};
|
||||||
|
method.method_id = iJIT_GetNewMethodID();
|
||||||
|
method.method_load_address = code_address;
|
||||||
|
method.method_size = uint32_t(code_size);
|
||||||
|
method.method_name = const_cast<char*>(method_name.data());
|
||||||
|
method.module_name = function_info
|
||||||
|
? (char*)function_info->module()->name().c_str()
|
||||||
|
: nullptr;
|
||||||
|
iJIT_NotifyEvent(iJVM_EVENT_TYPE_METHOD_LOAD_FINISHED_V2, (void*)&method);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// Now that everything is ready, fix up the indirection table.
|
// Now that everything is ready, fix up the indirection table.
|
||||||
// Note that we do support code that doesn't have an indirection fixup, so
|
// Note that we do support code that doesn't have an indirection fixup, so
|
||||||
// ignore those when we see them.
|
// ignore those when we see them.
|
||||||
|
|
Loading…
Reference in New Issue