summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAlbert Astals Cid <albert.astals@canonical.com>2017-02-09 10:57:31 +0100
committerAlbert Astals Cid <albert.astals@canonical.com>2017-02-10 09:26:38 +0000
commitdceb7c7276e5374032c379a21921c6e55e21bc7f (patch)
treef90140fa74b1640936bc28c01f602b1dccb2b265
parentf46977ae785632e52fc7212265f2e1e0d38565db (diff)
Don't crash if udev_monitor_new_from_netlink fails
Change-Id: Ia5d17b3c2e2d6d12345678075a4e6085aace7b2a Reviewed-by: Lorn Potter <lorn.potter@gmail.com>
-rw-r--r--src/systeminfo/linux/qinputinfomanagerudev.cpp50
-rw-r--r--src/systeminfo/linux/qnetworkinfo_linux.cpp18
2 files changed, 38 insertions, 30 deletions
diff --git a/src/systeminfo/linux/qinputinfomanagerudev.cpp b/src/systeminfo/linux/qinputinfomanagerudev.cpp
index b40941e5..e6a85d5a 100644
--- a/src/systeminfo/linux/qinputinfomanagerudev.cpp
+++ b/src/systeminfo/linux/qinputinfomanagerudev.cpp
@@ -72,33 +72,35 @@ void QInputInfoManagerUdev::init()
if (udevice) {
udevMonitor = udev_monitor_new_from_netlink(udevice, "udev");
- udev_monitor_filter_add_match_subsystem_devtype(udevMonitor, subsystem.toLatin1(), NULL);
- enumerate = udev_enumerate_new(udevice);
- udev_enumerate_add_match_subsystem(enumerate, subsystem.toLatin1());
-
- udev_monitor_enable_receiving(udevMonitor);
- notifierFd = udev_monitor_get_fd(udevMonitor);
-
- notifier = new QSocketNotifier(notifierFd, QSocketNotifier::Read, this);
- connect(notifier, SIGNAL(activated(int)), this, SLOT(onUDevChanges()));
-
- udev_enumerate_scan_devices(enumerate);
- devices = udev_enumerate_get_list_entry(enumerate);
-
- udev_list_entry_foreach(dev_list_entry, devices) {
- const char *path;
- path = udev_list_entry_get_name(dev_list_entry);
-
- dev = udev_device_new_from_syspath(udevice, path);
- if (qstrcmp(udev_device_get_subsystem(dev), "input") == 0 ) {
- QInputDevice *iDevice = addDevice(dev);
- if (iDevice && !iDevice->identifier().isEmpty()) {
- deviceMap.insert(iDevice->identifier(),iDevice);
+ if (udevMonitor) {
+ udev_monitor_filter_add_match_subsystem_devtype(udevMonitor, subsystem.toLatin1(), NULL);
+ enumerate = udev_enumerate_new(udevice);
+ udev_enumerate_add_match_subsystem(enumerate, subsystem.toLatin1());
+
+ udev_monitor_enable_receiving(udevMonitor);
+ notifierFd = udev_monitor_get_fd(udevMonitor);
+
+ notifier = new QSocketNotifier(notifierFd, QSocketNotifier::Read, this);
+ connect(notifier, SIGNAL(activated(int)), this, SLOT(onUDevChanges()));
+
+ udev_enumerate_scan_devices(enumerate);
+ devices = udev_enumerate_get_list_entry(enumerate);
+
+ udev_list_entry_foreach(dev_list_entry, devices) {
+ const char *path;
+ path = udev_list_entry_get_name(dev_list_entry);
+
+ dev = udev_device_new_from_syspath(udevice, path);
+ if (qstrcmp(udev_device_get_subsystem(dev), "input") == 0 ) {
+ QInputDevice *iDevice = addDevice(dev);
+ if (iDevice && !iDevice->identifier().isEmpty()) {
+ deviceMap.insert(iDevice->identifier(),iDevice);
+ }
}
+ udev_device_unref(dev);
}
- udev_device_unref(dev);
+ udev_enumerate_unref(enumerate);
}
- udev_enumerate_unref(enumerate);
}
// udev_unref(udevice);
Q_FOREACH (const QString &devicePath, deviceMap.keys()) {
diff --git a/src/systeminfo/linux/qnetworkinfo_linux.cpp b/src/systeminfo/linux/qnetworkinfo_linux.cpp
index 6979f948..9a981ec9 100644
--- a/src/systeminfo/linux/qnetworkinfo_linux.cpp
+++ b/src/systeminfo/linux/qnetworkinfo_linux.cpp
@@ -439,12 +439,16 @@ void QNetworkInfoPrivate::connectNotify(const QMetaMethod &signal)
if (!udevHandle) {
udevHandle = udev_new();
udevMonitor = udev_monitor_new_from_netlink(udevHandle, "udev");
- udev_monitor_filter_add_match_subsystem_devtype(udevMonitor, "net", NULL);
- udev_monitor_enable_receiving(udevMonitor);
- udevNotifier = new QSocketNotifier(udev_monitor_get_fd(udevMonitor), QSocketNotifier::Read, this);
- connect(udevNotifier, SIGNAL(activated(int)), this, SLOT(onUdevChanged()));
+ if (udevMonitor) {
+ udev_monitor_filter_add_match_subsystem_devtype(udevMonitor, "net", NULL);
+ udev_monitor_enable_receiving(udevMonitor);
+ udevNotifier = new QSocketNotifier(udev_monitor_get_fd(udevMonitor), QSocketNotifier::Read, this);
+ connect(udevNotifier, SIGNAL(activated(int)), this, SLOT(onUdevChanged()));
+ }
+ }
+ if (udevNotifier) {
+ udevNotifier->setEnabled(true);
}
- udevNotifier->setEnabled(true);
#endif // QT_NO_UDEV
watchNetworkInterfaceCount = true;
@@ -538,7 +542,9 @@ void QNetworkInfoPrivate::disconnectNotify(const QMetaMethod &signal)
if (signal == networkInterfaceCountChangedSignal
&& !watchNetworkStatus && !watchNetworkName && !watchNetworkSignalStrength ) {
#if !defined(QT_NO_UDEV)
- udevNotifier->setEnabled(false);
+ if (udevNotifier) {
+ udevNotifier->setEnabled(false);
+ }
watchNetworkInterfaceCount = false;
return;
#endif // QT_NO_UDEV