Files
compute-runtime/level_zero/tools/source/sysman/ras/ras.h
mraghuwa 978003e96e Add subdevice support for RAS module
Change-Id: Iced5aeed86d6b19a4710992155257e420ae1296f
Signed-off-by: mraghuwa <mayank.raghuwanshi@intel.com>
2020-10-27 17:54:29 +01:00

53 lines
1.3 KiB
C++

/*
* Copyright (C) 2020 Intel Corporation
*
* SPDX-License-Identifier: MIT
*
*/
#pragma once
#include "level_zero/core/source/device/device.h"
#include <level_zero/zes_api.h>
#include <vector>
struct _zes_ras_handle_t {
virtual ~_zes_ras_handle_t() = default;
};
namespace L0 {
struct OsSysman;
class Ras : _zes_ras_handle_t {
public:
virtual ze_result_t rasGetProperties(zes_ras_properties_t *pProperties) = 0;
virtual ze_result_t rasGetConfig(zes_ras_config_t *pConfig) = 0;
virtual ze_result_t rasSetConfig(const zes_ras_config_t *pConfig) = 0;
virtual ze_result_t rasGetState(zes_ras_state_t *pState) = 0;
static Ras *fromHandle(zes_ras_handle_t handle) {
return static_cast<Ras *>(handle);
}
inline zes_ras_handle_t toHandle() { return this; }
bool isRasErrorSupported = false;
zes_ras_error_type_t rasErrorType;
};
struct RasHandleContext {
RasHandleContext(OsSysman *pOsSysman) : pOsSysman(pOsSysman){};
~RasHandleContext();
void init(std::vector<ze_device_handle_t> &deviceHandles);
ze_result_t rasGet(uint32_t *pCount, zes_ras_handle_t *phRas);
OsSysman *pOsSysman = nullptr;
std::vector<Ras *> handleList = {};
private:
void createHandle(zes_ras_error_type_t type, ze_device_handle_t deviceHandle);
};
} // namespace L0