[libcamera-devel] [PATCH 05/10] libcamera: media_device: Add disconnected signal

Laurent Pinchart laurent.pinchart at ideasonboard.com
Thu Jan 24 11:16:46 CET 2019


The signal is emitted when the hardware device corresponding to the
media device is unplugged. This will trigger the full unplug handling
chain.

Signed-off-by: Laurent Pinchart <laurent.pinchart at ideasonboard.com>
---
 src/libcamera/include/media_device.h |  4 ++++
 src/libcamera/media_device.cpp       | 10 ++++++++++
 2 files changed, 14 insertions(+)

diff --git a/src/libcamera/include/media_device.h b/src/libcamera/include/media_device.h
index 8a7b9489faa9..27a2b46a4392 100644
--- a/src/libcamera/include/media_device.h
+++ b/src/libcamera/include/media_device.h
@@ -14,6 +14,8 @@
 
 #include <linux/media.h>
 
+#include <libcamera/signal.h>
+
 #include "media_object.h"
 
 namespace libcamera {
@@ -48,6 +50,8 @@ public:
 	MediaLink *link(const MediaPad *source, const MediaPad *sink);
 	int disableLinks();
 
+	Signal<MediaDevice *> disconnected;
+
 private:
 	std::string driver_;
 	std::string deviceNode_;
diff --git a/src/libcamera/media_device.cpp b/src/libcamera/media_device.cpp
index 51e5088ebdd9..be81bd8c4c23 100644
--- a/src/libcamera/media_device.cpp
+++ b/src/libcamera/media_device.cpp
@@ -427,6 +427,16 @@ int MediaDevice::disableLinks()
 	return 0;
 }
 
+/**
+ * \var MediaDevice::disconnected
+ * \brief Signal emitted when the media device is disconnected from the system
+ *
+ * This signal is emitted when the device enumerator detects that the media
+ * device has been removed from the system. For hot-pluggable devices this is
+ * usually caused by physical device disconnection, but can also result from
+ * driver unloading for most devices. The media device is passed as a parameter.
+ */
+
 /**
  * \var MediaDevice::objects_
  * \brief Global map of media objects (entities, pads, links) keyed by their
-- 
Regards,

Laurent Pinchart



More information about the libcamera-devel mailing list