mirror of
https://github.com/intel/compute-runtime.git
synced 2026-01-08 05:56:36 +08:00
feature: Add support for V3 state save header
Related-to: NEO-8396 Signed-off-by: Brandon Yates <brandon.yates@intel.com>
This commit is contained in:
committed by
Compute-Runtime-Automation
parent
ef37b140de
commit
ab92499b56
@@ -5,6 +5,7 @@
|
||||
*
|
||||
*/
|
||||
|
||||
#include "shared/source/debugger/debugger_l0.h"
|
||||
#include "shared/source/device/device.h"
|
||||
#include "shared/source/helpers/gfx_core_helper.h"
|
||||
#include "shared/source/memory_manager/memory_allocation.h"
|
||||
@@ -126,6 +127,61 @@ std::vector<char> createStateSaveAreaHeader(uint32_t version, uint16_t grfNum, u
|
||||
},
|
||||
};
|
||||
|
||||
SIP::StateSaveArea versionHeader = {
|
||||
// versionHeader
|
||||
"tssarea", // magic
|
||||
0, // reserved1
|
||||
{ // version
|
||||
3, // major
|
||||
0, // minor
|
||||
0}, // patch
|
||||
53, // size
|
||||
{0, 0, 0}, // reserved2
|
||||
};
|
||||
SIP::intelgt_state_save_area_V3 regHeaderV3 = {
|
||||
// regHeader
|
||||
1, // num_slices
|
||||
1, // num_subslices_per_slice
|
||||
8, // num_eus_per_subslice
|
||||
7, // num_threads_per_eu
|
||||
0, // state_area_offset
|
||||
6144, // state_save_size
|
||||
0, // slm_area_offset
|
||||
0, // slm_bank_size
|
||||
0, // reserved0
|
||||
4740, // sr_magic_offset
|
||||
0, // fifo_offset;
|
||||
0, // fifo_size;
|
||||
0, // fifo_head;
|
||||
0, // fifo_tail;
|
||||
0, // fifo_version;
|
||||
{0, 0, 0, 0, 0, 0, 0, 0, 0, 0}, // reserved1[10];
|
||||
SIP::SIP_FLAG_HEAPLESS, // sip_flags;
|
||||
{0, grfNum, 256, 32}, // grf
|
||||
{4096, 1, 256, 32}, // addr
|
||||
{4128, 2, 32, 4}, // flag
|
||||
{4156, 1, 32, 4}, // emask
|
||||
{4160, 2, 128, 16}, // sr
|
||||
{4192, 1, 128, 16}, // cr
|
||||
{4256, 1, 96, 12}, // notification
|
||||
{4288, 1, 128, 16}, // tdr
|
||||
{4320, 10, 256, 32}, // acc
|
||||
{4320, mmeNum, 256, 32}, // mme
|
||||
{4672, 1, 32, 4}, // ce
|
||||
{4704, 1, 128, 16}, // sp
|
||||
{4768, 1, 128 * 8, 128}, // cmd
|
||||
{4640, 1, 128, 16}, // tm
|
||||
{0, 1, 32, 4}, // fc
|
||||
{4736, 1, 32, 4}, // dbg
|
||||
{4744, 1, 64, 8}, // ctx
|
||||
{4752, 1, 64, 8}, // dbg_reg
|
||||
{4760, 1, 64, 8}, // scalar
|
||||
{4768, 1, 64, 8}, // msg
|
||||
};
|
||||
NEO::StateSaveAreaHeader stateSaveAreaHeader3 = {};
|
||||
stateSaveAreaHeader3.versionHeader = versionHeader;
|
||||
stateSaveAreaHeader3.regHeaderV3 = regHeaderV3;
|
||||
|
||||
char *begin = nullptr;
|
||||
unsigned long sizeOfHeader = 0u;
|
||||
if (version == 1) {
|
||||
@@ -134,6 +190,9 @@ std::vector<char> createStateSaveAreaHeader(uint32_t version, uint16_t grfNum, u
|
||||
} else if (version == 2) {
|
||||
begin = reinterpret_cast<char *>(&stateSaveAreaHeader2);
|
||||
sizeOfHeader = offsetof(SIP::StateSaveAreaHeader, regHeader.dbg_reg) + sizeof(SIP::StateSaveAreaHeader::regHeader.dbg_reg);
|
||||
} else if (version == 3) {
|
||||
begin = reinterpret_cast<char *>(&stateSaveAreaHeader3);
|
||||
sizeOfHeader = offsetof(NEO::StateSaveAreaHeader, regHeaderV3.msg) + sizeof(NEO::StateSaveAreaHeader::regHeaderV3.msg);
|
||||
}
|
||||
|
||||
return std::vector<char>(begin, begin + sizeOfHeader);
|
||||
|
||||
Reference in New Issue
Block a user