aboutsummaryrefslogtreecommitdiffstats
path: root/package/hotplug2
diff options
context:
space:
mode:
authorVasilis Tsiligiannis <b_tsiligiannis@silverton.gr>2010-04-03 18:15:42 +0000
committerVasilis Tsiligiannis <b_tsiligiannis@silverton.gr>2010-04-03 18:15:42 +0000
commitb6a5e28a76775d7b0f79ed0c868bf008b63c672b (patch)
tree99279134558e342902ad7dd5dbb3b7c29b5907d2 /package/hotplug2
parent5b5b531c5786cd10216f41cd692688a73fb2df96 (diff)
downloadmaster-187ad058-b6a5e28a76775d7b0f79ed0c868bf008b63c672b.tar.gz
master-187ad058-b6a5e28a76775d7b0f79ed0c868bf008b63c672b.tar.bz2
master-187ad058-b6a5e28a76775d7b0f79ed0c868bf008b63c672b.zip
[package] hotplug2: Always fork rules flagged as slow
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@20682 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'package/hotplug2')
-rw-r--r--package/hotplug2/patches/150-force_fork_slow.patch21
1 files changed, 21 insertions, 0 deletions
diff --git a/package/hotplug2/patches/150-force_fork_slow.patch b/package/hotplug2/patches/150-force_fork_slow.patch
new file mode 100644
index 0000000000..47101f56b9
--- /dev/null
+++ b/package/hotplug2/patches/150-force_fork_slow.patch
@@ -0,0 +1,21 @@
+--- a/workers/worker_fork.c
++++ b/workers/worker_fork.c
+@@ -396,7 +396,7 @@ static int worker_fork_process(void *in_
+ worker_fork_update_children(ctx);
+
+ child = NULL;
+- for (i = 0; i < ctx->children_count; i++) {
++ for (i = 0; i < ctx->children_count && i < ctx->max_children; i++) {
+ if (ctx->children[i]->busy == 0) {
+ child = ctx->children[i];
+ break;
+@@ -426,7 +426,8 @@ static int worker_fork_process(void *in_
+ /*
+ * We have to fork off a new child.
+ */
+- if (ctx->children_count < ctx->max_children)
++ if (ctx->children_count < ctx->max_children ||
++ (ruleset_flags(&ctx->settings->rules, uevent) & FLAG_SLOW))
+ child = worker_fork_spawn(ctx);
+
+ for (i = 0; i < uevent->env_vars_c; i++) {