libcamera: Replace plain pointers with std::unique<>

libcamera uses std::unique_ptr<> to simplify life time management of
objects and avoid leaks. For historical reasons there are a fair number
of plain pointers with manual memory management. Replace them with
std::unique_ptr<> when the conversion is simple.

Signed-off-by: Laurent Pinchart <laurent.pinchart@ideasonboard.com>
Reviewed-by: Milan Zamazal <mzamazal@redhat.com>
Reviewed-by: Isaac Scott <isaac.scott@ideasonboard.com>
Reviewed-by: Barnabás Pőcze <barnabas.pocze@ideasonboard.com>
This commit is contained in:
Laurent Pinchart
2025-10-15 17:06:51 +03:00
parent 0f9b73bae2
commit 1e4e158d98
16 changed files with 48 additions and 62 deletions

View File

@@ -73,7 +73,7 @@ int main(int argc, char **argv)
sa.sa_handler = &signalHandler;
sigaction(SIGINT, &sa, nullptr);
CameraManager *cm = new libcamera::CameraManager();
std::unique_ptr<CameraManager> cm = std::make_unique<CameraManager>();
ret = cm->start();
if (ret) {
@@ -82,13 +82,12 @@ int main(int argc, char **argv)
return EXIT_FAILURE;
}
MainWindow *mainWindow = new MainWindow(cm, options);
MainWindow *mainWindow = new MainWindow(cm.get(), options);
mainWindow->show();
ret = app.exec();
delete mainWindow;
cm->stop();
delete cm;
return ret;
}

View File

