2020-02-10 22:57:49 +08:00
|
|
|
/*
|
2023-01-18 22:41:50 +08:00
|
|
|
* Copyright (C) 2020-2023 Intel Corporation
|
2020-02-10 22:57:49 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#include <memory>
|
|
|
|
namespace NEO {
|
|
|
|
struct HardwareInfo;
|
2022-04-20 22:12:20 +08:00
|
|
|
class LinearStream;
|
2020-07-23 16:56:08 +08:00
|
|
|
class IndirectHeap;
|
2020-10-17 06:52:18 +08:00
|
|
|
struct DebugData;
|
|
|
|
class GraphicsAllocation;
|
2022-11-15 00:34:34 +08:00
|
|
|
struct RootDeviceEnvironment;
|
2020-07-27 23:37:51 +08:00
|
|
|
|
2020-02-10 22:57:49 +08:00
|
|
|
class Debugger {
|
|
|
|
public:
|
2020-08-24 15:27:30 +08:00
|
|
|
struct SbaAddresses {
|
2022-04-20 22:12:20 +08:00
|
|
|
constexpr static size_t trackedAddressCount = 6;
|
2023-04-28 17:38:31 +08:00
|
|
|
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;
|
2020-08-24 15:27:30 +08:00
|
|
|
};
|
|
|
|
|
2020-02-10 22:57:49 +08:00
|
|
|
virtual ~Debugger() = default;
|
2022-11-23 04:07:45 +08:00
|
|
|
virtual void captureStateBaseAddress(NEO::LinearStream &cmdStream, SbaAddresses sba, bool useFirstLevelBB) = 0;
|
2022-04-20 22:12:20 +08:00
|
|
|
virtual size_t getSbaTrackingCommandsSize(size_t trackedAddressCount) = 0;
|
|
|
|
|
2020-07-23 16:56:08 +08:00
|
|
|
void *getDebugSurfaceReservedSurfaceState(IndirectHeap &ssh);
|
|
|
|
|
2020-11-16 23:24:54 +08:00
|
|
|
inline static bool isDebugEnabled(bool internalUsage) {
|
|
|
|
return !internalUsage;
|
|
|
|
}
|
2020-02-10 22:57:49 +08:00
|
|
|
};
|
2022-04-20 22:12:20 +08:00
|
|
|
|
2023-01-18 22:41:50 +08:00
|
|
|
enum class DebuggingMode : uint32_t {
|
2023-12-12 19:37:31 +08:00
|
|
|
disabled,
|
|
|
|
online,
|
|
|
|
offline
|
2023-01-18 22:41:50 +08:00
|
|
|
};
|
|
|
|
|
2023-03-16 20:03:21 +08:00
|
|
|
inline DebuggingMode getDebuggingMode(uint32_t programDebugging) {
|
|
|
|
switch (programDebugging) {
|
|
|
|
case 1: {
|
2023-12-12 19:37:31 +08:00
|
|
|
return DebuggingMode::online;
|
2023-03-16 20:03:21 +08:00
|
|
|
}
|
|
|
|
case 2: {
|
2023-12-12 19:37:31 +08:00
|
|
|
return DebuggingMode::offline;
|
2023-03-16 20:03:21 +08:00
|
|
|
}
|
|
|
|
case 0:
|
|
|
|
default: {
|
2023-12-12 19:37:31 +08:00
|
|
|
return DebuggingMode::disabled;
|
2023-03-16 20:03:21 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-04-20 22:12:20 +08:00
|
|
|
static_assert(std::is_standard_layout<Debugger::SbaAddresses>::value);
|
2023-12-12 19:37:31 +08:00
|
|
|
} // namespace NEO
|