2021-10-13 21:30:46 +08:00
|
|
|
/*
|
2022-01-03 22:16:00 +08:00
|
|
|
* Copyright (C) 2021-2022 Intel Corporation
|
2021-10-13 21:30:46 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#pragma once
|
2022-01-31 18:12:51 +08:00
|
|
|
#include "shared/source/utilities/stackvec.h"
|
|
|
|
|
2021-10-13 21:30:46 +08:00
|
|
|
#include "igfxfmid.h"
|
|
|
|
|
|
|
|
#include <cstddef>
|
|
|
|
#include <cstdint>
|
|
|
|
#include <memory>
|
2022-02-01 19:04:09 +08:00
|
|
|
#include <string>
|
2021-12-22 22:25:53 +08:00
|
|
|
#include <vector>
|
2021-10-13 21:30:46 +08:00
|
|
|
|
2022-01-03 22:16:00 +08:00
|
|
|
struct drm_i915_query_item;
|
2022-01-20 02:14:10 +08:00
|
|
|
struct drm_i915_gem_execbuffer2;
|
|
|
|
|
2021-10-13 21:30:46 +08:00
|
|
|
namespace NEO {
|
|
|
|
class Drm;
|
2021-12-01 19:45:29 +08:00
|
|
|
class IoctlHelper;
|
2021-12-10 20:55:55 +08:00
|
|
|
enum class CacheRegion : uint16_t;
|
2022-01-21 02:13:07 +08:00
|
|
|
struct HardwareInfo;
|
2021-10-13 21:30:46 +08:00
|
|
|
|
2021-12-01 19:45:29 +08:00
|
|
|
extern IoctlHelper *ioctlHelperFactory[IGFX_MAX_PRODUCT];
|
2021-10-13 21:30:46 +08:00
|
|
|
|
2021-12-17 21:26:04 +08:00
|
|
|
struct MemoryClassInstance {
|
|
|
|
uint16_t memoryClass;
|
|
|
|
uint16_t memoryInstance;
|
|
|
|
};
|
|
|
|
|
2021-12-29 19:14:26 +08:00
|
|
|
struct EngineClassInstance {
|
|
|
|
uint16_t engineClass;
|
|
|
|
uint16_t engineInstance;
|
|
|
|
};
|
|
|
|
|
2021-12-17 21:26:04 +08:00
|
|
|
struct MemoryRegion {
|
|
|
|
MemoryClassInstance region;
|
|
|
|
uint64_t probedSize;
|
|
|
|
uint64_t unallocatedSize;
|
|
|
|
};
|
|
|
|
|
2022-01-03 22:16:00 +08:00
|
|
|
struct EngineCapabilities {
|
|
|
|
EngineClassInstance engine;
|
|
|
|
uint64_t capabilities;
|
|
|
|
};
|
|
|
|
|
2021-12-29 19:14:26 +08:00
|
|
|
struct DistanceInfo {
|
|
|
|
MemoryClassInstance region;
|
|
|
|
EngineClassInstance engine;
|
|
|
|
int32_t distance;
|
|
|
|
};
|
|
|
|
|
2022-01-31 18:12:51 +08:00
|
|
|
using MemRegionsVec = StackVec<MemoryClassInstance, 5>;
|
|
|
|
|
2021-12-01 19:45:29 +08:00
|
|
|
class IoctlHelper {
|
2021-10-13 21:30:46 +08:00
|
|
|
public:
|
2021-12-08 18:10:27 +08:00
|
|
|
virtual ~IoctlHelper() {}
|
2022-01-21 20:39:11 +08:00
|
|
|
static IoctlHelper *get(const HardwareInfo *hwInfo, const std::string &prelimVersion);
|
2021-10-13 21:30:46 +08:00
|
|
|
static uint32_t ioctl(Drm *drm, unsigned long request, void *arg);
|
2022-01-21 20:39:11 +08:00
|
|
|
virtual IoctlHelper *clone() = 0;
|
2021-11-02 23:59:57 +08:00
|
|
|
|
2022-01-31 18:12:51 +08:00
|
|
|
virtual uint32_t createGemExt(Drm *drm, const MemRegionsVec &memClassInstances, size_t allocSize, uint32_t &handle) = 0;
|
2021-12-22 22:25:53 +08:00
|
|
|
virtual std::vector<MemoryRegion> translateToMemoryRegions(const std::vector<uint8_t> ®ionInfo) = 0;
|
2021-12-10 20:55:55 +08:00
|
|
|
virtual CacheRegion closAlloc(Drm *drm) = 0;
|
|
|
|
virtual uint16_t closAllocWays(Drm *drm, CacheRegion closIndex, uint16_t cacheLevel, uint16_t numWays) = 0;
|
|
|
|
virtual CacheRegion closFree(Drm *drm, CacheRegion closIndex) = 0;
|
2021-12-14 17:46:01 +08:00
|
|
|
virtual int waitUserFence(Drm *drm, uint32_t ctxId, uint64_t address,
|
|
|
|
uint64_t value, uint32_t dataWidth, int64_t timeout, uint16_t flags) = 0;
|
|
|
|
virtual uint32_t getHwConfigIoctlVal() = 0;
|
2021-12-14 22:09:19 +08:00
|
|
|
virtual uint32_t getAtomicAdvise(bool isNonAtomic) = 0;
|
|
|
|
virtual uint32_t getPreferredLocationAdvise() = 0;
|
|
|
|
virtual bool setVmBoAdvise(Drm *drm, int32_t handle, uint32_t attribute, void *region) = 0;
|
2021-12-14 20:41:38 +08:00
|
|
|
virtual uint32_t getDirectSubmissionFlag() = 0;
|
2021-12-28 23:56:13 +08:00
|
|
|
virtual int32_t getMemRegionsIoctlVal() = 0;
|
2022-01-03 22:16:00 +08:00
|
|
|
virtual int32_t getEngineInfoIoctlVal() = 0;
|
|
|
|
virtual std::vector<EngineCapabilities> translateToEngineCaps(const std::vector<uint8_t> &data) = 0;
|
|
|
|
virtual uint32_t queryDistances(Drm *drm, std::vector<drm_i915_query_item> &queryItems, std::vector<DistanceInfo> &distanceInfos) = 0;
|
2022-01-04 22:48:05 +08:00
|
|
|
virtual int32_t getComputeEngineClass() = 0;
|
2022-01-20 02:14:10 +08:00
|
|
|
virtual int execBuffer(Drm *drm, drm_i915_gem_execbuffer2 *execBuffer, uint64_t completionGpuAddress, uint32_t counterValue) = 0;
|
2022-01-21 21:52:04 +08:00
|
|
|
virtual bool completionFenceExtensionSupported(Drm &drm, const HardwareInfo &hwInfo) = 0;
|
2021-12-10 20:55:55 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class IoctlHelperUpstream : public IoctlHelper {
|
|
|
|
public:
|
2022-01-21 20:39:11 +08:00
|
|
|
IoctlHelper *clone() override;
|
|
|
|
|
2022-01-31 18:12:51 +08:00
|
|
|
uint32_t createGemExt(Drm *drm, const MemRegionsVec &memClassInstances, size_t allocSize, uint32_t &handle) override;
|
2021-12-22 22:25:53 +08:00
|
|
|
std::vector<MemoryRegion> translateToMemoryRegions(const std::vector<uint8_t> ®ionInfo) override;
|
2021-12-10 20:55:55 +08:00
|
|
|
CacheRegion closAlloc(Drm *drm) override;
|
|
|
|
uint16_t closAllocWays(Drm *drm, CacheRegion closIndex, uint16_t cacheLevel, uint16_t numWays) override;
|
|
|
|
CacheRegion closFree(Drm *drm, CacheRegion closIndex) override;
|
2021-12-14 17:46:01 +08:00
|
|
|
int waitUserFence(Drm *drm, uint32_t ctxId, uint64_t address,
|
|
|
|
uint64_t value, uint32_t dataWidth, int64_t timeout, uint16_t flags) override;
|
|
|
|
uint32_t getHwConfigIoctlVal() override;
|
2021-12-14 22:09:19 +08:00
|
|
|
uint32_t getAtomicAdvise(bool isNonAtomic) override;
|
|
|
|
uint32_t getPreferredLocationAdvise() override;
|
|
|
|
bool setVmBoAdvise(Drm *drm, int32_t handle, uint32_t attribute, void *region) override;
|
2021-12-14 20:41:38 +08:00
|
|
|
uint32_t getDirectSubmissionFlag() override;
|
2021-12-28 23:56:13 +08:00
|
|
|
int32_t getMemRegionsIoctlVal() override;
|
2022-01-03 22:16:00 +08:00
|
|
|
int32_t getEngineInfoIoctlVal() override;
|
|
|
|
std::vector<EngineCapabilities> translateToEngineCaps(const std::vector<uint8_t> &data) override;
|
|
|
|
uint32_t queryDistances(Drm *drm, std::vector<drm_i915_query_item> &queryItems, std::vector<DistanceInfo> &distanceInfos) override;
|
2022-01-04 22:48:05 +08:00
|
|
|
int32_t getComputeEngineClass() override;
|
2022-01-20 02:14:10 +08:00
|
|
|
int execBuffer(Drm *drm, drm_i915_gem_execbuffer2 *execBuffer, uint64_t completionGpuAddress, uint32_t counterValue) override;
|
2022-01-21 21:52:04 +08:00
|
|
|
bool completionFenceExtensionSupported(Drm &drm, const HardwareInfo &hwInfo) override;
|
2021-10-13 21:30:46 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
template <PRODUCT_FAMILY gfxProduct>
|
2021-12-10 20:55:55 +08:00
|
|
|
class IoctlHelperImpl : public IoctlHelperUpstream {
|
2021-10-13 21:30:46 +08:00
|
|
|
public:
|
2021-12-01 19:45:29 +08:00
|
|
|
static IoctlHelper *get() {
|
|
|
|
static IoctlHelperImpl<gfxProduct> instance;
|
2021-10-13 21:30:46 +08:00
|
|
|
return &instance;
|
|
|
|
}
|
2022-01-21 20:39:11 +08:00
|
|
|
IoctlHelper *clone() override;
|
|
|
|
|
2022-01-31 18:12:51 +08:00
|
|
|
uint32_t createGemExt(Drm *drm, const MemRegionsVec &memClassInstances, size_t allocSize, uint32_t &handle) override;
|
2021-12-22 22:25:53 +08:00
|
|
|
std::vector<MemoryRegion> translateToMemoryRegions(const std::vector<uint8_t> ®ionInfo) override;
|
2021-10-13 21:30:46 +08:00
|
|
|
};
|
|
|
|
|
2021-12-08 18:10:27 +08:00
|
|
|
class IoctlHelperPrelim20 : public IoctlHelper {
|
2021-11-02 23:59:57 +08:00
|
|
|
public:
|
2022-01-21 20:39:11 +08:00
|
|
|
IoctlHelper *clone() override;
|
|
|
|
|
2022-01-31 18:12:51 +08:00
|
|
|
uint32_t createGemExt(Drm *drm, const MemRegionsVec &memClassInstances, size_t allocSize, uint32_t &handle) override;
|
2021-12-22 22:25:53 +08:00
|
|
|
std::vector<MemoryRegion> translateToMemoryRegions(const std::vector<uint8_t> ®ionInfo) override;
|
2021-12-10 20:55:55 +08:00
|
|
|
CacheRegion closAlloc(Drm *drm) override;
|
|
|
|
uint16_t closAllocWays(Drm *drm, CacheRegion closIndex, uint16_t cacheLevel, uint16_t numWays) override;
|
|
|
|
CacheRegion closFree(Drm *drm, CacheRegion closIndex) override;
|
2021-12-14 17:46:01 +08:00
|
|
|
int waitUserFence(Drm *drm, uint32_t ctxId, uint64_t address,
|
|
|
|
uint64_t value, uint32_t dataWidth, int64_t timeout, uint16_t flags) override;
|
|
|
|
uint32_t getHwConfigIoctlVal() override;
|
2021-12-14 22:09:19 +08:00
|
|
|
uint32_t getAtomicAdvise(bool isNonAtomic) override;
|
|
|
|
uint32_t getPreferredLocationAdvise() override;
|
|
|
|
bool setVmBoAdvise(Drm *drm, int32_t handle, uint32_t attribute, void *region) override;
|
2021-12-14 20:41:38 +08:00
|
|
|
uint32_t getDirectSubmissionFlag() override;
|
2021-12-28 23:56:13 +08:00
|
|
|
int32_t getMemRegionsIoctlVal() override;
|
2022-01-03 22:16:00 +08:00
|
|
|
int32_t getEngineInfoIoctlVal() override;
|
|
|
|
std::vector<EngineCapabilities> translateToEngineCaps(const std::vector<uint8_t> &data) override;
|
|
|
|
uint32_t queryDistances(Drm *drm, std::vector<drm_i915_query_item> &queryItems, std::vector<DistanceInfo> &distanceInfos) override;
|
2022-01-04 22:48:05 +08:00
|
|
|
int32_t getComputeEngineClass() override;
|
2022-01-20 02:14:10 +08:00
|
|
|
int execBuffer(Drm *drm, drm_i915_gem_execbuffer2 *execBuffer, uint64_t completionGpuAddress, uint32_t counterValue) override;
|
2022-01-21 21:52:04 +08:00
|
|
|
bool completionFenceExtensionSupported(Drm &drm, const HardwareInfo &hwInfo) override;
|
2021-10-13 21:30:46 +08:00
|
|
|
};
|
2021-11-02 23:59:57 +08:00
|
|
|
|
2021-10-13 21:30:46 +08:00
|
|
|
} // namespace NEO
|