18static NSString* MTLCommandEncoderErrorStateToString(
19 MTLCommandEncoderErrorState state) {
21 case MTLCommandEncoderErrorStateUnknown:
23 case MTLCommandEncoderErrorStateCompleted:
25 case MTLCommandEncoderErrorStateAffected:
27 case MTLCommandEncoderErrorStatePending:
29 case MTLCommandEncoderErrorStateFaulted:
37 case MTLCommandBufferErrorNone:
39 case MTLCommandBufferErrorInternal:
41 case MTLCommandBufferErrorTimeout:
43 case MTLCommandBufferErrorPageFault:
45 case MTLCommandBufferErrorNotPermitted:
46 return @"not permitted";
47 case MTLCommandBufferErrorOutOfMemory:
48 return @"out of memory";
49 case MTLCommandBufferErrorInvalidResource:
50 return @"invalid resource";
51 case MTLCommandBufferErrorMemoryless:
52 return @"memory-less";
57 return [NSString stringWithFormat:
@"<unknown> %zu", code];
65 if (buffer.status == MTLCommandBufferStatusCompleted) {
69 std::stringstream stream;
70 stream <<
">>>>>>>" << std::endl;
71 stream <<
"Impeller command buffer could not be committed!" << std::endl;
73 if (
auto desc = buffer.error.localizedDescription) {
74 stream << desc.UTF8String << std::endl;
79 << (buffer.error.domain.length > 0u ? buffer.error.domain.UTF8String
83 static_cast<MTLCommandBufferError
>(buffer.error.code))
88 if (@available(iOS 14.0, macOS 11.0, *)) {
89 NSArray<id<MTLCommandBufferEncoderInfo>>* infos =
90 buffer.error.userInfo[MTLCommandBufferEncoderInfoErrorKey];
91 for (id<MTLCommandBufferEncoderInfo> info in infos) {
92 stream << (info.label.length > 0u ? info.label.UTF8String
93 :
"<Unlabelled Render Pass>")
95 << MTLCommandEncoderErrorStateToString(info.errorState).UTF8String
98 auto signposts = [info.debugSignposts componentsJoinedByString:
@", "];
99 if (signposts.length > 0u) {
100 stream << signposts.UTF8String << std::endl;
104 for (id<MTLFunctionLog> log in buffer.logs) {
105 auto desc = log.description;
106 if (desc.length > 0u) {
107 stream << desc.UTF8String << std::endl;
118#ifndef FLUTTER_RELEASE
119 if (@available(iOS 14.0, macOS 11.0, *)) {
120 auto desc = [[MTLCommandBufferDescriptor alloc] init];
123 desc.errorOptions = MTLCommandBufferErrorOptionEncoderExecutionStatus;
124 return [
queue commandBufferWithDescriptor:desc];
127 return [
queue commandBuffer];
130CommandBufferMTL::CommandBufferMTL(
const std::weak_ptr<const Context>& context,
132 id<MTLCommandQueue>
queue)
133 : CommandBuffer(context),
137CommandBufferMTL::~CommandBufferMTL() =
default;
139bool CommandBufferMTL::IsValid()
const {
140 return buffer_ != nil;
143void CommandBufferMTL::SetLabel(std::string_view label)
const {
149 [buffer_ setLabel:@(label.data())];
155 case MTLCommandBufferStatusCompleted:
156 return CommandBufferMTL::Status::kCompleted;
157 case MTLCommandBufferStatusEnqueued:
158 return CommandBufferMTL::Status::kPending;
162 return CommandBufferMTL::Status::kError;
165bool CommandBufferMTL::OnSubmitCommands(
bool block_on_schedule,
167 auto context = context_.lock();
172 ContextMTL::Cast(*context).GetGPUTracer()->RecordCmdBuffer(buffer_);
176 addCompletedHandler:^(id<MTLCommandBuffer>
buffer) {
177 [[maybe_unused]]
auto result =
180 <<
"Must not have errors during command buffer submission.";
186 if (block_on_schedule) {
187 [buffer_ waitUntilScheduled];
194void CommandBufferMTL::OnWaitUntilCompleted() {}
196void CommandBufferMTL::OnWaitUntilScheduled() {}
198std::shared_ptr<RenderPass> CommandBufferMTL::OnCreateRenderPass(
204 auto context = context_.lock();
208 auto pass = std::shared_ptr<RenderPassMTL>(
209 new RenderPassMTL(context,
target, buffer_));
210 if (!pass->IsValid()) {
217std::shared_ptr<BlitPass> CommandBufferMTL::OnCreateBlitPass() {
222 auto pass = std::shared_ptr<BlitPassMTL>(
new BlitPassMTL(buffer_, device_));
223 if (!pass->IsValid()) {
230std::shared_ptr<ComputePass> CommandBufferMTL::OnCreateComputePass() {
234 auto context = context_.lock();
240 std::shared_ptr<ComputePassMTL>(
new ComputePassMTL(context, buffer_));
241 if (!pass->IsValid()) {
FlutterDesktopBinaryReply callback
#define FML_DCHECK(condition)
DEF_SWITCHES_START aot vmservice shared library Name of the *so containing AOT compiled Dart assets for launching the service isolate vm snapshot The VM snapshot data that will be memory mapped as read only SnapshotAssetPath must be present isolate snapshot The isolate snapshot data that will be memory mapped as read only SnapshotAssetPath must be present cache dir Path to the cache directory This is different from the persistent_cache_path in embedder which is used for Skia shader cache icu native lib Path to the library file that exports the ICU data vm service The hostname IP address on which the Dart VM Service should be served If not defaults to or::depending on whether ipv6 is specified disable vm Disable the Dart VM Service The Dart VM Service is never available in release mode Bind to the IPv6 localhost address for the Dart VM Service Ignored if vm service host is set profile Make the profiler discard new samples once the profiler sample buffer is full When this flag is not the profiler sample buffer is used as a ring buffer
static bool LogMTLCommandBufferErrorIfPresent(id< MTLCommandBuffer > buffer)
API_AVAILABLE(ios(14.0), macos(11.0)) static NSString *MTLCommandEncoderErrorStateToString(MTLCommandEncoderErrorState state)
static NSString * MTLCommandBufferErrorToString(MTLCommandBufferError code)
static id< MTLCommandBuffer > CreateCommandBuffer(id< MTLCommandQueue > queue)
static CommandBuffer::Status ToCommitResult(MTLCommandBufferStatus status)