summaryrefslogtreecommitdiffstats
path: root/testModule/systemd-preserve-process-marker.c
diff options
context:
space:
mode:
authortorben2015-04-20 14:44:12 +0200
committertorben2015-04-20 14:44:12 +0200
commit81e7552e02341e6bff0ac1daccbe9156fbd1d147 (patch)
tree3cfe9fe7ea679cfdcbcce3634a3dc59e4355cb91 /testModule/systemd-preserve-process-marker.c
parentMerge branch 'master' of git.openslx.org:openslx-ng/systemd-init (diff)
downloadsystemd-init-81e7552e02341e6bff0ac1daccbe9156fbd1d147.tar.gz
systemd-init-81e7552e02341e6bff0ac1daccbe9156fbd1d147.tar.xz
systemd-init-81e7552e02341e6bff0ac1daccbe9156fbd1d147.zip
Cleanup refactoring. Evaluate minimal needed dependencies.
Diffstat (limited to 'testModule/systemd-preserve-process-marker.c')
-rw-r--r--testModule/systemd-preserve-process-marker.c31
1 files changed, 31 insertions, 0 deletions
diff --git a/testModule/systemd-preserve-process-marker.c b/testModule/systemd-preserve-process-marker.c
new file mode 100644
index 00000000..172a5546
--- /dev/null
+++ b/testModule/systemd-preserve-process-marker.c
@@ -0,0 +1,31 @@
+#include <unistd.h>
+#include <stdlib.h>
+#include <string.h>
+#include <stdio.h>
+
+void print_array(int argc, char *argv[]) {
+ // Helper function to print given array with given length.
+ int i = 0;
+ int j = 0;
+ for (i = 0; i < argc; i ++) {
+ j = 0;
+ while(argv[i][j] != '\0')
+ printf("%c", argv[i][j++]);
+ printf(" ");
+ }
+ printf("\n");
+}
+int main(int argc, char *argv[]) {
+ int count;
+ char **copy = malloc(sizeof(char *) * (argc-1));
+ for (count = 0; count < argc - 1; count++)
+ copy[count] = strdup(argv[count + 1]);
+ // Adding systemd indicator to preserve wrapped process during changing
+ // root filesystem. We mark wrapper and child process.
+ copy[0][0] = '@';
+ argv[0][0] = '@';
+ if (-1 == execvp(argv[1], copy)) {
+ perror("child process execve failed [%m]");
+ return -1;
+ }
+}