diff options
author | Vasilis Tsiligiannis <acinonyx@openwrt.gr> | 2010-04-03 18:15:42 +0000 |
---|---|---|
committer | Vasilis Tsiligiannis <acinonyx@openwrt.gr> | 2010-04-03 18:15:42 +0000 |
commit | 2cdfbaa86cd647befa8f2d59b93bbf12144b744d (patch) | |
tree | ec63d8f2048cebfbe3dd0ea4342fac8e19a75098 /package/hotplug2/patches | |
parent | 1516cadf1f12a53263dd7dd604e8b5a5bf6ccf31 (diff) | |
download | upstream-2cdfbaa86cd647befa8f2d59b93bbf12144b744d.tar.gz upstream-2cdfbaa86cd647befa8f2d59b93bbf12144b744d.tar.bz2 upstream-2cdfbaa86cd647befa8f2d59b93bbf12144b744d.zip |
hotplug2: Always fork rules flagged as slow
SVN-Revision: 20682
Diffstat (limited to 'package/hotplug2/patches')
-rw-r--r-- | package/hotplug2/patches/150-force_fork_slow.patch | 21 |
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++) { |