aboutsummaryrefslogtreecommitdiff
path: root/main.c
diff options
context:
space:
mode:
authorJeremie Koenig <jk@jk.fr.eu.org>2010-08-22 21:23:36 +0000
committerJeremie Koenig <jk@jk.fr.eu.org>2010-08-30 14:29:51 +0200
commit4665f087fde174a9de3e1c3f3de090dd4bfa85e0 (patch)
tree111edd6241a6fc5b493939e9379f19396a097992 /main.c
parent5714e1cef2584410a7823c7ead9d2435141fb0c4 (diff)
downloadhurd-4665f087fde174a9de3e1c3f3de090dd4bfa85e0.tar.gz
hurd-4665f087fde174a9de3e1c3f3de090dd4bfa85e0.tar.bz2
hurd-4665f087fde174a9de3e1c3f3de090dd4bfa85e0.zip
Add a fake-self option to control the self symlink
* main.c (argp_parse, main): Add the --fake-self option. * main.h: Publish it. * rootdir.c (rootdir_gc_fakeself, rootdir_entries, rootdir_create_node): Use it.
Diffstat (limited to 'main.c')
-rw-r--r--main.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/main.c b/main.c
index 09cffc76..26f5248f 100644
--- a/main.c
+++ b/main.c
@@ -13,6 +13,7 @@
/* Command-line options */
int opt_clk_tck;
mode_t opt_stat_mode;
+pid_t opt_fake_self;
static error_t
argp_parser (int key, char *arg, struct argp_state *state)
@@ -32,6 +33,17 @@ argp_parser (int key, char *arg, struct argp_state *state)
if (*endp || ! *arg || opt_stat_mode & ~07777)
error (1, 0, "--stat-mode: MODE should be an octal mode");
break;
+
+ case 'S':
+ if (arg)
+ {
+ opt_fake_self = strtol (arg, &endp, 0);
+ if (*endp || ! *arg)
+ error (1, 0, "--fake-self: PID must be an integer");
+ }
+ else
+ opt_fake_self = 1;
+ break;
}
return 0;
@@ -48,6 +60,10 @@ struct argp argp = {
"You can use this option to override its mode to be more permissive "
"for compatibility purposes. "
"(default: 0400)" },
+ { "fake-self", 'S', "PID", OPTION_ARG_OPTIONAL,
+ "Provide a fake \"self\" symlink to the given PID, for compatibility "
+ "purposes. If PID is omitted, \"self\" will point to init. "
+ "(default: no self link)" },
{}
},
.parser = argp_parser,
@@ -95,6 +111,7 @@ int main (int argc, char **argv)
opt_clk_tck = sysconf(_SC_CLK_TCK);
opt_stat_mode = 0400;
+ opt_fake_self = -1;
argp_parse (&argp, argc, argv, 0, 0, 0);
task_get_bootstrap_port (mach_task_self (), &bootstrap);