[PATCH v1 3/3] libcamera: framebuffer_allocator: remove entry if allocation fails

Barnabás Pőcze pobrn at protonmail.com
Sun Mar 10 02:30:04 CET 2024


Remove the entry from the `buffers_` mapping if
`Camera::exportFrameBuffers()` fails, otherwise
there would be a stale entry in the map.
---
 src/libcamera/framebuffer_allocator.cpp | 4 ++++
 1 file changed, 4 insertions(+)

diff --git a/src/libcamera/framebuffer_allocator.cpp b/src/libcamera/framebuffer_allocator.cpp
index fc19a33a..dbd0db19 100644
--- a/src/libcamera/framebuffer_allocator.cpp
+++ b/src/libcamera/framebuffer_allocator.cpp
@@ -97,6 +97,10 @@ int FrameBufferAllocator::allocate(Stream *stream)
 		LOG(Allocator, Error)
 			<< "Stream is not part of " << camera_->id()
 			<< " active configuration";
+
+	if (ret < 0)
+		buffers_.erase(it);
+
 	return ret;
 }
 
-- 
2.44.0




More information about the libcamera-devel mailing list