libcamera: Rename V4L2Device to V4L2VideoDevice
In preparation of creating a new V4L2Device base class, rename V4L2Device to V4L2VideoDevice. This is a project wide rename without any intended functional change. Signed-off-by: Jacopo Mondi <jacopo@jmondi.org> Signed-off-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
This commit is contained in:
parent
20807a8c17
commit
3a6c4bd146
19 changed files with 130 additions and 129 deletions
89
test/v4l2_videodevice/capture_async.cpp
Normal file
89
test/v4l2_videodevice/capture_async.cpp
Normal file
|
@ -0,0 +1,89 @@
|
|||
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
||||
/*
|
||||
* Copyright (C) 2019, Google Inc.
|
||||
*
|
||||
* libcamera V4L2 API tests
|
||||
*/
|
||||
|
||||
#include <libcamera/buffer.h>
|
||||
#include <libcamera/camera_manager.h>
|
||||
#include <libcamera/event_dispatcher.h>
|
||||
#include <libcamera/timer.h>
|
||||
|
||||
#include <iostream>
|
||||
|
||||
#include "v4l2_videodevice_test.h"
|
||||
|
||||
class CaptureAsyncTest : public V4L2VideoDeviceTest
|
||||
{
|
||||
public:
|
||||
CaptureAsyncTest()
|
||||
: V4L2VideoDeviceTest("vimc", "Raw Capture 0"), frames(0) {}
|
||||
|
||||
void receiveBuffer(Buffer *buffer)
|
||||
{
|
||||
std::cout << "Received buffer " << buffer->index() << std::endl;
|
||||
frames++;
|
||||
|
||||
/* Requeue the buffer for further use. */
|
||||
capture_->queueBuffer(buffer);
|
||||
}
|
||||
|
||||
protected:
|
||||
int run()
|
||||
{
|
||||
const unsigned int bufferCount = 8;
|
||||
|
||||
EventDispatcher *dispatcher = CameraManager::instance()->eventDispatcher();
|
||||
Timer timeout;
|
||||
int ret;
|
||||
|
||||
pool_.createBuffers(bufferCount);
|
||||
|
||||
ret = capture_->exportBuffers(&pool_);
|
||||
if (ret)
|
||||
return TestFail;
|
||||
|
||||
capture_->bufferReady.connect(this, &CaptureAsyncTest::receiveBuffer);
|
||||
|
||||
/* Queue all the buffers to the device. */
|
||||
for (Buffer &b : pool_.buffers()) {
|
||||
if (capture_->queueBuffer(&b))
|
||||
return TestFail;
|
||||
}
|
||||
|
||||
ret = capture_->streamOn();
|
||||
if (ret)
|
||||
return TestFail;
|
||||
|
||||
timeout.start(10000);
|
||||
while (timeout.isRunning()) {
|
||||
dispatcher->processEvents();
|
||||
if (frames > 30)
|
||||
break;
|
||||
}
|
||||
|
||||
if (frames < 1) {
|
||||
std::cout << "Failed to capture any frames within timeout." << std::endl;
|
||||
return TestFail;
|
||||
}
|
||||
|
||||
if (frames < 30) {
|
||||
std::cout << "Failed to capture 30 frames within timeout." << std::endl;
|
||||
return TestFail;
|
||||
}
|
||||
|
||||
std::cout << "Processed " << frames << " frames" << std::endl;
|
||||
|
||||
ret = capture_->streamOff();
|
||||
if (ret)
|
||||
return TestFail;
|
||||
|
||||
return TestPass;
|
||||
}
|
||||
|
||||
private:
|
||||
unsigned int frames;
|
||||
};
|
||||
|
||||
TEST_REGISTER(CaptureAsyncTest);
|
Loading…
Add table
Add a link
Reference in a new issue