2020-03-13 18:01:09 +08:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2020 Intel Corporation
|
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2020-09-29 15:32:35 +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-03-13 18:01:09 +08:00
|
|
|
|
|
|
|
#include <vector>
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
struct _zes_mem_handle_t {
|
|
|
|
virtual ~_zes_mem_handle_t() = default;
|
2020-03-13 18:01:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
|
|
|
|
struct OsSysman;
|
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
class Memory : _zes_mem_handle_t {
|
2020-03-13 18:01:09 +08:00
|
|
|
public:
|
2020-07-29 17:45:54 +08:00
|
|
|
virtual ze_result_t memoryGetProperties(zes_mem_properties_t *pProperties) = 0;
|
|
|
|
virtual ze_result_t memoryGetBandwidth(zes_mem_bandwidth_t *pBandwidth) = 0;
|
|
|
|
virtual ze_result_t memoryGetState(zes_mem_state_t *pState) = 0;
|
2020-03-13 18:01:09 +08:00
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
static Memory *fromHandle(zes_mem_handle_t handle) {
|
2020-03-13 18:01:09 +08:00
|
|
|
return static_cast<Memory *>(handle);
|
|
|
|
}
|
2020-07-29 17:45:54 +08:00
|
|
|
inline zes_mem_handle_t toHandle() { return this; }
|
2020-08-14 02:03:21 +08:00
|
|
|
bool initSuccess = false;
|
2020-03-13 18:01:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
struct MemoryHandleContext {
|
2020-08-14 02:03:21 +08:00
|
|
|
MemoryHandleContext(OsSysman *pOsSysman) : pOsSysman(pOsSysman){};
|
2020-03-13 18:01:09 +08:00
|
|
|
~MemoryHandleContext();
|
|
|
|
|
2020-09-29 15:32:35 +08:00
|
|
|
ze_result_t init(std::vector<ze_device_handle_t> &deviceHandles);
|
2020-03-13 18:01:09 +08:00
|
|
|
|
2020-07-29 17:45:54 +08:00
|
|
|
ze_result_t memoryGet(uint32_t *pCount, zes_mem_handle_t *phMemory);
|
2020-03-13 18:01:09 +08:00
|
|
|
|
2020-04-11 15:41:07 +08:00
|
|
|
OsSysman *pOsSysman = nullptr;
|
|
|
|
bool isLmemSupported = false;
|
2020-07-14 00:20:32 +08:00
|
|
|
std::vector<Memory *> handleList = {};
|
2020-08-14 02:03:21 +08:00
|
|
|
|
|
|
|
private:
|
2020-09-29 15:32:35 +08:00
|
|
|
void createHandle(ze_device_handle_t deviceHandle);
|
2020-03-13 18:01:09 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace L0
|