From e410062003cd26930243ff067a723d1752dfd8d7 Mon Sep 17 00:00:00 2001 From: Jacopo Mondi Date: Wed, 16 Jan 2019 18:30:40 +0100 Subject: test: pipeline: IPU3: Add IPU3 pipeline test Add test for the Intel IPU3 pipeline that lists all the cameras registered in the system and verifies the result matches the expected. This test is meant to be run on IPU3 platforms, it gets skipped otherwise. Acked-by: Kieran Bingham Reviewed-by: Laurent Pinchart Signed-off-by: Jacopo Mondi --- test/pipeline/ipu3/ipu3_pipeline_test.cpp | 130 ++++++++++++++++++++++++++++++ test/pipeline/ipu3/meson.build | 11 +++ test/pipeline/meson.build | 1 + 3 files changed, 142 insertions(+) create mode 100644 test/pipeline/ipu3/ipu3_pipeline_test.cpp create mode 100644 test/pipeline/ipu3/meson.build create mode 100644 test/pipeline/meson.build (limited to 'test/pipeline') diff --git a/test/pipeline/ipu3/ipu3_pipeline_test.cpp b/test/pipeline/ipu3/ipu3_pipeline_test.cpp new file mode 100644 index 00000000..5dbf0206 --- /dev/null +++ b/test/pipeline/ipu3/ipu3_pipeline_test.cpp @@ -0,0 +1,130 @@ +/* SPDX-License-Identifier: GPL-2.0-or-later */ +/* + * Copyright (C) 2019, Google Inc. + * + * ipu3_pipeline_test.cpp - Intel IPU3 pipeline test + */ + +#include + +#include +#include +#include + +#include +#include + +#include "device_enumerator.h" +#include "media_device.h" +#include "media_object.h" +#include "test.h" + +using namespace std; +using namespace libcamera; + +/* + * Verify that the Intel IPU3 pipeline handler gets matched and cameras + * are enumerated correctly. + * + * The test is supposed to be run on an IPU3 platform, otherwise it gets + * skipped. + * + * The test lists all cameras registered in the system, if any camera is + * available at all. + */ +class IPU3PipelineTest : public Test +{ +protected: + int init(); + int run(); + void cleanup(); + +private: + CameraManager *cameraManager_; + unsigned int sensors_; +}; + +int IPU3PipelineTest::init() +{ + unique_ptr enumerator = DeviceEnumerator::create(); + if (!enumerator) { + cerr << "Failed to create device enumerator" << endl; + return TestFail; + } + + if (enumerator->enumerate()) { + cerr << "Failed to enumerate media devices" << endl; + return TestFail; + } + + DeviceMatch imgu_dm("ipu3-imgu"); + DeviceMatch cio2_dm("ipu3-cio2"); + + if (!enumerator->search(imgu_dm)) { + cerr << "Failed to find IPU3 IMGU: test skip" << endl; + return TestSkip; + } + + MediaDevice *cio2 = enumerator->search(cio2_dm); + if (!cio2) { + cerr << "Failed to find IPU3 CIO2: test skip" << endl; + return TestSkip; + } + + if (cio2->open()) { + cerr << "Failed to open media device " << cio2->devnode() << endl; + return TestFail; + } + + /* + * Camera sensor are connected to the CIO2 unit. + * Count how many sensors are connected in the system + * and later verify this matches the number of registered + * cameras. + */ + int ret = cio2->populate(); + if (ret) { + cerr << "Failed to populate media device " << cio2->devnode() << endl; + return TestFail; + } + + sensors_ = 0; + const vector &entities = cio2->entities(); + for (MediaEntity *entity : entities) { + if (entity->function() == MEDIA_ENT_F_CAM_SENSOR) + sensors_++; + } + + enumerator.reset(nullptr); + + cameraManager_ = CameraManager::instance(); + ret = cameraManager_->start(); + if (ret) { + cerr << "Failed to start the CameraManager" << endl; + return TestFail; + } + + return 0; +} + +int IPU3PipelineTest::run() +{ + auto cameras = cameraManager_->cameras(); + for (const std::shared_ptr &cam : cameras) + cout << "Found camera '" << cam->name() << "'" << endl; + + if (cameras.size() != sensors_) { + cerr << cameras.size() << " cameras registered, but " << sensors_ + << " were expected" << endl; + return TestFail; + } + + return TestPass; +} + +void IPU3PipelineTest::cleanup() +{ + cameraManager_->stop(); +} + +TEST_REGISTER(IPU3PipelineTest) diff --git a/test/pipeline/ipu3/meson.build b/test/pipeline/ipu3/meson.build new file mode 100644 index 00000000..caba5c74 --- /dev/null +++ b/test/pipeline/ipu3/meson.build @@ -0,0 +1,11 @@ +ipu3_test = [ + ['ipu3_pipeline_test', 'ipu3_pipeline_test.cpp'], +] + +foreach t : ipu3_test + exe = executable(t[0], t[1], + link_with : test_libraries, + include_directories : test_includes_internal) + + test(t[0], exe, suite: 'ipu3', is_parallel: false) +endforeach diff --git a/test/pipeline/meson.build b/test/pipeline/meson.build new file mode 100644 index 00000000..f434c79c --- /dev/null +++ b/test/pipeline/meson.build @@ -0,0 +1 @@ +subdir('ipu3') -- cgit v1.2.1