2018-08-10 22:41:44 +08:00
|
|
|
/*
|
2024-01-29 21:10:58 +08:00
|
|
|
* Copyright (C) 2018-2024 Intel Corporation
|
2018-09-18 15:11:08 +08:00
|
|
|
*
|
|
|
|
* SPDX-License-Identifier: MIT
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2018-08-10 22:41:44 +08:00
|
|
|
#pragma once
|
2021-06-08 03:47:12 +08:00
|
|
|
#include "shared/source/os_interface/windows/d3dkmthk_wrapper.h"
|
2019-02-27 18:39:32 +08:00
|
|
|
|
2018-08-10 22:41:44 +08:00
|
|
|
#include <cstdint>
|
|
|
|
|
2019-03-26 18:59:46 +08:00
|
|
|
namespace NEO {
|
2018-08-10 22:41:44 +08:00
|
|
|
class Gdi;
|
|
|
|
class Wddm;
|
2019-02-27 18:17:17 +08:00
|
|
|
class OsContextWin;
|
2018-10-26 18:22:47 +08:00
|
|
|
class WddmResidencyController;
|
2019-12-17 22:26:00 +08:00
|
|
|
struct MonitoredFence;
|
2019-12-16 22:42:13 +08:00
|
|
|
struct WddmSubmitArguments;
|
2018-08-23 23:53:58 +08:00
|
|
|
|
2018-08-10 22:41:44 +08:00
|
|
|
class WddmInterface {
|
|
|
|
public:
|
|
|
|
WddmInterface(Wddm &wddm) : wddm(wddm){};
|
2018-08-14 15:45:57 +08:00
|
|
|
virtual ~WddmInterface() = default;
|
2018-08-10 22:41:44 +08:00
|
|
|
WddmInterface() = delete;
|
2019-02-27 18:17:17 +08:00
|
|
|
virtual bool createHwQueue(OsContextWin &osContext) = 0;
|
2018-08-21 23:36:08 +08:00
|
|
|
virtual void destroyHwQueue(D3DKMT_HANDLE hwQueue) = 0;
|
2019-09-13 14:13:02 +08:00
|
|
|
virtual bool createMonitoredFence(OsContextWin &osContext) = 0;
|
2019-12-17 22:26:00 +08:00
|
|
|
MOCKABLE_VIRTUAL bool createMonitoredFence(MonitoredFence &monitorFence);
|
2024-01-29 21:10:58 +08:00
|
|
|
MOCKABLE_VIRTUAL void destroyMonitorFence(D3DKMT_HANDLE fenceHandle);
|
2019-12-17 22:26:00 +08:00
|
|
|
virtual void destroyMonitorFence(MonitoredFence &monitorFence) = 0;
|
2021-05-20 04:12:09 +08:00
|
|
|
virtual bool hwQueuesSupported() = 0;
|
2019-12-16 22:42:13 +08:00
|
|
|
virtual bool submit(uint64_t commandBuffer, size_t size, void *commandHeader, WddmSubmitArguments &submitArguments) = 0;
|
2024-01-29 21:10:58 +08:00
|
|
|
virtual bool createMonitoredFenceForDirectSubmission(MonitoredFence &monitorFence, OsContextWin &osContext) = 0;
|
2018-08-10 22:41:44 +08:00
|
|
|
Wddm &wddm;
|
|
|
|
};
|
|
|
|
|
|
|
|
class WddmInterface20 : public WddmInterface {
|
|
|
|
public:
|
|
|
|
using WddmInterface::WddmInterface;
|
2019-02-27 18:17:17 +08:00
|
|
|
bool createHwQueue(OsContextWin &osContext) override;
|
2018-08-21 23:36:08 +08:00
|
|
|
void destroyHwQueue(D3DKMT_HANDLE hwQueue) override;
|
2019-09-13 14:13:02 +08:00
|
|
|
bool createMonitoredFence(OsContextWin &osContext) override;
|
2019-12-17 22:26:00 +08:00
|
|
|
void destroyMonitorFence(MonitoredFence &monitorFence) override;
|
2021-05-20 04:12:09 +08:00
|
|
|
bool hwQueuesSupported() override;
|
2019-12-16 22:42:13 +08:00
|
|
|
bool submit(uint64_t commandBuffer, size_t size, void *commandHeader, WddmSubmitArguments &submitArguments) override;
|
2024-04-24 19:53:41 +08:00
|
|
|
bool createMonitoredFenceForDirectSubmission(MonitoredFence &monitorFence, OsContextWin &osContext) override;
|
2018-08-10 22:41:44 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
class WddmInterface23 : public WddmInterface {
|
|
|
|
public:
|
|
|
|
using WddmInterface::WddmInterface;
|
2019-02-27 18:17:17 +08:00
|
|
|
bool createHwQueue(OsContextWin &osContext) override;
|
2018-08-21 23:36:08 +08:00
|
|
|
void destroyHwQueue(D3DKMT_HANDLE hwQueue) override;
|
2019-09-13 14:13:02 +08:00
|
|
|
bool createMonitoredFence(OsContextWin &osContext) override;
|
2019-12-17 22:26:00 +08:00
|
|
|
void destroyMonitorFence(MonitoredFence &monitorFence) override;
|
2021-05-20 04:12:09 +08:00
|
|
|
bool hwQueuesSupported() override;
|
2019-12-16 22:42:13 +08:00
|
|
|
bool submit(uint64_t commandBuffer, size_t size, void *commandHeader, WddmSubmitArguments &submitArguments) override;
|
2024-01-29 21:10:58 +08:00
|
|
|
bool createMonitoredFenceForDirectSubmission(MonitoredFence &monitorFence, OsContextWin &osContext) override;
|
2018-08-10 22:41:44 +08:00
|
|
|
};
|
2019-03-26 18:59:46 +08:00
|
|
|
} // namespace NEO
|