auth/box: bind in the binary by default

This prevents stuttering on the command line by
not having to give a -r flag for the binary itself.
This commit is contained in:
Jacob Moody 2022-06-08 02:44:35 +00:00
parent 056ad652a4
commit 1b5ea51ee1

View file

@ -54,9 +54,6 @@ resolvenames(char **names, int nname)
case '#': case '#':
case '/': case '/':
break; break;
case '.':
if(names[i][1] == '/')
break;
default: default:
names[i] = cleanname(smprint("%s/%s", buf, names[i])); names[i] = cleanname(smprint("%s/%s", buf, names[i]));
} }
@ -111,19 +108,6 @@ sandbox(char **names, int *flags, int nname)
binderr(newroot, "/", MREPL); binderr(newroot, "/", MREPL);
} }
static void
run(char **a)
{
exec(a[0], a);
if(a[0][0] != '/' && a[0][0] != '#' &&
(a[0][0] != '.' || (a[0][1] != '/' &&
(a[0][1] != '.' || a[0][2] != '/'))))
exec(smprint("/bin/%s", a[0]), a);
sysfatal("exec: %s: %r", a[0]);
}
void void
usage(void) usage(void)
{ {
@ -134,6 +118,8 @@ usage(void)
void void
main(int argc, char **argv) main(int argc, char **argv)
{ {
char *b;
Dir *d;
char devs[1024]; char devs[1024];
int dfd; int dfd;
char *parts[256]; char *parts[256];
@ -164,6 +150,19 @@ main(int argc, char **argv)
if(argc == 0) if(argc == 0)
usage(); usage();
b = argv[0];
d = dirstat(b);
if(d == nil){
b = smprint("/bin/%s", b);
d = dirstat(b);
if(d == nil)
sysfatal("could not stat %s %r", argv[0]);
}
free(d);
parts[nparts] = b;
mflags[nparts++] = MREPL;
argv[0] = b;
rfork(RFNAMEG|RFENVG); rfork(RFNAMEG|RFENVG);
dfd = open("/dev/drivers", OWRITE|OCEXEC); dfd = open("/dev/drivers", OWRITE|OCEXEC);
if(dfd < 0) if(dfd < 0)
@ -188,5 +187,5 @@ main(int argc, char **argv)
sysfatal("could not write chdev: %r"); sysfatal("could not write chdev: %r");
} }
close(dfd); close(dfd);
run(argv); exec(argv[0], argv);
} }