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