2020-03-06 18:09:57 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019-2020 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2020-07-03 22:35:35 +08:00
|
|
|
#include "level_zero/core/source/device/device.h"
|
2020-04-07 19:02:52 +08:00
|
|
|
#include "level_zero/tools/source/sysman/engine/engine.h"
|
2020-06-12 03:33:34 +08:00
|
|
|
#include "level_zero/tools/source/sysman/fabric_port/fabric_port.h"
|
2020-03-22 15:52:57 +08:00
|
|
|
#include "level_zero/tools/source/sysman/frequency/frequency.h"
|
2020-07-03 22:35:35 +08:00
|
|
|
#include "level_zero/tools/source/sysman/global_operations/global_operations.h"
|
2020-03-13 18:01:09 +08:00
|
|
|
#include "level_zero/tools/source/sysman/memory/memory.h"
|
2020-03-22 15:52:57 +08:00
|
|
|
#include "level_zero/tools/source/sysman/pci/pci.h"
|
2020-04-28 14:40:46 +08:00
|
|
|
#include "level_zero/tools/source/sysman/power/power.h"
|
2020-04-06 17:56:25 +08:00
|
|
|
#include "level_zero/tools/source/sysman/ras/ras.h"
|
2020-04-09 18:19:35 +08:00
|
|
|
#include "level_zero/tools/source/sysman/scheduler/scheduler.h"
|
2020-03-22 15:52:57 +08:00
|
|
|
#include "level_zero/tools/source/sysman/standby/standby.h"
|
2020-04-24 19:17:09 +08:00
|
|
|
#include "level_zero/tools/source/sysman/temperature/temperature.h"
|
2020-07-29 17:45:54 +08:00
|
|
|
#include <level_zero/zes_api.h>
|
2020-03-06 18:09:57 +08:00
|
|
|
#include <level_zero/zet_api.h>
|
2020-07-03 22:35:35 +08:00
|
|
|
|
2020-03-06 18:09:57 +08:00
|
|
|
#include <unordered_map>
|
|
|
|
|
|
|
|
struct _zet_sysman_handle_t {};
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
|
2020-07-03 22:35:35 +08:00
|
|
|
struct SysmanDevice : _ze_device_handle_t {
|
|
|
|
|
|
|
|
static SysmanDevice *fromHandle(zes_device_handle_t handle) { return Device::fromHandle(handle)->getSysmanHandle(); }
|
|
|
|
|
|
|
|
virtual ze_result_t powerGet(uint32_t *pCount, zes_pwr_handle_t *phPower) = 0;
|
2020-07-24 19:09:09 +08:00
|
|
|
virtual ze_result_t frequencyGet(uint32_t *pCount, zes_freq_handle_t *phFrequency) = 0;
|
2020-07-21 04:06:42 +08:00
|
|
|
virtual ze_result_t fabricPortGet(uint32_t *pCount, zes_fabric_port_handle_t *phPort) = 0;
|
2020-07-29 18:58:08 +08:00
|
|
|
virtual ze_result_t temperatureGet(uint32_t *pCount, zes_temp_handle_t *phTemperature) = 0;
|
2020-07-15 02:36:12 +08:00
|
|
|
virtual ze_result_t standbyGet(uint32_t *pCount, zes_standby_handle_t *phStandby) = 0;
|
2020-07-26 02:23:21 +08:00
|
|
|
virtual ze_result_t deviceGetProperties(zes_device_properties_t *pProperties) = 0;
|
|
|
|
virtual ze_result_t processesGetState(uint32_t *pCount, zes_process_state_t *pProcesses) = 0;
|
|
|
|
virtual ze_result_t deviceReset(ze_bool_t force) = 0;
|
|
|
|
virtual ze_result_t deviceGetState(zes_device_state_t *pState) = 0;
|
2020-07-30 20:31:57 +08:00
|
|
|
virtual ze_result_t engineGet(uint32_t *pCount, zes_engine_handle_t *phEngine) = 0;
|
2020-07-23 09:34:28 +08:00
|
|
|
virtual ze_result_t pciGetProperties(zes_pci_properties_t *pProperties) = 0;
|
|
|
|
virtual ze_result_t pciGetState(zes_pci_state_t *pState) = 0;
|
|
|
|
virtual ze_result_t pciGetBars(uint32_t *pCount, zes_pci_bar_properties_t *pProperties) = 0;
|
|
|
|
virtual ze_result_t pciGetStats(zes_pci_stats_t *pStats) = 0;
|
2020-07-31 18:34:29 +08:00
|
|
|
virtual ze_result_t schedulerGet(uint32_t *pCount, zes_sched_handle_t *phScheduler) = 0;
|
2020-08-05 03:22:42 +08:00
|
|
|
virtual ze_result_t rasGet(uint32_t *pCount, zes_ras_handle_t *phRas) = 0;
|
2020-08-07 10:27:43 +08:00
|
|
|
virtual ze_result_t memoryGet(uint32_t *pCount, zes_mem_handle_t *phMemory) = 0;
|
2020-07-03 22:35:35 +08:00
|
|
|
virtual ~SysmanDevice() = default;
|
|
|
|
};
|
|
|
|
|
|
|
|
class SysmanDeviceHandleContext {
|
|
|
|
public:
|
|
|
|
SysmanDeviceHandleContext() = delete;
|
|
|
|
static SysmanDevice *init(ze_device_handle_t device);
|
|
|
|
};
|
|
|
|
|
2020-03-06 18:09:57 +08:00
|
|
|
} // namespace L0
|