mirror of
https://gitdl.cn/https://github.com/chakralinux/core.git
synced 2025-01-24 02:22:15 +08:00
125 lines
4.5 KiB
Diff
125 lines
4.5 KiB
Diff
From 2127f99fb43d2ef950e95329ce40bdd5da8b015c Mon Sep 17 00:00:00 2001
|
|
From: Dave Reisner <dreisner@archlinux.org>
|
|
Date: Fri, 25 May 2012 19:43:24 -0400
|
|
Subject: [PATCH] Reinstate TIMEOUT= handling
|
|
|
|
This is mostly to deal with ipw2?00 drivers which have yet to be fixed
|
|
in the kernel.
|
|
---
|
|
src/libudev/libudev-device.c | 19 +++++++++++++++++++
|
|
src/libudev/libudev-private.h | 1 +
|
|
src/udev/udevd.c | 13 ++++++++++---
|
|
3 files changed, 30 insertions(+), 3 deletions(-)
|
|
|
|
diff --git a/src/libudev/libudev-device.c b/src/libudev/libudev-device.c
|
|
index a8277d1..5966189 100644
|
|
--- a/src/libudev/libudev-device.c
|
|
+++ b/src/libudev/libudev-device.c
|
|
@@ -68,6 +68,7 @@ struct udev_device {
|
|
struct udev_list tags_list;
|
|
unsigned long long int seqnum;
|
|
unsigned long long int usec_initialized;
|
|
+ int timeout;
|
|
int devlink_priority;
|
|
int refcount;
|
|
dev_t devnum;
|
|
@@ -89,6 +90,21 @@ struct udev_device {
|
|
bool db_persist;
|
|
};
|
|
|
|
+int udev_device_get_timeout(struct udev_device *udev_device)
|
|
+{
|
|
+ return udev_device->timeout;
|
|
+}
|
|
+
|
|
+static int udev_device_set_timeout(struct udev_device *udev_device, int timeout)
|
|
+{
|
|
+ char num[32];
|
|
+
|
|
+ udev_device->timeout = timeout;
|
|
+ snprintf(num, sizeof(num), "%u", timeout);
|
|
+ udev_device_add_property(udev_device, "TIMEOUT", num);
|
|
+ return 0;
|
|
+}
|
|
+
|
|
/**
|
|
* udev_device_get_seqnum:
|
|
* @udev_device: udev device
|
|
@@ -362,6 +378,8 @@ void udev_device_add_property_from_string_parse(struct udev_device *udev_device,
|
|
|
|
util_strscpyl(path, sizeof(path), TEST_PREFIX "/sys", &property[8], NULL);
|
|
udev_device_set_syspath(udev_device, path);
|
|
+ } else if (strncmp(property, "TIMEOUT=", 8) == 0) {
|
|
+ udev_device_set_timeout(udev_device, strtoull(&property[8], NULL, 10));
|
|
} else if (startswith(property, "SUBSYSTEM=")) {
|
|
udev_device_set_subsystem(udev_device, &property[10]);
|
|
} else if (startswith(property, "DEVTYPE=")) {
|
|
@@ -605,6 +623,7 @@ struct udev_device *udev_device_new(struct udev *udev)
|
|
udev_list_init(udev, &udev_device->sysattr_value_list, true);
|
|
udev_list_init(udev, &udev_device->sysattr_list, false);
|
|
udev_list_init(udev, &udev_device->tags_list, true);
|
|
+ udev_device->timeout = -1;
|
|
udev_device->watch_handle = -1;
|
|
/* copy global properties */
|
|
udev_list_entry_foreach(list_entry, udev_get_properties_list_entry(udev))
|
|
diff --git a/src/libudev/libudev-private.h b/src/libudev/libudev-private.h
|
|
index 4eb4a59..99aefeb 100644
|
|
--- a/src/libudev/libudev-private.h
|
|
+++ b/src/libudev/libudev-private.h
|
|
@@ -70,6 +70,7 @@ const char *udev_device_get_id_filename(struct udev_device *udev_device);
|
|
void udev_device_set_is_initialized(struct udev_device *udev_device);
|
|
int udev_device_add_tag(struct udev_device *udev_device, const char *tag);
|
|
void udev_device_cleanup_tags_list(struct udev_device *udev_device);
|
|
+int udev_device_get_timeout(struct udev_device *udev_device);
|
|
unsigned long long udev_device_get_usec_initialized(struct udev_device *udev_device);
|
|
void udev_device_set_usec_initialized(struct udev_device *udev_device, unsigned long long usec_initialized);
|
|
int udev_device_get_devlink_priority(struct udev_device *udev_device);
|
|
diff --git a/src/udev/udevd.c b/src/udev/udevd.c
|
|
index 0d85960..cd24462 100644
|
|
--- a/src/udev/udevd.c
|
|
+++ b/src/udev/udevd.c
|
|
@@ -384,7 +384,7 @@ out:
|
|
}
|
|
}
|
|
|
|
-static void event_run(struct event *event)
|
|
+static void event_run(struct event *event, bool force)
|
|
{
|
|
struct udev_list_node *loop;
|
|
|
|
@@ -410,7 +410,7 @@ static void event_run(struct event *event)
|
|
return;
|
|
}
|
|
|
|
- if (children >= children_max) {
|
|
+ if (!force && children >= children_max) {
|
|
if (children_max > 1)
|
|
log_debug("maximum number (%i) of children reached\n", children);
|
|
return;
|
|
@@ -444,6 +444,13 @@ static int event_queue_insert(struct udev_device *dev)
|
|
|
|
event->state = EVENT_QUEUED;
|
|
udev_list_node_append(&event->node, &event_list);
|
|
+
|
|
+ /* run all events with a timeout set immediately */
|
|
+ if (udev_device_get_timeout(dev) > 0) {
|
|
+ event_run(event, true);
|
|
+ return 0;
|
|
+ }
|
|
+
|
|
return 0;
|
|
}
|
|
|
|
@@ -549,7 +556,7 @@ static void event_queue_start(struct udev *udev)
|
|
if (is_devpath_busy(event))
|
|
continue;
|
|
|
|
- event_run(event);
|
|
+ event_run(event, false);
|
|
}
|
|
}
|
|
|
|
--
|
|
1.7.10.2
|
|
|