[libcamera-devel] [PATCH 2/4] libcamera: buffer: Document the BufferPool

Kieran Bingham kieran.bingham at ideasonboard.com
Tue Jan 29 14:53:55 CET 2019


Add Doxygen documentation for the existing code in the BufferPool class.

Signed-off-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
---
 src/libcamera/buffer.cpp | 42 ++++++++++++++++++++++++++++++++++++++++
 1 file changed, 42 insertions(+)

diff --git a/src/libcamera/buffer.cpp b/src/libcamera/buffer.cpp
index 6dfebfc6bb28..5c580b540a67 100644
--- a/src/libcamera/buffer.cpp
+++ b/src/libcamera/buffer.cpp
@@ -64,6 +64,37 @@ int Buffer::setDmabuf(int fd)
 /**
  * \class BufferPool
  * \brief A pool of buffers
+ *
+ * The BufferPool class groups together a collection of Buffers for passing
+ * between devices. The buffers must be exported by a device before they can be
+ * imported into another device for further use.
+ */
+
+/**
+ * \enum BufferPool::Memory
+ * \brief Identify the memory type used in the BufferPool
+ */
+
+/**
+ * \var BufferPool::Internal
+ * \brief The memory for the Buffers in this pool is allocated internally by the
+ * device associated with the pool
+ */
+
+/**
+ * \var BufferPool::External
+ * \brief The memory for the Buffers in this pool is allocated externally by
+ * another device and can be imported for use by other devices.
+ *
+ * The buffers in the pool have been exported to make them available for sharing
+ * with other devices, and can be managed using their own file descriptors.
+ */
+
+/**
+ * \brief Construct a buffer pool. The \a memory argument declares the intent of
+ * the pool to be either internal or external to a device.
+ *
+ * \sa BufferPool::Memory
  */
 BufferPool::BufferPool(BufferPool::Memory memory)
 	: memory_(memory)
@@ -75,6 +106,9 @@ BufferPool::~BufferPool()
 	free();
 }
 
+/**
+ * \brief Allocate buffers in a pool
+ */
 int BufferPool::allocate(unsigned int count)
 {
 	for (unsigned int i = 0; i < count; ++i) {
@@ -91,6 +125,9 @@ int BufferPool::allocate(unsigned int count)
 	return 0;
 }
 
+/**
+ * \brief Release all buffers from pool.
+ */
 void BufferPool::free()
 {
 	for (Buffer *buffer : buffers_)
@@ -99,4 +136,9 @@ void BufferPool::free()
 	buffers_.clear();
 }
 
+/**
+ * \fn BufferPool::count()
+ * \brief Get the number of Buffers contained within this pool
+ */
+
 } /* namespace libcamera */
-- 
2.19.1



More information about the libcamera-devel mailing list