2020-03-06 18:09:57 +08:00
|
|
|
/*
|
2021-05-17 02:51:16 +08:00
|
|
|
* Copyright (C) 2020-2021 Intel Corporation
|
2020-03-06 18:09:57 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
2020-07-23 01:40:20 +08:00
|
|
|
#include "level_zero/core/source/context/context.h"
|
2020-03-19 13:21:57 +08:00
|
|
|
#include "level_zero/core/source/kernel/kernel.h"
|
|
|
|
#include "level_zero/core/source/module/module_build_log.h"
|
2020-03-06 18:09:57 +08:00
|
|
|
#include <level_zero/ze_api.h>
|
|
|
|
|
2020-07-14 21:40:00 +08:00
|
|
|
#include <set>
|
2020-03-06 18:09:57 +08:00
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
struct _ze_module_handle_t {};
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
struct Device;
|
|
|
|
|
2020-11-13 02:53:30 +08:00
|
|
|
enum class ModuleType {
|
|
|
|
Builtin,
|
|
|
|
User
|
|
|
|
};
|
|
|
|
|
2020-03-06 18:09:57 +08:00
|
|
|
struct Module : _ze_module_handle_t {
|
2020-11-13 02:53:30 +08:00
|
|
|
|
|
|
|
static Module *create(Device *device, const ze_module_desc_t *desc, ModuleBuildLog *moduleBuildLog, ModuleType type);
|
2020-03-06 18:09:57 +08:00
|
|
|
|
|
|
|
virtual ~Module() = default;
|
|
|
|
|
|
|
|
virtual Device *getDevice() const = 0;
|
|
|
|
|
|
|
|
virtual ze_result_t createKernel(const ze_kernel_desc_t *desc,
|
|
|
|
ze_kernel_handle_t *phFunction) = 0;
|
|
|
|
virtual ze_result_t destroy() = 0;
|
|
|
|
virtual ze_result_t getNativeBinary(size_t *pSize, uint8_t *pModuleNativeBinary) = 0;
|
|
|
|
virtual ze_result_t getFunctionPointer(const char *pKernelName, void **pfnFunction) = 0;
|
2021-03-19 00:04:09 +08:00
|
|
|
virtual ze_result_t getGlobalPointer(const char *pGlobalName, size_t *pSize, void **pPtr) = 0;
|
2020-03-06 18:09:57 +08:00
|
|
|
virtual ze_result_t getDebugInfo(size_t *pDebugDataSize, uint8_t *pDebugData) = 0;
|
|
|
|
virtual ze_result_t getKernelNames(uint32_t *pCount, const char **pNames) = 0;
|
2020-11-18 00:53:33 +08:00
|
|
|
virtual ze_result_t getProperties(ze_module_properties_t *pModuleProperties) = 0;
|
2020-06-17 22:43:24 +08:00
|
|
|
virtual ze_result_t performDynamicLink(uint32_t numModules,
|
|
|
|
ze_module_handle_t *phModules,
|
|
|
|
ze_module_build_log_handle_t *phLinkLog) = 0;
|
2020-03-06 18:09:57 +08:00
|
|
|
|
|
|
|
virtual const KernelImmutableData *getKernelImmutableData(const char *functionName) const = 0;
|
|
|
|
virtual const std::vector<std::unique_ptr<KernelImmutableData>> &getKernelImmutableDataVector() const = 0;
|
|
|
|
virtual uint32_t getMaxGroupSize() const = 0;
|
2020-03-16 20:34:33 +08:00
|
|
|
virtual bool isDebugEnabled() const = 0;
|
2021-07-24 01:23:42 +08:00
|
|
|
virtual bool shouldAllocatePrivateMemoryPerDispatch() const = 0;
|
|
|
|
virtual void checkIfPrivateMemoryPerDispatchIsNeeded() = 0;
|
2020-03-06 18:09:57 +08:00
|
|
|
|
|
|
|
Module() = default;
|
|
|
|
Module(const Module &) = delete;
|
|
|
|
Module(Module &&) = delete;
|
|
|
|
Module &operator=(const Module &) = delete;
|
|
|
|
Module &operator=(Module &&) = delete;
|
|
|
|
|
|
|
|
static Module *fromHandle(ze_module_handle_t handle) { return static_cast<Module *>(handle); }
|
|
|
|
|
|
|
|
inline ze_module_handle_t toHandle() { return this; }
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace L0
|