2020-04-06 17:56:25 +08:00
|
|
|
/*
|
2023-03-24 15:32:22 +08:00
|
|
|
* Copyright (C) 2020-2023 Intel Corporation
|
2020-04-06 17:56:25 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2023-03-24 15:32:22 +08:00
|
|
|
#include "level_zero/api/sysman/zes_handles_struct.h"
|
2020-10-23 11:29:36 +08:00
|
|
|
#include "level_zero/core/source/device/device.h"
|
2020-07-29 17:45:54 +08:00
|
|
|
#include <level_zero/zes_api.h>
|
2020-04-06 17:56:25 +08:00
|
|
|
|
2022-07-02 18:23:53 +08:00
|
|
|
#include <mutex>
|
2020-04-06 17:56:25 +08:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
|
|
|
|
struct OsSysman;
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
class Ras : _zes_ras_handle_t {
|
2020-04-06 17:56:25 +08:00
|
|
|
public:
|
2020-07-29 17:45:54 +08:00
|
|
|
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;
|
2021-01-07 18:28:00 +08:00
|
|
|
virtual ze_result_t rasGetState(zes_ras_state_t *pState, ze_bool_t clear) = 0;
|
2020-04-06 17:56:25 +08:00
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
static Ras *fromHandle(zes_ras_handle_t handle) {
|
2020-04-06 17:56:25 +08:00
|
|
|
return static_cast<Ras *>(handle);
|
|
|
|
}
|
2020-07-29 17:45:54 +08:00
|
|
|
inline zes_ras_handle_t toHandle() { return this; }
|
2020-06-15 19:03:11 +08:00
|
|
|
bool isRasErrorSupported = false;
|
2022-03-12 08:52:01 +08:00
|
|
|
zes_ras_error_type_t rasErrorType{};
|
2020-04-06 17:56:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct RasHandleContext {
|
|
|
|
RasHandleContext(OsSysman *pOsSysman) : pOsSysman(pOsSysman){};
|
2021-12-03 15:08:10 +08:00
|
|
|
MOCKABLE_VIRTUAL ~RasHandleContext();
|
2020-04-06 17:56:25 +08:00
|
|
|
|
2021-12-03 15:08:10 +08:00
|
|
|
MOCKABLE_VIRTUAL void init(std::vector<ze_device_handle_t> &deviceHandles);
|
2021-04-14 20:30:33 +08:00
|
|
|
void releaseRasHandles();
|
2020-04-06 17:56:25 +08:00
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
ze_result_t rasGet(uint32_t *pCount, zes_ras_handle_t *phRas);
|
2020-04-06 17:56:25 +08:00
|
|
|
|
|
|
|
OsSysman *pOsSysman = nullptr;
|
2020-07-14 00:20:32 +08:00
|
|
|
std::vector<Ras *> handleList = {};
|
2022-08-11 21:42:59 +08:00
|
|
|
bool isRasInitDone() {
|
|
|
|
return rasInitDone;
|
|
|
|
}
|
2020-06-15 19:03:11 +08:00
|
|
|
|
|
|
|
private:
|
2020-10-23 11:29:36 +08:00
|
|
|
void createHandle(zes_ras_error_type_t type, ze_device_handle_t deviceHandle);
|
2022-07-02 18:23:53 +08:00
|
|
|
std::once_flag initRasOnce;
|
2022-08-11 21:42:59 +08:00
|
|
|
bool rasInitDone = false;
|
2020-04-06 17:56:25 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace L0
|