summaryrefslogtreecommitdiff
path: root/package/hotplug2/patches/120-fork_handling.patch
diff options
context:
space:
mode:
Diffstat (limited to 'package/hotplug2/patches/120-fork_handling.patch')
-rw-r--r--package/hotplug2/patches/120-fork_handling.patch142
1 files changed, 0 insertions, 142 deletions
diff --git a/package/hotplug2/patches/120-fork_handling.patch b/package/hotplug2/patches/120-fork_handling.patch
deleted file mode 100644
index c234a6c..0000000
--- a/package/hotplug2/patches/120-fork_handling.patch
+++ /dev/null
@@ -1,142 +0,0 @@
-Index: hotplug2-0.9/hotplug2.c
-===================================================================
---- hotplug2-0.9.orig/hotplug2.c 2007-06-25 11:36:44.800185312 +0200
-+++ hotplug2-0.9/hotplug2.c 2007-06-25 11:39:08.318367232 +0200
-@@ -313,6 +313,17 @@
- }
-
- #ifdef HAVE_RULES
-+static int action_needs_fork(struct hotplug2_event_t *event, struct rules_t *rules)
-+{
-+ int i, rv;
-+
-+ for (i = 0; i < rules->rules_c; i++) {
-+ if (rule_needs_fork(event, &rules->rules[i]))
-+ return 1;
-+ }
-+ return 0;
-+}
-+
- void perform_action(struct hotplug2_event_t *event, struct rules_t *rules) {
- int i, rv;
-
-@@ -565,14 +576,20 @@
- cur_seqnum = strtoull(seqnum, NULL, 0);
- if (cur_seqnum > highest_seqnum)
- highest_seqnum = cur_seqnum;
--
-+
- if ((dumb && tmpevent->action == ACTION_ADD && modalias != NULL) || (!dumb)) {
-- /*
-- * We have more children than we want. Wait until SIGCHLD handler reduces
-- * their numbers.
-- */
-- while (child_c >= max_child_c) {
-- usleep(HOTPLUG2_THROTTLE_INTERVAL);
-+ int untracked = 0;
-+
-+ if (!dumb && !action_needs_fork(tmpevent, rules))
-+ untracked = 1;
-+ else {
-+ /*
-+ * We have more children than we want. Wait until SIGCHLD handler reduces
-+ * their numbers.
-+ */
-+ while (child_c >= max_child_c) {
-+ usleep(HOTPLUG2_THROTTLE_INTERVAL);
-+ }
- }
-
- sigemptyset(&block_mask);
-@@ -595,13 +612,16 @@
- break;
- default:
- DBG("spawn", "spawning: %d.", p);
-- child = add_child(child, p, cur_seqnum);
-- child_c++;
-+ if (!untracked) {
-+ child = add_child(child, p, cur_seqnum);
-+ child_c++;
-+ }
- break;
- }
- sigprocmask(SIG_UNBLOCK, &block_mask, 0);
- }
-
-+done:
- free_hotplug2_event(tmpevent);
- }
-
-Index: hotplug2-0.9/rules.c
-===================================================================
---- hotplug2-0.9.orig/rules.c 2007-06-25 11:36:44.801185160 +0200
-+++ hotplug2-0.9/rules.c 2007-06-25 11:36:44.822181968 +0200
-@@ -363,6 +363,41 @@
- return EVAL_NOT_AVAILABLE;
- }
-
-+int rule_needs_fork(struct hotplug2_event_t *event, struct rule_t *rule)
-+{
-+ int i, last_rv;
-+
-+ for (i = 0; i < rule->conditions_c; i++) {
-+ if (rule_condition_eval(event, &(rule->conditions[i])) != EVAL_MATCH)
-+ return 0;
-+ }
-+ for (i = 0; i < rule->actions_c; i++) {
-+ switch (rule->actions[i].type) {
-+ case ACT_STOP_PROCESSING:
-+ return 0;
-+ break;
-+ case ACT_STOP_IF_FAILED:
-+ if (last_rv != 0)
-+ return 0;
-+ break;
-+ case ACT_NEXT_EVENT:
-+ return 0;
-+ break;
-+ case ACT_NEXT_IF_FAILED:
-+ if (last_rv != 0)
-+ return 0;
-+ break;
-+ case ACT_RUN_SHELL:
-+ return 1;
-+ break;
-+ case ACT_RUN_NOSHELL:
-+ return 1;
-+ break;
-+ }
-+ }
-+ return 0;
-+}
-+
- int rule_execute(struct hotplug2_event_t *event, struct rule_t *rule) {
- int i, last_rv;
-
-Index: hotplug2-0.9/rules.h
-===================================================================
---- hotplug2-0.9.orig/rules.h 2007-06-25 11:36:44.801185160 +0200
-+++ hotplug2-0.9/rules.h 2007-06-25 11:36:44.822181968 +0200
-@@ -77,5 +77,6 @@
- int rule_execute(struct hotplug2_event_t *, struct rule_t *);
- void rules_free(struct rules_t *);
- struct rules_t *rules_from_config(char *);
-+int rule_needs_fork(struct hotplug2_event_t *event, struct rule_t *rule);
-
- #endif /* ifndef RULES_H*/
-Index: hotplug2-0.9/childlist.c
-===================================================================
---- hotplug2-0.9.orig/childlist.c 2007-06-25 11:40:23.477941240 +0200
-+++ hotplug2-0.9/childlist.c 2007-06-25 11:40:48.164188360 +0200
-@@ -41,10 +41,8 @@
- struct hotplug2_child_t *remove_child_by_pid(struct hotplug2_child_t *child, pid_t pid, event_seqnum_t *largest_seqnum, int *child_c) {
- struct hotplug2_child_t *tmp_child;
-
-- if (child == NULL) {
-- ERROR("remove_child_by_pid", "Invalid child list passed (NULL).");
-+ if (child == NULL)
- return NULL;
-- }
-
- tmp_child = child;
-