blob: 27f97f72430a8773ed3e621fc30d36b607674f1f [file] [log] [blame]
// Copyright 2020 The Fuchsia Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef SRC_CAMERA_BIN_DEVICE_SYSMEM_ALLOCATOR_H_
#define SRC_CAMERA_BIN_DEVICE_SYSMEM_ALLOCATOR_H_
#include <fuchsia/sysmem/cpp/fidl.h>
#include <lib/async-loop/cpp/loop.h>
#include <lib/fidl/cpp/interface_handle.h>
#include <lib/fpromise/promise.h>
#include <lib/fpromise/scope.h>
#include <lib/fpromise/sequencer.h>
#include <lib/sys/cpp/component_context.h>
#include <lib/trace/event.h>
namespace camera {
struct BufferCollectionWithLifetime {
fuchsia::sysmem::BufferCollectionInfo_2 buffers;
zx::eventpair deallocation_complete;
};
class SysmemAllocator {
public:
explicit SysmemAllocator(fuchsia::sysmem::AllocatorHandle allocator);
const fuchsia::sysmem::AllocatorPtr& fidl() const { return allocator_; }
// This method will bind `token` to a new `BufferCollection` and `name` and `constraints` will
// be set on the collection. Upon a successful allocation, the collection will be closed and
// the `BufferCollectionInfo_2` will be returned by the promise. It does not check for free space
// before allocation.
//
// An error is returned from the promise if the allocation is unable to complete for any reason.
fpromise::promise<BufferCollectionWithLifetime, zx_status_t> BindSharedCollection(
fuchsia::sysmem::BufferCollectionTokenHandle token,
fuchsia::sysmem::BufferCollectionConstraints constraints, std::string name);
private:
fuchsia::sysmem::AllocatorPtr allocator_;
fpromise::scope scope_;
};
} // namespace camera
#endif // SRC_CAMERA_BIN_DEVICE_SYSMEM_ALLOCATOR_H_