42 lines
738 B
C++
42 lines
738 B
C++
/*
|
|
* Copyright (C) 2024 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <cstdint>
|
|
#include <string>
|
|
|
|
namespace NEO {
|
|
|
|
enum class FaultType : uint16_t {
|
|
notPresent = 0b00,
|
|
writeAccessViolation = 0b01,
|
|
atomicAccessViolation = 0b10
|
|
};
|
|
enum class FaultAccess : uint16_t {
|
|
read = 0b00,
|
|
write = 0b01,
|
|
atomic = 0b10
|
|
};
|
|
enum class FaultLevel : uint16_t {
|
|
pte = 0b000,
|
|
pde = 0b001,
|
|
pdp = 0b010,
|
|
pml4 = 0b011,
|
|
pml5 = 0b0100
|
|
};
|
|
|
|
namespace GpuPageFaultHelpers {
|
|
|
|
std::string faultTypeToString(FaultType type);
|
|
std::string faultAccessToString(FaultAccess access);
|
|
std::string faultLevelToString(FaultLevel level);
|
|
|
|
} // namespace GpuPageFaultHelpers
|
|
|
|
} // namespace NEO
|