35 bool isValid()
const {
return providerHandle_.isValid(); }
39 const std::vector<unsigned int> &planeSizes,
40 std::vector<std::unique_ptr<FrameBuffer>> *buffers);
43 std::unique_ptr<FrameBuffer> createBuffer(
44 std::string name,
const std::vector<unsigned int> &planeSizes);
46 UniqueFD allocFromHeap(
const char *name, std::size_t size);
47 UniqueFD allocFromUDmaBuf(
const char *name, std::size_t size);
66 void sync(uint64_t step);
RAII-style wrapper for file descriptors.
Definition: shared_fd.h:16
int exportBuffers(unsigned int count, const std::vector< unsigned int > &planeSizes, std::vector< std::unique_ptr< FrameBuffer >> *buffers)
Allocate and export buffers from the DmaBufAllocator.
Definition: dma_buf_allocator.cpp:223
Allocate using a memfd + /dev/udmabuf.
Helper class for dma-buf allocations.
Definition: dma_buf_allocator.h:22
File descriptor wrapper that owns a file descriptor.
DmaBufAllocator(DmaBufAllocatorFlags flags=DmaBufAllocatorFlag::CmaHeap)
Construct a DmaBufAllocator of a given type.
Definition: dma_buf_allocator.cpp:97
Top-level libcamera namespace.
Definition: backtrace.h:17
SyncType
Read and/or write access via the CPU map.
Definition: dma_buf_allocator.h:55
unique_ptr-like wrapper for a file descriptor
Definition: unique_fd.h:17
~DmaBufAllocator()
Destroy the DmaBufAllocator instance.
#define LIBCAMERA_FLAGS_ENABLE_OPERATORS(_enum)
Enable bitwise operations on the enum enumeration.
Allocate from the system dma-heap, using the page allocator.
Allocate from a CMA dma-heap, providing physically-contiguous memory.
Type-safe container for enum-based bitfields.
Definition: flags.h:15
UniqueFD alloc(const char *name, std::size_t size)
Allocate a dma-buf from the DmaBufAllocator.
Definition: dma_buf_allocator.cpp:200
bool isValid() const
Check if the DmaBufAllocator instance is valid.
Definition: dma_buf_allocator.h:35
DmaBufAllocatorFlag
Type of the dma-buf provider.
Definition: dma_buf_allocator.h:25
Helper class for dma-buf's synchronization.
Definition: dma_buf_allocator.h:52