mirror of
https://github.com/intel/compute-runtime.git
synced 2025-09-15 13:01:45 +08:00

If prelim kernel is being used, query engines with prelim ioctls. Signed-off-by: Szymon Morek <szymon.morek@intel.com>
124 lines
3.7 KiB
C++
124 lines
3.7 KiB
C++
/*
|
|
* Copyright (C) 2020-2022 Intel Corporation
|
|
*
|
|
* SPDX-License-Identifier: MIT
|
|
*
|
|
*/
|
|
|
|
#include "shared/source/execution_environment/root_device_environment.h"
|
|
#include "shared/source/helpers/string.h"
|
|
#include "shared/source/os_interface/linux/cache_info_impl.h"
|
|
#include "shared/source/os_interface/linux/drm_engine_mapper.h"
|
|
#include "shared/source/os_interface/linux/engine_info_impl.h"
|
|
#include "shared/source/os_interface/linux/ioctl_helper.h"
|
|
#include "shared/source/os_interface/linux/memory_info.h"
|
|
#include "shared/source/os_interface/linux/sys_calls.h"
|
|
#include "shared/source/os_interface/linux/system_info.h"
|
|
|
|
#include "drm_neo.h"
|
|
#include "drm_query_flags.h"
|
|
|
|
#include <fstream>
|
|
|
|
namespace NEO {
|
|
|
|
namespace IoctlToStringHelper {
|
|
std::string getIoctlStringRemaining(unsigned long request) {
|
|
return std::to_string(request);
|
|
}
|
|
|
|
std::string getIoctlParamStringRemaining(int param) {
|
|
return std::to_string(param);
|
|
}
|
|
} // namespace IoctlToStringHelper
|
|
|
|
bool Drm::queryEngineInfo(bool isSysmanEnabled) {
|
|
auto ioctlHelper = IoctlHelper::get(this);
|
|
auto dataQuery = this->query(ioctlHelper->getEngineInfoIoctlVal(), DrmQueryItemFlags::empty);
|
|
if (dataQuery.empty()) {
|
|
return false;
|
|
}
|
|
auto engines = ioctlHelper->translateToEngineCaps(dataQuery);
|
|
this->engineInfo.reset(new EngineInfoImpl(engines));
|
|
return true;
|
|
}
|
|
|
|
unsigned int Drm::bindDrmContext(uint32_t drmContextId, uint32_t deviceIndex, aub_stream::EngineType engineType, bool engineInstancedDevice) {
|
|
return DrmEngineMapper::engineNodeMap(engineType);
|
|
}
|
|
|
|
int Drm::createDrmVirtualMemory(uint32_t &drmVmId) {
|
|
drm_i915_gem_vm_control ctl = {};
|
|
auto ret = SysCalls::ioctl(getFileDescriptor(), DRM_IOCTL_I915_GEM_VM_CREATE, &ctl);
|
|
if (ret == 0) {
|
|
if (ctl.vm_id == 0) {
|
|
// 0 is reserved for invalid/unassigned ppgtt
|
|
return -1;
|
|
}
|
|
drmVmId = ctl.vm_id;
|
|
}
|
|
return ret;
|
|
}
|
|
|
|
bool Drm::queryTopology(const HardwareInfo &hwInfo, QueryTopologyData &topologyData) {
|
|
auto dataQuery = this->query(DRM_I915_QUERY_TOPOLOGY_INFO, DrmQueryItemFlags::topology);
|
|
if (dataQuery.empty()) {
|
|
return false;
|
|
}
|
|
auto data = reinterpret_cast<drm_i915_query_topology_info *>(dataQuery.data());
|
|
|
|
topologyData.maxSliceCount = data->max_slices;
|
|
topologyData.maxSubSliceCount = data->max_subslices;
|
|
topologyData.maxEuCount = data->max_eus_per_subslice;
|
|
|
|
TopologyMapping mapping;
|
|
auto result = translateTopologyInfo(data, topologyData, mapping);
|
|
this->topologyMap[0] = mapping;
|
|
return result;
|
|
}
|
|
|
|
bool Drm::isDebugAttachAvailable() {
|
|
return false;
|
|
}
|
|
|
|
void Drm::setupCacheInfo(const HardwareInfo &hwInfo) {
|
|
this->cacheInfo.reset(new CacheInfoImpl());
|
|
}
|
|
|
|
int Drm::bindBufferObject(OsContext *osContext, uint32_t vmHandleId, BufferObject *bo) {
|
|
return 0;
|
|
}
|
|
|
|
int Drm::unbindBufferObject(OsContext *osContext, uint32_t vmHandleId, BufferObject *bo) {
|
|
return 0;
|
|
}
|
|
|
|
void Drm::waitForBind(uint32_t vmHandleId) {
|
|
}
|
|
|
|
bool Drm::isVmBindAvailable() {
|
|
return this->bindAvailable;
|
|
}
|
|
|
|
uint32_t Drm::createDrmContextExt(drm_i915_gem_context_create_ext &gcc, uint32_t drmVmId, bool isCooperativeContextRequested) {
|
|
drm_i915_gem_context_create_ext_setparam extSetparam = {};
|
|
|
|
if (drmVmId > 0) {
|
|
extSetparam.base.name = I915_CONTEXT_CREATE_EXT_SETPARAM;
|
|
extSetparam.param.param = I915_CONTEXT_PARAM_VM;
|
|
extSetparam.param.value = drmVmId;
|
|
gcc.extensions = reinterpret_cast<uint64_t>(&extSetparam);
|
|
gcc.flags |= I915_CONTEXT_CREATE_FLAGS_USE_EXTENSIONS;
|
|
}
|
|
return ioctl(DRM_IOCTL_I915_GEM_CONTEXT_CREATE_EXT, &gcc);
|
|
}
|
|
|
|
void Drm::queryPageFaultSupport() {
|
|
}
|
|
|
|
bool Drm::hasPageFaultSupport() const {
|
|
return pageFaultSupported;
|
|
}
|
|
|
|
} // namespace NEO
|