2018-01-29 11:18:34 +01:00
|
|
|
/*
|
2023-01-03 13:25:09 +00:00
|
|
|
* Copyright (C) 2018-2023 Intel Corporation
|
2018-09-18 09:11:08 +02:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
2018-01-29 11:18:34 +01:00
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
2020-02-23 22:44:01 +01:00
|
|
|
#include "shared/source/command_stream/csr_deps.h"
|
2020-02-24 10:22:30 +01:00
|
|
|
|
2023-01-03 13:25:09 +00:00
|
|
|
#include "CL/cl.h"
|
2019-02-27 11:39:32 +01:00
|
|
|
|
2018-02-13 13:20:34 +01:00
|
|
|
#include <array>
|
2018-01-29 11:18:34 +01:00
|
|
|
|
2019-03-26 11:59:46 +01:00
|
|
|
namespace NEO {
|
2018-02-08 22:59:03 +01:00
|
|
|
class MemObj;
|
2018-08-07 15:09:16 +02:00
|
|
|
class Buffer;
|
2021-10-18 15:07:01 +00:00
|
|
|
class GraphicsAllocation;
|
2018-02-08 22:59:03 +01:00
|
|
|
|
|
|
|
|
struct EventsRequest {
|
|
|
|
|
EventsRequest() = delete;
|
|
|
|
|
|
|
|
|
|
EventsRequest(cl_uint numEventsInWaitList, const cl_event *eventWaitList, cl_event *outEvent)
|
2020-01-22 16:22:30 +01:00
|
|
|
: numEventsInWaitList(numEventsInWaitList), eventWaitList(eventWaitList), outEvent(outEvent) {}
|
|
|
|
|
|
2021-03-11 13:48:04 +00:00
|
|
|
void fillCsrDependenciesForTimestampPacketContainer(CsrDependencies &csrDeps, CommandStreamReceiver ¤tCsr, CsrDependencies::DependenciesType depsType) const;
|
2023-01-19 16:11:39 +00:00
|
|
|
void fillCsrDependenciesForRootDevices(CsrDependencies &csrDeps, CommandStreamReceiver ¤tCsr) const;
|
2021-08-26 16:38:39 +00:00
|
|
|
void setupBcsCsrForOutputEvent(CommandStreamReceiver &bcsCsr) const;
|
2018-02-08 22:59:03 +01:00
|
|
|
|
|
|
|
|
cl_uint numEventsInWaitList;
|
|
|
|
|
const cl_event *eventWaitList;
|
|
|
|
|
cl_event *outEvent;
|
|
|
|
|
};
|
|
|
|
|
|
2018-02-17 22:26:28 +01:00
|
|
|
using MemObjSizeArray = std::array<size_t, 3>;
|
|
|
|
|
using MemObjOffsetArray = std::array<size_t, 3>;
|
|
|
|
|
|
2018-02-08 22:59:03 +01:00
|
|
|
struct TransferProperties {
|
|
|
|
|
TransferProperties() = delete;
|
|
|
|
|
|
2018-02-17 22:26:28 +01:00
|
|
|
TransferProperties(MemObj *memObj, cl_command_type cmdType, cl_map_flags mapFlags, bool blocking, size_t *offsetPtr, size_t *sizePtr,
|
2020-05-25 18:27:17 +02:00
|
|
|
void *ptr, bool doTransferOnCpu, uint32_t rootDeviceIndex);
|
2018-02-08 22:59:03 +01:00
|
|
|
|
2018-04-04 09:29:48 +02:00
|
|
|
MemObjOffsetArray offset = {};
|
|
|
|
|
MemObjSizeArray size = {};
|
2019-04-08 14:49:35 +02:00
|
|
|
MemObj *memObj = nullptr;
|
2018-04-04 09:29:48 +02:00
|
|
|
void *ptr = nullptr;
|
2019-04-08 14:49:35 +02:00
|
|
|
void *lockedPtr = nullptr;
|
|
|
|
|
cl_command_type cmdType = 0;
|
|
|
|
|
cl_map_flags mapFlags = 0;
|
2018-04-04 09:29:48 +02:00
|
|
|
uint32_t mipLevel = 0;
|
|
|
|
|
uint32_t mipPtrOffset = 0;
|
2019-04-08 14:49:35 +02:00
|
|
|
bool blocking = false;
|
|
|
|
|
bool doTransferOnCpu = false;
|
2023-08-04 12:10:12 +00:00
|
|
|
bool finishRequired = false;
|
2018-12-12 14:36:45 +01:00
|
|
|
|
|
|
|
|
void *getCpuPtrForReadWrite();
|
2018-02-13 13:20:34 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
struct MapInfo {
|
2018-02-17 22:26:28 +01:00
|
|
|
MapInfo() = default;
|
2018-04-04 09:29:48 +02:00
|
|
|
MapInfo(void *ptr, size_t ptrLength, MemObjSizeArray size, MemObjOffsetArray offset, uint32_t mipLevel)
|
2019-04-08 14:49:35 +02:00
|
|
|
: size(size), offset(offset), ptrLength(ptrLength), ptr(ptr), mipLevel(mipLevel) {
|
2018-04-04 09:29:48 +02:00
|
|
|
}
|
2018-02-13 13:20:34 +01:00
|
|
|
|
2018-04-04 09:29:48 +02:00
|
|
|
MemObjSizeArray size = {};
|
|
|
|
|
MemObjOffsetArray offset = {};
|
2019-04-08 14:49:35 +02:00
|
|
|
size_t ptrLength = 0;
|
|
|
|
|
void *ptr = nullptr;
|
2018-04-04 09:29:48 +02:00
|
|
|
uint32_t mipLevel = 0;
|
2019-04-08 14:49:35 +02:00
|
|
|
bool readOnly = false;
|
2021-10-18 15:07:01 +00:00
|
|
|
GraphicsAllocation *graphicsAllocation = nullptr;
|
2018-02-08 22:59:03 +01:00
|
|
|
};
|
2019-03-26 11:59:46 +01:00
|
|
|
} // namespace NEO
|