[libcamera-devel] [PATCH v3 3/3] test: v4l2_videodevice: Verify the Dequeue Watchdog
Laurent Pinchart
laurent.pinchart at ideasonboard.com
Tue Apr 5 18:00:27 CEST 2022
Hi Naush,
Thank you for the patch.
On Tue, Mar 29, 2022 at 12:29:29PM +0100, Naushir Patuck via libcamera-devel wrote:
> From: Kieran Bingham <kieran.bingham at ideasonboard.com>
>
> Add a test that captures 5 frames, with a short (5ms) watchdog.
> The default framerate of the VIMC pipeline should ensure that
> we never meet this watchdog, and the timeout should activate.
>
> Signed-off-by: Kieran Bingham <kieran.bingham at ideasonboard.com>
> Signed-off-by: Naushir Patuck <naush at raspberrypi.com>
Reviewed-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
> ---
> test/v4l2_videodevice/dequeue_watchdog.cpp | 96 ++++++++++++++++++++++
> test/v4l2_videodevice/meson.build | 1 +
> 2 files changed, 97 insertions(+)
> create mode 100644 test/v4l2_videodevice/dequeue_watchdog.cpp
>
> diff --git a/test/v4l2_videodevice/dequeue_watchdog.cpp b/test/v4l2_videodevice/dequeue_watchdog.cpp
> new file mode 100644
> index 000000000000..0cb4de6f81a0
> --- /dev/null
> +++ b/test/v4l2_videodevice/dequeue_watchdog.cpp
> @@ -0,0 +1,96 @@
> +/* SPDX-License-Identifier: GPL-2.0-or-later */
> +/*
> + * Copyright (C) 2022, Ideas on Board Oy.
> + *
> + * libcamera V4L2 dequeue watchdog test
> + */
> +
> +#include <iostream>
> +
> +#include <libcamera/base/event_dispatcher.h>
> +#include <libcamera/base/thread.h>
> +#include <libcamera/base/timer.h>
> +
> +#include <libcamera/framebuffer.h>
> +
> +#include "v4l2_videodevice_test.h"
> +
> +using namespace libcamera;
> +using namespace std::chrono_literals;
> +
> +class DequeueWatchdogTest : public V4L2VideoDeviceTest
> +{
> +public:
> + DequeueWatchdogTest()
> + : V4L2VideoDeviceTest("vimc", "Raw Capture 0"), frames_(0), barks_(0) {}
> +
> +protected:
> + int run()
> + {
> + constexpr unsigned int bufferCount = 8;
> +
> + EventDispatcher *dispatcher = Thread::current()->eventDispatcher();
> + Timer timeout;
> +
> + int ret = capture_->allocateBuffers(bufferCount, &buffers_);
> + if (ret < 0)
> + return TestFail;
> +
> + capture_->dequeueTimeout.connect(this, &DequeueWatchdogTest::barkCounter);
> + capture_->setDequeueTimeout(5ms);
> +
> + capture_->bufferReady.connect(this, &DequeueWatchdogTest::receiveBuffer);
> +
> + for (const std::unique_ptr<FrameBuffer> &buffer : buffers_) {
> + if (capture_->queueBuffer(buffer.get())) {
> + std::cout << "Failed to queue buffer" << std::endl;
> + return TestFail;
> + }
> + }
> +
> + capture_->streamOn();
> +
> + timeout.start(5s);
> + while (timeout.isRunning()) {
> + dispatcher->processEvents();
> + if (frames_ > 5)
> + break;
> + }
> +
> + std::cout << "Processed " << frames_ << " frames_ and heard "
> + << barks_ << " barks_" << std::endl;
> +
> + if (!barks_) {
> + std::cout << "Failed to hear any barks_." << std::endl;
> + return TestFail;
> + }
> +
> + capture_->streamOff();
> +
> + return TestPass;
> + }
> +
> +private:
> + void receiveBuffer(FrameBuffer *buffer)
> + {
> + if (buffer->metadata().status == FrameMetadata::FrameCancelled)
> + return;
> +
> + std::cout << "Buffer received" << std::endl;
> + frames_++;
> +
> + /* Requeue the buffer for further use. */
> + capture_->queueBuffer(buffer);
> + }
> +
> + void barkCounter()
> + {
> + std::cout << "Watchdog is barking" << std::endl;
> + barks_++;
> + }
> +
> + unsigned int frames_;
> + unsigned int barks_;
> +};
> +
> +TEST_REGISTER(DequeueWatchdogTest)
> diff --git a/test/v4l2_videodevice/meson.build b/test/v4l2_videodevice/meson.build
> index 643f82edce5e..7a26f53d106a 100644
> --- a/test/v4l2_videodevice/meson.build
> +++ b/test/v4l2_videodevice/meson.build
> @@ -6,6 +6,7 @@ v4l2_videodevice_tests = [
> ['double_open', 'double_open.cpp'],
> ['controls', 'controls.cpp'],
> ['formats', 'formats.cpp'],
> + ['dequeue_watchdog', 'dequeue_watchdog.cpp'],
> ['request_buffers', 'request_buffers.cpp'],
> ['buffer_cache', 'buffer_cache.cpp'],
> ['stream_on_off', 'stream_on_off.cpp'],
--
Regards,
Laurent Pinchart
More information about the libcamera-devel
mailing list