[libcamera-devel] [PATCH] pipeline: raspberrypi: Simplify RPiCameraData::clearIncompleteRequests()
David Plowman
david.plowman at raspberrypi.com
Fri Jun 11 16:38:17 CEST 2021
Hi Naush
Thanks for the tidy-up!
I can't say I understand the details of this sufficiently to give a
very meaningful review, however, I get the point that you can simply
stop the streams without having to queue buffers back first.
Nevertheless, I've been running with this for a while now with no ill
effects, hence:
Tested-by: David Plowman <david.plowman at raspberrypi.com>
Thanks!
David
On Thu, 3 Jun 2021 at 13:43, Naushir Patuck <naush at raspberrypi.com> wrote:
>
> With the addition of FrameBuffer::cancel(), the logic to clear and return
> pending requests can be simplified by not having to queue all the request
> buffers to the device before calling streamOff().
>
> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
> ---
> .../pipeline/raspberrypi/raspberrypi.cpp | 46 ++++---------------
> 1 file changed, 8 insertions(+), 38 deletions(-)
>
> diff --git a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> index a65b4568256c..887f8d0f7404 100644
> --- a/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> +++ b/src/libcamera/pipeline/raspberrypi/raspberrypi.cpp
> @@ -884,7 +884,9 @@ void PipelineHandlerRPi::stop(Camera *camera)
> /* Disable SOF event generation. */
> data->unicam_[Unicam::Image].dev()->setFrameStartEnabled(false);
>
> - /* This also stops the streams. */
> + for (auto const stream : data->streams_)
> + stream->dev()->streamOff();
> +
> data->clearIncompleteRequests();
> data->bayerQueue_ = {};
> data->embeddedQueue_ = {};
> @@ -1477,49 +1479,17 @@ void RPiCameraData::ispOutputDequeue(FrameBuffer *buffer)
>
> void RPiCameraData::clearIncompleteRequests()
> {
> - /*
> - * Queue up any buffers passed in the request.
> - * This is needed because streamOff() will then mark the buffers as
> - * cancelled.
> - */
> - for (auto const request : requestQueue_) {
> - for (auto const stream : streams_) {
> - if (!stream->isExternal())
> - continue;
> -
> - FrameBuffer *buffer = request->findBuffer(stream);
> - if (buffer)
> - stream->queueBuffer(buffer);
> - }
> - }
> -
> - /* Stop all streams. */
> - for (auto const stream : streams_)
> - stream->dev()->streamOff();
> -
> /*
> * All outstanding requests (and associated buffers) must be returned
> - * back to the pipeline. The buffers would have been marked as
> - * cancelled by the call to streamOff() earlier.
> + * back to the pipeline.
> */
> while (!requestQueue_.empty()) {
> Request *request = requestQueue_.front();
> - /*
> - * A request could be partially complete,
> - * i.e. we have returned some buffers, but still waiting
> - * for others or waiting for metadata.
> - */
> - for (auto const stream : streams_) {
> - if (!stream->isExternal())
> - continue;
>
> - FrameBuffer *buffer = request->findBuffer(stream);
> - /*
> - * Has the buffer already been handed back to the
> - * request? If not, do so now.
> - */
> - if (buffer && buffer->request())
> - pipe_->completeBuffer(request, buffer);
> + for (auto &b : request->buffers()) {
> + FrameBuffer *buffer = b.second;
> + buffer->cancel();
> + pipe_->completeBuffer(request, buffer);
> }
>
> pipe_->completeRequest(request);
> --
> 2.25.1
>
More information about the libcamera-devel
mailing list