2018-07-18 09:40:26 +00:00
|
|
|
// Copyright 2018 The Dawn Authors
|
2017-04-20 18:38:20 +00:00
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
2018-07-24 14:42:33 +00:00
|
|
|
#ifndef DAWNNATIVE_METAL_DEVICEMTL_H_
|
|
|
|
#define DAWNNATIVE_METAL_DEVICEMTL_H_
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2018-07-25 15:03:23 +00:00
|
|
|
#include "dawn_native/dawn_platform.h"
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2020-07-15 18:06:07 +00:00
|
|
|
#include "dawn_native/Commands.h"
|
2018-07-24 11:53:51 +00:00
|
|
|
#include "dawn_native/Device.h"
|
2020-01-15 18:22:53 +00:00
|
|
|
#include "dawn_native/metal/CommandRecordingContext.h"
|
2018-07-24 11:53:51 +00:00
|
|
|
#include "dawn_native/metal/Forward.h"
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2019-09-18 04:32:52 +00:00
|
|
|
#import <IOSurface/IOSurfaceRef.h>
|
2017-04-20 18:38:20 +00:00
|
|
|
#import <Metal/Metal.h>
|
2019-09-18 04:32:52 +00:00
|
|
|
#import <QuartzCore/QuartzCore.h>
|
2018-09-06 13:26:48 +00:00
|
|
|
|
2019-03-22 07:36:34 +00:00
|
|
|
#include <atomic>
|
2018-09-06 13:26:48 +00:00
|
|
|
#include <memory>
|
2019-03-22 07:36:34 +00:00
|
|
|
#include <mutex>
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2022-01-12 09:17:35 +00:00
|
|
|
namespace dawn::native::metal {
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2021-06-07 03:17:10 +00:00
|
|
|
namespace {
|
|
|
|
struct KalmanInfo;
|
|
|
|
}
|
|
|
|
|
2021-10-12 17:46:26 +00:00
|
|
|
class Device final : public DeviceBase {
|
2017-11-24 19:12:44 +00:00
|
|
|
public:
|
2021-12-22 19:02:23 +00:00
|
|
|
static ResultOrError<Ref<Device>> Create(AdapterBase* adapter,
|
|
|
|
NSPRef<id<MTLDevice>> mtlDevice,
|
|
|
|
const DeviceDescriptor* descriptor);
|
2020-04-08 16:04:32 +00:00
|
|
|
~Device() override;
|
2017-11-24 19:12:44 +00:00
|
|
|
|
2020-04-07 15:10:17 +00:00
|
|
|
MaybeError Initialize();
|
|
|
|
|
2019-10-07 15:32:10 +00:00
|
|
|
MaybeError TickImpl() override;
|
2017-11-24 19:12:44 +00:00
|
|
|
|
|
|
|
id<MTLDevice> GetMTLDevice();
|
2019-10-07 08:18:09 +00:00
|
|
|
id<MTLCommandQueue> GetMTLQueue();
|
2017-11-24 19:12:44 +00:00
|
|
|
|
2020-01-15 18:22:53 +00:00
|
|
|
CommandRecordingContext* GetPendingCommandContext();
|
2021-07-21 15:41:29 +00:00
|
|
|
MaybeError SubmitPendingCommandBuffer();
|
2017-11-24 19:12:44 +00:00
|
|
|
|
2021-07-21 09:34:28 +00:00
|
|
|
Ref<Texture> CreateTextureWrappingIOSurface(const ExternalImageDescriptor* descriptor,
|
2019-03-01 12:01:18 +00:00
|
|
|
IOSurfaceRef ioSurface,
|
|
|
|
uint32_t plane);
|
2019-03-22 07:36:34 +00:00
|
|
|
void WaitForCommandsToBeScheduled();
|
2019-03-01 12:01:18 +00:00
|
|
|
|
2019-01-29 00:10:07 +00:00
|
|
|
ResultOrError<std::unique_ptr<StagingBufferBase>> CreateStagingBuffer(size_t size) override;
|
|
|
|
MaybeError CopyFromStagingToBuffer(StagingBufferBase* source,
|
2019-04-05 20:51:29 +00:00
|
|
|
uint64_t sourceOffset,
|
2019-01-29 00:10:07 +00:00
|
|
|
BufferBase* destination,
|
2019-04-05 20:51:29 +00:00
|
|
|
uint64_t destinationOffset,
|
|
|
|
uint64_t size) override;
|
2020-08-20 13:29:39 +00:00
|
|
|
MaybeError CopyFromStagingToTexture(const StagingBufferBase* source,
|
2020-07-15 18:06:07 +00:00
|
|
|
const TextureDataLayout& dataLayout,
|
|
|
|
TextureCopy* dst,
|
2020-08-20 13:29:39 +00:00
|
|
|
const Extent3D& copySizePixels) override;
|
|
|
|
|
|
|
|
uint32_t GetOptimalBytesPerRowAlignment() const override;
|
|
|
|
uint64_t GetOptimalBufferToTextureCopyOffsetAlignment() const override;
|
2019-01-29 00:10:07 +00:00
|
|
|
|
2021-01-05 02:39:18 +00:00
|
|
|
float GetTimestampPeriodInNS() const override;
|
|
|
|
|
2017-11-24 19:12:44 +00:00
|
|
|
private:
|
2020-11-16 23:07:56 +00:00
|
|
|
Device(AdapterBase* adapter,
|
|
|
|
NSPRef<id<MTLDevice>> mtlDevice,
|
2021-12-22 19:02:23 +00:00
|
|
|
const DeviceDescriptor* descriptor);
|
2020-04-07 15:10:17 +00:00
|
|
|
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<BindGroupBase>> CreateBindGroupImpl(
|
2018-12-05 07:18:30 +00:00
|
|
|
const BindGroupDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<BindGroupLayoutBase>> CreateBindGroupLayoutImpl(
|
2021-09-01 22:15:41 +00:00
|
|
|
const BindGroupLayoutDescriptor* descriptor,
|
|
|
|
PipelineCompatibilityToken pipelineCompatibilityToken) override;
|
2020-07-08 19:45:40 +00:00
|
|
|
ResultOrError<Ref<BufferBase>> CreateBufferImpl(
|
|
|
|
const BufferDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<CommandBufferBase>> CreateCommandBuffer(
|
|
|
|
CommandEncoder* encoder,
|
|
|
|
const CommandBufferDescriptor* descriptor) override;
|
|
|
|
ResultOrError<Ref<PipelineLayoutBase>> CreatePipelineLayoutImpl(
|
2018-07-25 15:03:23 +00:00
|
|
|
const PipelineLayoutDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<QuerySetBase>> CreateQuerySetImpl(
|
2020-06-11 00:34:14 +00:00
|
|
|
const QuerySetDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<SamplerBase>> CreateSamplerImpl(
|
|
|
|
const SamplerDescriptor* descriptor) override;
|
|
|
|
ResultOrError<Ref<ShaderModuleBase>> CreateShaderModuleImpl(
|
2020-12-07 18:12:13 +00:00
|
|
|
const ShaderModuleDescriptor* descriptor,
|
|
|
|
ShaderModuleParseResult* parseResult) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<SwapChainBase>> CreateSwapChainImpl(
|
2019-02-15 11:15:58 +00:00
|
|
|
const SwapChainDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<NewSwapChainBase>> CreateSwapChainImpl(
|
2020-01-23 17:20:38 +00:00
|
|
|
Surface* surface,
|
2020-01-25 10:05:40 +00:00
|
|
|
NewSwapChainBase* previousSwapChain,
|
2020-01-23 17:20:38 +00:00
|
|
|
const SwapChainDescriptor* descriptor) override;
|
2020-04-23 19:47:12 +00:00
|
|
|
ResultOrError<Ref<TextureBase>> CreateTextureImpl(
|
|
|
|
const TextureDescriptor* descriptor) override;
|
2021-03-31 18:36:32 +00:00
|
|
|
ResultOrError<Ref<TextureViewBase>> CreateTextureViewImpl(
|
2018-10-12 08:32:58 +00:00
|
|
|
TextureBase* texture,
|
|
|
|
const TextureViewDescriptor* descriptor) override;
|
2021-10-13 00:43:05 +00:00
|
|
|
Ref<ComputePipelineBase> CreateUninitializedComputePipelineImpl(
|
|
|
|
const ComputePipelineDescriptor* descriptor) override;
|
|
|
|
Ref<RenderPipelineBase> CreateUninitializedRenderPipelineImpl(
|
|
|
|
const RenderPipelineDescriptor* descriptor) override;
|
|
|
|
void InitializeComputePipelineAsyncImpl(Ref<ComputePipelineBase> computePipeline,
|
|
|
|
WGPUCreateComputePipelineAsyncCallback callback,
|
|
|
|
void* userdata) override;
|
2021-09-29 00:49:01 +00:00
|
|
|
void InitializeRenderPipelineAsyncImpl(Ref<RenderPipelineBase> renderPipeline,
|
|
|
|
WGPUCreateRenderPipelineAsyncCallback callback,
|
|
|
|
void* userdata) override;
|
2018-05-17 21:09:07 +00:00
|
|
|
|
2019-04-26 07:52:57 +00:00
|
|
|
void InitTogglesFromDriver();
|
2021-10-12 17:46:26 +00:00
|
|
|
void DestroyImpl() override;
|
2019-12-16 23:36:16 +00:00
|
|
|
MaybeError WaitForIdleForDestruction() override;
|
2021-04-07 18:09:21 +00:00
|
|
|
ResultOrError<ExecutionSerial> CheckAndUpdateCompletedSerials() override;
|
2019-04-26 07:52:57 +00:00
|
|
|
|
2020-11-16 23:07:56 +00:00
|
|
|
NSPRef<id<MTLDevice>> mMtlDevice;
|
|
|
|
NSPRef<id<MTLCommandQueue>> mCommandQueue;
|
2017-11-24 19:12:44 +00:00
|
|
|
|
2020-01-15 18:22:53 +00:00
|
|
|
CommandRecordingContext mCommandContext;
|
2019-03-22 07:36:34 +00:00
|
|
|
|
|
|
|
// The completed serial is updated in a Metal completion handler that can be fired on a
|
|
|
|
// different thread, so it needs to be atomic.
|
|
|
|
std::atomic<uint64_t> mCompletedSerial;
|
|
|
|
|
|
|
|
// mLastSubmittedCommands will be accessed in a Metal schedule handler that can be fired on
|
|
|
|
// a different thread so we guard access to it with a mutex.
|
|
|
|
std::mutex mLastSubmittedCommandsMutex;
|
2020-11-16 23:07:56 +00:00
|
|
|
NSPRef<id<MTLCommandBuffer>> mLastSubmittedCommands;
|
2021-06-07 03:17:10 +00:00
|
|
|
|
|
|
|
// The current estimation of timestamp period
|
|
|
|
float mTimestampPeriod = 1.0f;
|
|
|
|
// The base of CPU timestamp and GPU timestamp to measure the linear regression between GPU
|
|
|
|
// and CPU timestamps.
|
|
|
|
MTLTimestamp mCpuTimestamp API_AVAILABLE(macos(10.15), ios(14.0)) = 0;
|
|
|
|
MTLTimestamp mGpuTimestamp API_AVAILABLE(macos(10.15), ios(14.0)) = 0;
|
|
|
|
// The parameters for kalman filter
|
|
|
|
std::unique_ptr<KalmanInfo> mKalmanInfo;
|
2017-04-20 18:38:20 +00:00
|
|
|
};
|
|
|
|
|
2022-01-12 09:17:35 +00:00
|
|
|
} // namespace dawn::native::metal
|
2017-04-20 18:38:20 +00:00
|
|
|
|
2018-07-24 14:42:33 +00:00
|
|
|
#endif // DAWNNATIVE_METAL_DEVICEMTL_H_
|