mirror of
https://github.com/intel/compute-runtime.git
synced 2025-12-20 08:53:55 +08:00
Related-To: NEO-4637 Change-Id: I0cd0cf17bac332f1a00c10a324f94e91fe031c0a Signed-off-by: Mateusz Hoppe <mateusz.hoppe@intel.com>
38 lines
1018 B
C++
38 lines
1018 B
C++
/*
|
|
* Copyright (C) 2020 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
#include <memory>
|
|
namespace NEO {
|
|
struct HardwareInfo;
|
|
class CommandContainer;
|
|
class IndirectHeap;
|
|
|
|
class Debugger {
|
|
public:
|
|
struct SbaAddresses {
|
|
uint64_t GeneralStateBaseAddress = 0;
|
|
uint64_t SurfaceStateBaseAddress = 0;
|
|
uint64_t DynamicStateBaseAddress = 0;
|
|
uint64_t IndirectObjectBaseAddress = 0;
|
|
uint64_t InstructionBaseAddress = 0;
|
|
uint64_t BindlessSurfaceStateBaseAddress = 0;
|
|
uint64_t BindlessSamplerStateBaseAddress = 0;
|
|
};
|
|
|
|
static std::unique_ptr<Debugger> create(HardwareInfo *hwInfo);
|
|
virtual ~Debugger() = default;
|
|
virtual bool isDebuggerActive() = 0;
|
|
bool isLegacy() const { return isLegacyMode; }
|
|
virtual void captureStateBaseAddress(CommandContainer &container, SbaAddresses sba) = 0;
|
|
|
|
void *getDebugSurfaceReservedSurfaceState(IndirectHeap &ssh);
|
|
|
|
protected:
|
|
bool isLegacyMode = true;
|
|
};
|
|
} // namespace NEO
|