2020-03-06 11:09:57 +01:00
|
|
|
/*
|
2021-05-16 20:51:16 +02:00
|
|
|
* Copyright (C) 2020-2021 Intel Corporation
|
2020-03-06 11:09:57 +01:00
|
|
|
*
|
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
|
*
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include "shared/source/command_stream/csr_definitions.h"
|
|
|
|
|
|
2020-03-18 22:21:57 -07:00
|
|
|
#include "level_zero/core/source/cmdqueue/cmdqueue.h"
|
|
|
|
|
#include "level_zero/core/source/cmdqueue/cmdqueue_imp.h"
|
2020-07-29 02:45:54 -07:00
|
|
|
#include <level_zero/ze_api.h>
|
2020-03-06 11:09:57 +01:00
|
|
|
|
|
|
|
|
#include <limits>
|
|
|
|
|
|
|
|
|
|
struct _ze_fence_handle_t {};
|
|
|
|
|
|
|
|
|
|
namespace L0 {
|
|
|
|
|
|
|
|
|
|
struct Fence : _ze_fence_handle_t {
|
|
|
|
|
static Fence *create(CommandQueueImp *cmdQueue, const ze_fence_desc_t *desc);
|
|
|
|
|
virtual ~Fence() = default;
|
|
|
|
|
virtual ze_result_t destroy() = 0;
|
2020-07-29 02:45:54 -07:00
|
|
|
virtual ze_result_t hostSynchronize(uint64_t timeout) = 0;
|
2020-03-06 11:09:57 +01:00
|
|
|
virtual ze_result_t queryStatus() = 0;
|
|
|
|
|
virtual ze_result_t reset() = 0;
|
|
|
|
|
|
|
|
|
|
static Fence *fromHandle(ze_fence_handle_t handle) { return static_cast<Fence *>(handle); }
|
|
|
|
|
|
|
|
|
|
inline ze_fence_handle_t toHandle() { return this; }
|
|
|
|
|
|
|
|
|
|
enum State : uint32_t {
|
|
|
|
|
STATE_SIGNALED = 0u,
|
|
|
|
|
STATE_CLEARED = std::numeric_limits<uint32_t>::max(),
|
|
|
|
|
STATE_INITIAL = STATE_CLEARED
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
enum EnqueueState : uint32_t { ENQUEUE_NOT_READY = 0u,
|
|
|
|
|
ENQUEUE_READY };
|
|
|
|
|
|
2020-09-18 14:18:23 +02:00
|
|
|
NEO::GraphicsAllocation &getAllocation() const { return *allocation; }
|
2020-03-06 11:09:57 +01:00
|
|
|
|
|
|
|
|
uint64_t getGpuAddress() {
|
|
|
|
|
UNRECOVERABLE_IF(allocation == nullptr);
|
|
|
|
|
return allocation->getGpuAddress();
|
|
|
|
|
}
|
|
|
|
|
|
2021-09-03 11:42:31 +00:00
|
|
|
void setPartitionCount(uint32_t newPartitionCount) {
|
|
|
|
|
partitionCount = newPartitionCount;
|
|
|
|
|
}
|
|
|
|
|
|
2020-03-06 11:09:57 +01:00
|
|
|
protected:
|
|
|
|
|
NEO::GraphicsAllocation *allocation = nullptr;
|
2021-09-03 11:42:31 +00:00
|
|
|
uint32_t partitionCount = 1;
|
2020-03-06 11:09:57 +01:00
|
|
|
};
|
|
|
|
|
|
2020-05-13 11:25:29 +02:00
|
|
|
struct FenceImp : public Fence {
|
|
|
|
|
FenceImp(CommandQueueImp *cmdQueueImp) : cmdQueue(cmdQueueImp) {}
|
|
|
|
|
|
|
|
|
|
~FenceImp() override;
|
|
|
|
|
|
|
|
|
|
ze_result_t destroy() override {
|
|
|
|
|
delete this;
|
|
|
|
|
return ZE_RESULT_SUCCESS;
|
|
|
|
|
}
|
|
|
|
|
|
2020-07-29 02:45:54 -07:00
|
|
|
ze_result_t hostSynchronize(uint64_t timeout) override;
|
2020-05-13 11:25:29 +02:00
|
|
|
|
|
|
|
|
ze_result_t queryStatus() override;
|
|
|
|
|
|
|
|
|
|
ze_result_t reset() override;
|
|
|
|
|
|
2020-09-18 14:18:23 +02:00
|
|
|
void initialize();
|
2020-05-13 11:25:29 +02:00
|
|
|
|
|
|
|
|
protected:
|
|
|
|
|
CommandQueueImp *cmdQueue;
|
|
|
|
|
};
|
2020-03-06 11:09:57 +01:00
|
|
|
} // namespace L0
|