mirror of
https://git.libcamera.org/libcamera/libcamera.git
synced 2025-07-13 07:19:45 +03:00
Remove the need for the caller to open and close the media device when populating the MediaDevice. This is done as an effort to make the usage of the MediaDevice less error prone and the interface stricter. The rework also revealed and fixes a potential memory leak in MediaDevice::populate() where resources would not be deleted if the second MEDIA_IOC_G_TOPOLOGY would fail. Signed-off-by: Niklas Söderlund <niklas.soderlund@ragnatech.se> Reviewed-by: Kieran Bingham <kieran.bingham@ideasonboard.com> Reviewed-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
125 lines
2.7 KiB
C++
125 lines
2.7 KiB
C++
/* SPDX-License-Identifier: GPL-2.0-or-later */
|
|
/*
|
|
* Copyright (C) 2019, Google Inc.
|
|
*
|
|
* ipu3_pipeline_test.cpp - Intel IPU3 pipeline test
|
|
*/
|
|
|
|
#include <iostream>
|
|
|
|
#include <sys/stat.h>
|
|
#include <sys/types.h>
|
|
#include <unistd.h>
|
|
|
|
#include <libcamera/camera.h>
|
|
#include <libcamera/camera_manager.h>
|
|
|
|
#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<DeviceEnumerator> 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;
|
|
}
|
|
|
|
std::shared_ptr<MediaDevice> cio2 = enumerator->search(cio2_dm);
|
|
if (!cio2) {
|
|
cerr << "Failed to find IPU3 CIO2: test skip" << endl;
|
|
return TestSkip;
|
|
}
|
|
|
|
/*
|
|
* 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->deviceNode() << endl;
|
|
return TestFail;
|
|
}
|
|
|
|
sensors_ = 0;
|
|
const vector<MediaEntity *> &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<Camera> &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)
|