summaryrefslogtreecommitdiffstats
path: root/usr.sbin/jail/command.c
diff options
context:
space:
mode:
authorjamie <jamie@FreeBSD.org>2011-06-18 15:23:08 +0000
committerjamie <jamie@FreeBSD.org>2011-06-18 15:23:08 +0000
commitb3870a12d7efae3649e1a6c7496069c521524a0b (patch)
treead59a2ee8acfbad5eba1ef300574c820f63e8367 /usr.sbin/jail/command.c
parent8d425bfde2c0af68087f5784ac994ac5d316a375 (diff)
downloadFreeBSD-src-b3870a12d7efae3649e1a6c7496069c521524a0b.zip
FreeBSD-src-b3870a12d7efae3649e1a6c7496069c521524a0b.tar.gz
Move the actual create/remove (IP__OP) handling into run_command,
and the cost of an ugly single-use global variable.
Diffstat (limited to 'usr.sbin/jail/command.c')
-rw-r--r--usr.sbin/jail/command.c39
1 files changed, 32 insertions, 7 deletions
diff --git a/usr.sbin/jail/command.c b/usr.sbin/jail/command.c
index d79f4f9..fa6a026 100644
--- a/usr.sbin/jail/command.c
+++ b/usr.sbin/jail/command.c
@@ -94,7 +94,7 @@ next_command(struct cfjail *j)
rval = 0;
create_failed = (j->flags & (JF_STOP | JF_FAILED)) == JF_FAILED;
- for (; (comparam = *j->comparam) && comparam != IP__OP;
+ for (; (comparam = *j->comparam);
j->comparam += create_failed ? -1 : 1) {
if (j->comstring == NULL) {
switch (comparam) {
@@ -102,6 +102,7 @@ next_command(struct cfjail *j)
if (!bool_param(j->intparams[IP_MOUNT_DEVFS]))
continue;
/* FALLTHROUGH */
+ case IP__OP:
case IP_STOP_TIMEOUT:
j->comstring = &dummystring;
break;
@@ -256,19 +257,43 @@ run_command(struct cfjail *j)
static char *cleanenv;
+ /* Perform some operations that aren't actually commands */
+ comparam = *j->comparam;
+ down = j->flags & (JF_STOP | JF_FAILED);
+ switch (comparam) {
+ case IP_STOP_TIMEOUT:
+ return term_procs(j);
+
+ case IP__OP:
+ if (down) {
+ if (jail_remove(j->jid) == 0 && verbose >= 0 &&
+ (verbose > 0 || (j->flags & JF_STOP
+ ? note_remove : j->name != NULL)))
+ jail_note(j, "removed\n");
+ j->jid = -1;
+ if (j->flags & JF_STOP)
+ dep_done(j, DF_LIGHT);
+ else
+ j->flags &= ~JF_PERSIST;
+ } else {
+ if (create_jail(j) < 0) {
+ failed(j);
+ return -1;
+ }
+ if (verbose >= 0 && (j->name || verbose > 0))
+ jail_note(j, "created\n");
+ dep_done(j, DF_LIGHT);
+ }
+ requeue(j, &ready);
+ return 1;
+ }
/*
* Collect exec arguments. Internal commands for network and
* mounting build their own argument lists.
*/
- comparam = *j->comparam;
comstring = j->comstring;
bg = 0;
- down = j->flags & (JF_STOP | JF_FAILED);
switch (comparam) {
- case IP_STOP_TIMEOUT:
- /* This isn't really a command */
- return term_procs(j);
-
case IP__IP4_IFADDR:
argv = alloca(8 * sizeof(char *));
*(const char **)&argv[0] = _PATH_IFCONFIG;
OpenPOWER on IntegriCloud