summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorLaurent Pinchart <laurent.pinchart@ideasonboard.com>2019-01-24 01:04:09 +0200
committerLaurent Pinchart <laurent.pinchart@ideasonboard.com>2019-01-24 22:24:13 +0200
commit9d29af143b6b91dfe34c7a302c12a077561438c5 (patch)
treedccfbb72fa283508457b90fa16b09ca4d7de8a15 /src
parent4f043b05e74cf66f2a78f593eaef2772f11af33f (diff)
libcamera: media_device: Add disconnected signal
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@ideasonboard.com> Reviewed-by: Niklas Söderlund <niklas.soderlund@ragnatech.se>
Diffstat (limited to 'src')
-rw-r--r--src/libcamera/include/media_device.h4
-rw-r--r--src/libcamera/media_device.cpp10
2 files changed, 14 insertions, 0 deletions
diff --git a/src/libcamera/include/media_device.h b/src/libcamera/include/media_device.h
index 8a7b9489..27a2b46a 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 51e5088e..be81bd8c 100644
--- a/src/libcamera/media_device.cpp
+++ b/src/libcamera/media_device.cpp
@@ -428,6 +428,16 @@ int MediaDevice::disableLinks()
}
/**
+ * \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
* object id.