@@ -87,8 +87,8 @@ private:
};
MainWindow::MainWindow(CameraManager *cm, const OptionsParser::Options &options)
: saveRaw_(nullptr), options_(options), cm_(cm), allocator_(nullptr),
isCapturing_(false), captureRaw_(false)
: saveRaw_(nullptr), options_(options), cm_(cm), isCapturing_(false),
captureRaw_(false)
{
int ret;
@@ -450,7 +450,7 @@ int MainWindow::startCapture()
saveRaw_->setEnabled(config_->size() == 2);
/* Allocate and map buffers. */
allocator_ = new FrameBufferAllocator(camera_);
allocator_ = std::make_unique<FrameBufferAllocator>(camera_);
for (StreamConfiguration &config : *config_) {
Stream *stream = config.stream();
@@ -531,8 +531,7 @@ error:
freeBuffers_.clear();
delete allocator_;
allocator_ = nullptr;
allocator_.reset();
return ret;
}
@@ -564,7 +563,7 @@ void MainWindow::stopCapture()
requests_.clear();
freeQueue_.clear();
delete allocator_;
allocator_.reset();
isCapturing_ = false;

View File

@@ -109,7 +109,7 @@ private:
/* Camera manager, camera, configuration and buffers */
libcamera::CameraManager *cm_;
std::shared_ptr<libcamera::Camera> camera_;
libcamera::FrameBufferAllocator *allocator_;
std::unique_ptr<libcamera::FrameBufferAllocator> allocator_;
std::unique_ptr<libcamera::CameraConfiguration> config_;
std::map<libcamera::FrameBuffer *, std::unique_ptr<Image>> mappedBuffers_;

View File

@@ -28,14 +28,12 @@ namespace libcamera {
LOG_DECLARE_CATEGORY(DeviceEnumerator)
DeviceEnumeratorUdev::DeviceEnumeratorUdev()
: udev_(nullptr), monitor_(nullptr), notifier_(nullptr)
: udev_(nullptr), monitor_(nullptr)
{
}
DeviceEnumeratorUdev::~DeviceEnumeratorUdev()
{
delete notifier_;
if (monitor_)
udev_monitor_unref(monitor_);
if (udev_)
@@ -212,7 +210,7 @@ done:
return ret;
int fd = udev_monitor_get_fd(monitor_);
notifier_ = new EventNotifier(fd, EventNotifier::Read);
notifier_ = std::make_unique<EventNotifier>(fd, EventNotifier::Read);
notifier_->activated.connect(this, &DeviceEnumeratorUdev::udevNotify);
return 0;

View File

@@ -70,7 +70,7 @@ LOG_DEFINE_CATEGORY(IPCUnixSocket)
*/
IPCUnixSocket::IPCUnixSocket()
: headerReceived_(false), notifier_(nullptr)
: headerReceived_(false)
{
}
@@ -130,7 +130,7 @@ int IPCUnixSocket::bind(UniqueFD fd)
return -EINVAL;
fd_ = std::move(fd);
notifier_ = new EventNotifier(fd_.get(), EventNotifier::Read);
notifier_ = std::make_unique<EventNotifier>(fd_.get(), EventNotifier::Read);
notifier_->activated.connect(this, &IPCUnixSocket::dataNotifier);
return 0;
@@ -146,8 +146,7 @@ void IPCUnixSocket::close()
if (!isBound())
return;
delete notifier_;
notifier_ = nullptr;
notifier_.reset();
fd_.reset();
headerReceived_ = false;

View File

@@ -123,7 +123,8 @@ int V4L2Device::setFd(UniqueFD fd)
fd_ = std::move(fd);
fdEventNotifier_ = new EventNotifier(fd_.get(), EventNotifier::Exception);
fdEventNotifier_ = std::make_unique<EventNotifier>(fd_.get(),
EventNotifier::Exception);
fdEventNotifier_->activated.connect(this, &V4L2Device::eventAvailable);
fdEventNotifier_->setEnabled(false);
@@ -142,7 +143,7 @@ void V4L2Device::close()
if (!isOpen())
return;
delete fdEventNotifier_;
fdEventNotifier_.reset();
fd_.reset();
}

View File

@@ -535,8 +535,7 @@ std::ostream &operator<<(std::ostream &out, const V4L2DeviceFormat &f)
*/
V4L2VideoDevice::V4L2VideoDevice(const std::string &deviceNode)
: V4L2Device(deviceNode), formatInfo_(nullptr), cache_(nullptr),
fdBufferNotifier_(nullptr), state_(State::Stopped),
watchdogDuration_(0.0)
state_(State::Stopped), watchdogDuration_(0.0)
{
/*
* We default to an MMAP based CAPTURE video device, however this will
@@ -626,7 +625,7 @@ int V4L2VideoDevice::open()
return -EINVAL;
}
fdBufferNotifier_ = new EventNotifier(fd(), notifierType);
fdBufferNotifier_ = std::make_unique<EventNotifier>(fd(), notifierType);
fdBufferNotifier_->activated.connect(this, &V4L2VideoDevice::bufferAvailable);
fdBufferNotifier_->setEnabled(false);
@@ -715,7 +714,7 @@ int V4L2VideoDevice::open(SharedFD handle, enum v4l2_buf_type type)
return -EINVAL;
}
fdBufferNotifier_ = new EventNotifier(fd(), notifierType);
fdBufferNotifier_ = std::make_unique<EventNotifier>(fd(), notifierType);
fdBufferNotifier_->activated.connect(this, &V4L2VideoDevice::bufferAvailable);
fdBufferNotifier_->setEnabled(false);
@@ -760,7 +759,7 @@ void V4L2VideoDevice::close()
return;
releaseBuffers();
delete fdBufferNotifier_;
fdBufferNotifier_.reset();
formatInfo_ = nullptr;
@@ -1374,7 +1373,7 @@ int V4L2VideoDevice::allocateBuffers(unsigned int count,
if (ret < 0)
return ret;
cache_ = new V4L2BufferCache(*buffers);
cache_ = std::make_unique<V4L2BufferCache>(*buffers);
memoryType_ = V4L2_MEMORY_MMAP;
return ret;
@@ -1599,7 +1598,7 @@ int V4L2VideoDevice::importBuffers(unsigned int count)
if (ret)
return ret;
cache_ = new V4L2BufferCache(count);
cache_ = std::make_unique<V4L2BufferCache>(count);
LOG(V4L2, Debug) << "Prepared to import " << count << " buffers";
@@ -1621,8 +1620,7 @@ int V4L2VideoDevice::releaseBuffers()
LOG(V4L2, Debug) << "Releasing buffers";
delete cache_;
cache_ = nullptr;
cache_.reset();
return requestBuffers(0, memoryType_);
}
@@ -2197,14 +2195,12 @@ V4L2PixelFormat V4L2VideoDevice::toV4L2PixelFormat(const PixelFormat &pixelForma
V4L2M2MDevice::V4L2M2MDevice(const std::string &deviceNode)
: deviceNode_(deviceNode)
{
output_ = new V4L2VideoDevice(deviceNode);
capture_ = new V4L2VideoDevice(deviceNode);
output_ = std::make_unique<V4L2VideoDevice>(deviceNode);
capture_ = std::make_unique<V4L2VideoDevice>(deviceNode);
}
V4L2M2MDevice::~V4L2M2MDevice()
{
delete capture_;
delete output_;
}
/**

View File

@@ -20,7 +20,7 @@ LOG_DECLARE_CATEGORY(V4L2Compat)
V4L2Camera::V4L2Camera(std::shared_ptr<Camera> camera)
: camera_(camera), controls_(controls::controls), isRunning_(false),
bufferAllocator_(nullptr), efd_(-1), bufferAvailableCount_(0)
efd_(-1), bufferAvailableCount_(0)
{
camera_->requestCompleted.connect(this, &V4L2Camera::requestComplete);
}
@@ -43,7 +43,7 @@ int V4L2Camera::open(StreamConfiguration *streamConfig)
return -EINVAL;
}
bufferAllocator_ = new FrameBufferAllocator(camera_);
bufferAllocator_ = std::make_unique<FrameBufferAllocator>(camera_);
*streamConfig = config_->at(0);
return 0;
@@ -53,8 +53,7 @@ void V4L2Camera::close()
{
requestPool_.clear();
delete bufferAllocator_;
bufferAllocator_ = nullptr;
bufferAllocator_.reset();
camera_->release();
}

View File

@@ -80,7 +80,7 @@ private:
bool isRunning_;
libcamera::Mutex bufferLock_;
libcamera::FrameBufferAllocator *bufferAllocator_;
std::unique_ptr<libcamera::FrameBufferAllocator> bufferAllocator_;
std::vector<std::unique_ptr<libcamera::Request>> requestPool_;

View File

@@ -54,25 +54,21 @@ V4L2CompatManager::~V4L2CompatManager()
{
files_.clear();
mmaps_.clear();
proxies_.clear();
if (cm_) {
proxies_.clear();
if (cm_)
cm_->stop();
delete cm_;
cm_ = nullptr;
}
}
int V4L2CompatManager::start()
{
cm_ = new CameraManager();
cm_ = std::make_unique<CameraManager>();
int ret = cm_->start();
if (ret) {
LOG(V4L2Compat, Error) << "Failed to start camera manager: "
<< strerror(-ret);
delete cm_;
cm_ = nullptr;
cm_.reset();
return ret;
}
@@ -83,10 +79,8 @@ int V4L2CompatManager::start()
* created here to wrap a camera device.
*/
auto cameras = cm_->cameras();
for (auto [index, camera] : utils::enumerate(cameras)) {
V4L2CameraProxy *proxy = new V4L2CameraProxy(index, camera);
proxies_.emplace_back(proxy);
}
for (auto [index, camera] : utils::enumerate(cameras))
proxies_.emplace_back(std::make_unique<V4L2CameraProxy>(index, camera));
return 0;
}

View File

@@ -61,7 +61,7 @@ private:
FileOperations fops_;
libcamera::CameraManager *cm_;
std::unique_ptr<libcamera::CameraManager> cm_;
std::vector<std::unique_ptr<V4L2CameraProxy>> proxies_;
std::map<int, std::shared_ptr<V4L2CameraFile>> files_;