libcamera v0.4.0
Supporting cameras in Linux since 2019
 
Loading...
Searching...
No Matches
dma_buf_allocator.h
1/* SPDX-License-Identifier: LGPL-2.1-or-later */
2/*
3 * Copyright (C) 2020, Raspberry Pi Ltd
4 *
5 * Helper class for dma-buf allocations.
6 */
7
8#pragma once
9
10#include <memory>
11#include <string>
12#include <vector>
13
17
18namespace libcamera {
19
20class FrameBuffer;
21
23{
24public:
26 CmaHeap = 1 << 0,
27 SystemHeap = 1 << 1,
28 UDmaBuf = 1 << 2,
29 };
30
32
35 bool isValid() const { return providerHandle_.isValid(); }
36 UniqueFD alloc(const char *name, std::size_t size);
37
38 int exportBuffers(unsigned int count,
39 const std::vector<unsigned int> &planeSizes,
40 std::vector<std::unique_ptr<FrameBuffer>> *buffers);
41
42private:
43 std::unique_ptr<FrameBuffer> createBuffer(
44 std::string name, const std::vector<unsigned int> &planeSizes);
45
46 UniqueFD allocFromHeap(const char *name, std::size_t size);
47 UniqueFD allocFromUDmaBuf(const char *name, std::size_t size);
48 UniqueFD providerHandle_;
50};
51
52class DmaSyncer final
53{
54public:
55 enum class SyncType {
56 Read = 0,
59 };
60
62
63 ~DmaSyncer();
64
65private:
66 void sync(uint64_t step);
67
68 SharedFD fd_;
69 uint64_t flags_ = 0;
70};
71
73
74} /* namespace libcamera */
bool isValid() const
Check if the DmaBufAllocator instance is valid.
Definition dma_buf_allocator.h:35
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
DmaBufAllocator(DmaBufAllocatorFlags flags=DmaBufAllocatorFlag::CmaHeap)
Construct a DmaBufAllocator of a given type.
Definition dma_buf_allocator.cpp:97
DmaBufAllocatorFlag
Type of the dma-buf provider.
Definition dma_buf_allocator.h:25
@ CmaHeap
Allocate from a CMA dma-heap, providing physically-contiguous memory.
Definition dma_buf_allocator.h:26
@ SystemHeap
Allocate from the system dma-heap, using the page allocator.
Definition dma_buf_allocator.h:27
@ UDmaBuf
Allocate using a memfd + /dev/udmabuf.
Definition dma_buf_allocator.h:28
Flags< DmaBufAllocatorFlag > DmaBufAllocatorFlags
A bitwise combination of DmaBufAllocator::DmaBufAllocatorFlag values.
Definition dma_buf_allocator.h:31
~DmaBufAllocator()
Destroy the DmaBufAllocator instance.
UniqueFD alloc(const char *name, std::size_t size)
Allocate a dma-buf from the DmaBufAllocator.
Definition dma_buf_allocator.cpp:200
Helper class for dma-buf's synchronization.
Definition dma_buf_allocator.h:53
SyncType
Read and/or write access via the CPU map.
Definition dma_buf_allocator.h:55
@ Write
Indicates that the mapped dm-buf will be written by the client via the CPU map.
Definition dma_buf_allocator.h:57
@ ReadWrite
Indicates that the mapped dma-buf will be read and written by the client via the CPU map.
Definition dma_buf_allocator.h:58
@ Read
Indicates that the mapped dma-buf will be read by the client via the CPU map.
Definition dma_buf_allocator.h:56
DmaSyncer(SharedFD fd, SyncType type=SyncType::ReadWrite)
Construct a DmaSyncer with a dma-buf's fd and the access type.
Definition dma_buf_allocator.cpp:296
Type-safe container for enum-based bitfields.
Definition flags.h:16
Frame buffer data and its associated dynamic metadata.
Definition framebuffer.h:49
RAII-style wrapper for file descriptors.
Definition shared_fd.h:17
unique_ptr-like wrapper for a file descriptor
Definition unique_fd.h:18
Enum-based bit fields.
#define LIBCAMERA_FLAGS_ENABLE_OPERATORS(_enum)
Enable bitwise operations on the enum enumeration.
Definition flags.h:189
Top-level libcamera namespace.
Definition backtrace.h:17
File descriptor wrapper.
File descriptor wrapper that owns a file descriptor.