summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMichael Shalayeff <mickey@cvs.openbsd.org>1997-04-26 17:50:09 +0000
committerMichael Shalayeff <mickey@cvs.openbsd.org>1997-04-26 17:50:09 +0000
commit39bc18ac3290db498ba2a6e3d30637f836947340 (patch)
treec51a4d1d3eb0e60ee753f74939d48dd8d35af766
parent6bdc1ce3a8ccaf3a9fec3bcb79ef0e745806e9f5 (diff)
boot.conf support
ttyname function in cons.c rdonly var 'tty' to view tty settings serial console soon
-rw-r--r--sys/arch/i386/stand/boot/boot.c20
-rw-r--r--sys/arch/i386/stand/boot/cmd.c219
-rw-r--r--sys/arch/i386/stand/boot/cmd.h7
-rw-r--r--sys/lib/libsa/cons.c23
-rw-r--r--sys/lib/libsa/stand.h3
-rw-r--r--sys/stand/boot/boot.c20
-rw-r--r--sys/stand/boot/cmd.c219
-rw-r--r--sys/stand/boot/cmd.h7
8 files changed, 357 insertions, 161 deletions
diff --git a/sys/arch/i386/stand/boot/boot.c b/sys/arch/i386/stand/boot/boot.c
index bad06787a71..65d16c933d5 100644
--- a/sys/arch/i386/stand/boot/boot.c
+++ b/sys/arch/i386/stand/boot/boot.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: boot.c,v 1.7 1997/04/21 20:03:30 mickey Exp $ */
+/* $OpenBSD: boot.c,v 1.8 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -49,7 +49,7 @@ extern const char version[];
int boothowto;
u_int cnvmem, extmem;
struct cmd_state cmd = {
- "", "", "/", (void *)0x100000, 50, ""
+ "", "bsd", "/etc/boot.conf", "/", (void *)0x100000, 50, ""
};
void
@@ -57,30 +57,31 @@ boot(bootdev)
dev_t bootdev;
{
register char *bootfile = kernels[0];
- register int i = 0;
+ register int i = 0, f;
#ifdef DEBUG
*(u_int16_t*)0xb8148 = 0x4730;
#endif
gateA20(1);
+ cons_probe(); /* call console init before any io */
#ifndef _TEST
memprobe();
#endif
#ifdef DEBUG
*(u_int16_t*)0xb8148 = 0x4f31;
#endif
- cons_probe();
debug_init();
printf(">> OpenBSD BOOT: %u/%u k [%s]\n", cnvmem, extmem, version);
devboot(bootdev, cmd.bootdev);
+ f = read_conf(&cmd);
while (1) {
- strncpy(cmd.image, bootfile, sizeof(cmd.image));
-
- do {
- printf("boot> ");
- } while(!getcmd(&cmd));
+ if (f <= 0) /* no boot.conf, or no boot cmd in there */
+ do {
+ printf("boot> ");
+ } while(!getcmd(&cmd));
+ f = 0;
printf("booting %s: ", cmd.path);
exec(cmd.path, cmd.addr, boothowto);
@@ -92,6 +93,7 @@ boot(bootdev)
cmd.timeout += 20;
printf(" failed(%d). will try %s\n", errno, bootfile);
+ strncpy(cmd.image, bootfile, sizeof(cmd.image));
}
}
diff --git a/sys/arch/i386/stand/boot/cmd.c b/sys/arch/i386/stand/boot/cmd.c
index 66935bec89f..7d196c09859 100644
--- a/sys/arch/i386/stand/boot/cmd.c
+++ b/sys/arch/i386/stand/boot/cmd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmd.c,v 1.11 1997/04/21 20:20:25 mickey Exp $ */
+/* $OpenBSD: cmd.c,v 1.12 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -46,41 +46,43 @@ extern int debug;
#define CTRL(c) ((c)&0x1f)
-static int Xaddr __P((struct cmd_state *));
-static int Xboot __P((struct cmd_state *));
-static int Xcd __P((struct cmd_state *));
-static int Xcp __P((struct cmd_state *));
-static int Xdevice __P((struct cmd_state *));
+static int Xaddr __P((register struct cmd_state *));
+static int Xboot __P((register struct cmd_state *));
+static int Xcd __P((register struct cmd_state *));
+static int Xcp __P((register struct cmd_state *));
+static int Xdevice __P((register struct cmd_state *));
#ifdef DEBUG
-static int Xdebug __P((struct cmd_state *));
+static int Xdebug __P((register struct cmd_state *));
#endif
-static int Xhelp __P((struct cmd_state *));
-static int Ximage __P((struct cmd_state *));
-static int Xls __P((struct cmd_state *));
-static int Xnope __P((struct cmd_state *));
-static int Xreboot __P((struct cmd_state *));
-static int Xregs __P((struct cmd_state *));
-static int Xset __P((struct cmd_state *));
-static int Xhowto __P((struct cmd_state *));
+static int Xhelp __P((register struct cmd_state *));
+static int Ximage __P((register struct cmd_state *));
+static int Xls __P((register struct cmd_state *));
+static int Xnope __P((register struct cmd_state *));
+static int Xreboot __P((register struct cmd_state *));
+static int Xregs __P((register struct cmd_state *));
+static int Xset __P((register struct cmd_state *));
+static int Xhowto __P((register struct cmd_state *));
+static int Xtty __P((register struct cmd_state *));
struct cmd_table {
char *cmd_name;
- int (*cmd_exec)(struct cmd_state *);
+ int (*cmd_exec) __P((register struct cmd_state *));
const struct cmd_table *cmd_table;
};
-const struct cmd_table cmd_set[] = {
+static const struct cmd_table cmd_set[] = {
{"addr", Xaddr},
{"boothowto", Xhowto},
#ifdef DEBUG
{"debug", Xdebug},
#endif
{"device", Xdevice},
+ {"tty", Xtty},
{"image", Ximage},
{NULL,0}
};
-const struct cmd_table cmd_table[] = {
+static const struct cmd_table cmd_table[] = {
{"boot", Xboot}, /* XXX must be first */
{"cd", Xcd},
{"cp", Xcp},
@@ -97,28 +99,91 @@ extern const char version[];
static void ls __P((char *, register struct stat *));
static int readline __P((register char *, int));
char *nextword __P((register char *));
-static int bootparse __P((struct cmd_state *, int));
+static int bootparse __P((register struct cmd_state *, int));
static char *whatcmd
__P((register const struct cmd_table **, register char *));
-char cmd_buf[133];
+static int docmd __P((register struct cmd_state *));
+static char *qualify __P((register struct cmd_state *, char *));
+
+static char cmd_buf[133];
int
getcmd(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
+{
+ cmd->cmd = NULL;
+
+ if (!readline(cmd_buf, cmd->timeout))
+ cmd->cmd = cmd_table;
+
+ return docmd(cmd);
+}
+
+int
+read_conf(cmd)
+ register struct cmd_state *cmd;
+{
+#ifndef INSECURE
+ struct stat sb;
+#endif
+ int fd, eof = 0;
+
+ if ((fd = open(qualify(cmd, cmd->conf), 0)) < 0) {
+ if (errno != ENOENT) {
+ printf("open(%s): %s\n", cmd->path, strerror(errno));
+ return 0;
+ }
+ return -1;
+ }
+
+#ifndef INSECURE
+ (void) fstat(fd, &sb);
+ if (sb.st_uid || (sb.st_mode & 2)) {
+ printf("non-secure %s, will not proceed\n", cmd->path);
+ close(fd);
+ return -1;
+ }
+#endif
+
+ do {
+ register char *p = cmd_buf;
+
+ cmd->cmd = NULL;
+
+ do
+ eof = read(fd, p, 1);
+ while (eof > 0 && *p++ != '\n');
+
+ if (eof < 0)
+ printf("%s: %s\n", cmd->path, strerror(errno));
+ else
+ *--p = '\0';
+
+ } while (eof > 0 && !(eof = docmd(cmd)));
+
+ close(fd);
+ return eof;
+}
+
+static int
+docmd(cmd)
+ register struct cmd_state *cmd;
{
const struct cmd_table *ct;
- register char *p;
+ register char *p = NULL;
cmd->argc = 1;
-
- if (!readline(cmd_buf, cmd->timeout)) {
- cmd->cmd = cmd_table;
- p = NULL;
- } else {
+ if (cmd->cmd == NULL) {
/* command */
for (p = cmd_buf; *p && (*p == ' ' || *p == '\t'); p++)
;
+ if (*p == '#' || *p == '\0') { /* comment or empty string */
+#ifdef DEBUG
+ printf("rem\n");
+#endif
+ return 0;
+ }
ct = cmd_table;
cmd->argv[cmd->argc] = p; /* in case it's shortcut boot */
p = whatcmd(&ct, p);
@@ -192,12 +257,14 @@ readline(buf, to)
while (1) {
switch ((ch = getchar())) {
+ case CTRL('r'):
+ while (pe > buf)
+ putchar('\b');
+ printf(buf);
case CTRL('u'):
while (pe >= buf) {
pe--;
putchar('\b');
- putchar(' ');
- putchar('\b');
}
p = pe = buf;
continue;
@@ -207,8 +274,6 @@ readline(buf, to)
case '\b':
if (p > buf) {
putchar('\b');
- putchar(' ');
- putchar('\b');
p--;
pe--;
}
@@ -263,7 +328,7 @@ Xdebug(cmd)
static int
Xhelp(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register const struct cmd_table *ct;
@@ -278,7 +343,7 @@ Xhelp(cmd)
/* called only w/ no arguments */
static int
Xset(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register const struct cmd_table *ct;
@@ -291,7 +356,7 @@ Xset(cmd)
static int
Xdevice(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc != 2)
printf("device=%s\n", cmd->bootdev);
@@ -302,7 +367,7 @@ Xdevice(cmd)
static int
Ximage(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc != 2)
printf("image=%s\n", cmd->image);
@@ -313,7 +378,7 @@ Ximage(cmd)
static int
Xaddr(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register char *p;
@@ -336,19 +401,26 @@ Xaddr(cmd)
}
static int
+Xtty(cmd)
+ register struct cmd_state *cmd;
+{
+ if (cmd->argc == 1)
+ printf("tty=%s\n", ttyname(0));
+ else {
+ }
+
+ return 0;
+}
+
+static int
Xls(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
struct stat sb;
register char *p;
int fd;
- if (cmd->argv[1] != NULL)
- strncpy (cmd->path, cmd->argv[1], sizeof(cmd->path));
- else
- sprintf(cmd->path, "%s:%s/.", cmd->bootdev, cmd->cwd);
-
- if (stat(cmd->path, &sb) < 0) {
+ if (stat(qualify(cmd, (cmd->argv[1]? cmd->argv[1]: "/.")), &sb) < 0) {
printf("stat(%s): %s\n", cmd->path, strerror(errno));
return 0;
}
@@ -384,9 +456,9 @@ Xls(cmd)
putchar ((mode) & S_IWOTH? 'w' : '-'); \
putchar ((mode) & S_IXOTH? *(s): (s)[1]);
-void
+static void
ls(name, sb)
- char *name;
+ register char *name;
register struct stat *sb;
{
putchar("-fc-d-b---l-s-w-"[(sb->st_mode & S_IFMT) >> 12]);
@@ -401,7 +473,7 @@ ls(name, sb)
static int
Xhowto(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc < 2) {
printf("boothowto=");
@@ -426,23 +498,10 @@ Xhowto(cmd)
static int
Xboot(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc > 1 && cmd->argv[1][0] != '-') {
- register char *p;
-
- for (p = cmd->argv[1]; *p; p++)
- if (*p == ':')
- break;
- if (*p == ':')
- sprintf(cmd->path, "%s", cmd->argv[1]);
- else if (cmd->argv[1][0] == '/')
- sprintf(cmd->path, "%s:%s", cmd->bootdev,
- cmd->argv[1]);
- else
- sprintf(cmd->path, "%s:%s%s", cmd->bootdev,
- cmd->cwd, cmd->argv[1]);
-
+ qualify(cmd, (cmd->argv[1]? cmd->argv[1]: cmd->image));
if (bootparse(cmd, 2))
return 0;
} else {
@@ -455,9 +514,35 @@ Xboot(cmd)
return 1;
}
+/*
+ * Qualifies the path adding neccessary dev&|cwd
+ */
+
+static char *
+qualify(cmd, name)
+ register struct cmd_state *cmd;
+ char *name;
+{
+ register char *p;
+
+ for (p = name; *p; p++)
+ if (*p == ':')
+ break;
+ if (*p == ':')
+ if (p[1] == '/')
+ sprintf(cmd->path, "%s", name);
+ else
+ sprintf(cmd->path, "%s%s%s", name, cmd->cwd, name);
+ else if (name[0] == '/')
+ sprintf(cmd->path, "%s:%s", cmd->bootdev, name);
+ else
+ sprintf(cmd->path, "%s:%s%s", cmd->bootdev, cmd->cwd, name);
+ return cmd->path;
+}
+
static int
bootparse(cmd, i)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
int i;
{
register char *cp;
@@ -499,7 +584,7 @@ bootparse(cmd, i)
static int
Xcd(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register char *p, *q;
struct stat sb;
@@ -552,7 +637,7 @@ Xcd(cmd)
static int
Xreboot(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
printf("Rebooting...\n");
exit();
@@ -561,7 +646,7 @@ Xreboot(cmd)
static int
Xregs(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
DUMP_REGS;
return 0;
@@ -569,14 +654,14 @@ Xregs(cmd)
static int
Xnope(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
return 0;
}
static int
Xcp(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
printf("cp: no writable filesystems\n");
return 0;
diff --git a/sys/arch/i386/stand/boot/cmd.h b/sys/arch/i386/stand/boot/cmd.h
index a806e1c05f7..7682af1dd25 100644
--- a/sys/arch/i386/stand/boot/cmd.h
+++ b/sys/arch/i386/stand/boot/cmd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmd.h,v 1.4 1997/04/21 20:03:31 mickey Exp $ */
+/* $OpenBSD: cmd.h,v 1.5 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -36,14 +36,17 @@ struct cmd_table;
struct cmd_state {
char bootdev[16]; /* device */
char image[32]; /* image */
+ char *conf; /* /etc/boot.conf normally */
char cwd[MAXPATHLEN - 32 - 16];
void *addr; /* load here */
int timeout;
- char path[MAXPATHLEN]; /* buffer for pathname compose */
+ char path[MAXPATHLEN]; /* buffer for pathname compose */
const struct cmd_table *cmd;
int argc;
char *argv[8]; /* XXX i hope this is enough */
};
int getcmd __P((register struct cmd_state *));
+int read_conf __P((register struct cmd_state *));
+
diff --git a/sys/lib/libsa/cons.c b/sys/lib/libsa/cons.c
index 2e38e664f34..f0677f66149 100644
--- a/sys/lib/libsa/cons.c
+++ b/sys/lib/libsa/cons.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cons.c,v 1.2 1997/04/02 04:59:22 mickey Exp $ */
+/* $OpenBSD: cons.c,v 1.3 1997/04/26 17:50:08 mickey Exp $ */
/*
* Copyright (c) 1996 Michael Shalayeff
@@ -34,20 +34,35 @@
#include <stand.h>
-struct consw *console = &consw[0];
+static struct consw *console = &consw[0];
int
cons_probe()
{
- int i;
+ int i, f = 0;
for (i = 0; i < ncons; i++) {
- if ((consw[i].cn_probe)() != 0)
+ if ((consw[i].cn_probe)() != 0) {
+ if (f == 0)
+ f++, console = &consw[i];
printf("%s present\n", consw[i].name);
+ }
}
+ if (!f) /* not found */
+ printf("no any console detected, ");
printf("using %s console\n", console->name);
return 1;
}
+char *
+ttyname(fd)
+ int fd;
+{
+ if (fd)
+ return "(not a tty)";
+ else
+ return console->name;
+}
+
void
putc(c)
int c;
diff --git a/sys/lib/libsa/stand.h b/sys/lib/libsa/stand.h
index d4ec3c203fd..0a9b40a87c7 100644
--- a/sys/lib/libsa/stand.h
+++ b/sys/lib/libsa/stand.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: stand.h,v 1.22 1997/04/21 19:49:30 mickey Exp $ */
+/* $OpenBSD: stand.h,v 1.23 1997/04/26 17:50:08 mickey Exp $ */
/* $NetBSD: stand.h,v 1.18 1996/11/30 04:35:51 gwr Exp $ */
/*-
@@ -187,6 +187,7 @@ off_t null_seek __P((struct open_file *f, off_t offset, int where));
int null_stat __P((struct open_file *f, struct stat *sb));
int null_readdir __P((struct open_file *f, char *name));
int cons_probe __P((void));
+char *ttyname __P((int)); /* match userland decl, but ignore !0 */
void putc __P((int));
int getc __P((void));
int ischar __P((void));
diff --git a/sys/stand/boot/boot.c b/sys/stand/boot/boot.c
index bad06787a71..65d16c933d5 100644
--- a/sys/stand/boot/boot.c
+++ b/sys/stand/boot/boot.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: boot.c,v 1.7 1997/04/21 20:03:30 mickey Exp $ */
+/* $OpenBSD: boot.c,v 1.8 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -49,7 +49,7 @@ extern const char version[];
int boothowto;
u_int cnvmem, extmem;
struct cmd_state cmd = {
- "", "", "/", (void *)0x100000, 50, ""
+ "", "bsd", "/etc/boot.conf", "/", (void *)0x100000, 50, ""
};
void
@@ -57,30 +57,31 @@ boot(bootdev)
dev_t bootdev;
{
register char *bootfile = kernels[0];
- register int i = 0;
+ register int i = 0, f;
#ifdef DEBUG
*(u_int16_t*)0xb8148 = 0x4730;
#endif
gateA20(1);
+ cons_probe(); /* call console init before any io */
#ifndef _TEST
memprobe();
#endif
#ifdef DEBUG
*(u_int16_t*)0xb8148 = 0x4f31;
#endif
- cons_probe();
debug_init();
printf(">> OpenBSD BOOT: %u/%u k [%s]\n", cnvmem, extmem, version);
devboot(bootdev, cmd.bootdev);
+ f = read_conf(&cmd);
while (1) {
- strncpy(cmd.image, bootfile, sizeof(cmd.image));
-
- do {
- printf("boot> ");
- } while(!getcmd(&cmd));
+ if (f <= 0) /* no boot.conf, or no boot cmd in there */
+ do {
+ printf("boot> ");
+ } while(!getcmd(&cmd));
+ f = 0;
printf("booting %s: ", cmd.path);
exec(cmd.path, cmd.addr, boothowto);
@@ -92,6 +93,7 @@ boot(bootdev)
cmd.timeout += 20;
printf(" failed(%d). will try %s\n", errno, bootfile);
+ strncpy(cmd.image, bootfile, sizeof(cmd.image));
}
}
diff --git a/sys/stand/boot/cmd.c b/sys/stand/boot/cmd.c
index 66935bec89f..7d196c09859 100644
--- a/sys/stand/boot/cmd.c
+++ b/sys/stand/boot/cmd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmd.c,v 1.11 1997/04/21 20:20:25 mickey Exp $ */
+/* $OpenBSD: cmd.c,v 1.12 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -46,41 +46,43 @@ extern int debug;
#define CTRL(c) ((c)&0x1f)
-static int Xaddr __P((struct cmd_state *));
-static int Xboot __P((struct cmd_state *));
-static int Xcd __P((struct cmd_state *));
-static int Xcp __P((struct cmd_state *));
-static int Xdevice __P((struct cmd_state *));
+static int Xaddr __P((register struct cmd_state *));
+static int Xboot __P((register struct cmd_state *));
+static int Xcd __P((register struct cmd_state *));
+static int Xcp __P((register struct cmd_state *));
+static int Xdevice __P((register struct cmd_state *));
#ifdef DEBUG
-static int Xdebug __P((struct cmd_state *));
+static int Xdebug __P((register struct cmd_state *));
#endif
-static int Xhelp __P((struct cmd_state *));
-static int Ximage __P((struct cmd_state *));
-static int Xls __P((struct cmd_state *));
-static int Xnope __P((struct cmd_state *));
-static int Xreboot __P((struct cmd_state *));
-static int Xregs __P((struct cmd_state *));
-static int Xset __P((struct cmd_state *));
-static int Xhowto __P((struct cmd_state *));
+static int Xhelp __P((register struct cmd_state *));
+static int Ximage __P((register struct cmd_state *));
+static int Xls __P((register struct cmd_state *));
+static int Xnope __P((register struct cmd_state *));
+static int Xreboot __P((register struct cmd_state *));
+static int Xregs __P((register struct cmd_state *));
+static int Xset __P((register struct cmd_state *));
+static int Xhowto __P((register struct cmd_state *));
+static int Xtty __P((register struct cmd_state *));
struct cmd_table {
char *cmd_name;
- int (*cmd_exec)(struct cmd_state *);
+ int (*cmd_exec) __P((register struct cmd_state *));
const struct cmd_table *cmd_table;
};
-const struct cmd_table cmd_set[] = {
+static const struct cmd_table cmd_set[] = {
{"addr", Xaddr},
{"boothowto", Xhowto},
#ifdef DEBUG
{"debug", Xdebug},
#endif
{"device", Xdevice},
+ {"tty", Xtty},
{"image", Ximage},
{NULL,0}
};
-const struct cmd_table cmd_table[] = {
+static const struct cmd_table cmd_table[] = {
{"boot", Xboot}, /* XXX must be first */
{"cd", Xcd},
{"cp", Xcp},
@@ -97,28 +99,91 @@ extern const char version[];
static void ls __P((char *, register struct stat *));
static int readline __P((register char *, int));
char *nextword __P((register char *));
-static int bootparse __P((struct cmd_state *, int));
+static int bootparse __P((register struct cmd_state *, int));
static char *whatcmd
__P((register const struct cmd_table **, register char *));
-char cmd_buf[133];
+static int docmd __P((register struct cmd_state *));
+static char *qualify __P((register struct cmd_state *, char *));
+
+static char cmd_buf[133];
int
getcmd(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
+{
+ cmd->cmd = NULL;
+
+ if (!readline(cmd_buf, cmd->timeout))
+ cmd->cmd = cmd_table;
+
+ return docmd(cmd);
+}
+
+int
+read_conf(cmd)
+ register struct cmd_state *cmd;
+{
+#ifndef INSECURE
+ struct stat sb;
+#endif
+ int fd, eof = 0;
+
+ if ((fd = open(qualify(cmd, cmd->conf), 0)) < 0) {
+ if (errno != ENOENT) {
+ printf("open(%s): %s\n", cmd->path, strerror(errno));
+ return 0;
+ }
+ return -1;
+ }
+
+#ifndef INSECURE
+ (void) fstat(fd, &sb);
+ if (sb.st_uid || (sb.st_mode & 2)) {
+ printf("non-secure %s, will not proceed\n", cmd->path);
+ close(fd);
+ return -1;
+ }
+#endif
+
+ do {
+ register char *p = cmd_buf;
+
+ cmd->cmd = NULL;
+
+ do
+ eof = read(fd, p, 1);
+ while (eof > 0 && *p++ != '\n');
+
+ if (eof < 0)
+ printf("%s: %s\n", cmd->path, strerror(errno));
+ else
+ *--p = '\0';
+
+ } while (eof > 0 && !(eof = docmd(cmd)));
+
+ close(fd);
+ return eof;
+}
+
+static int
+docmd(cmd)
+ register struct cmd_state *cmd;
{
const struct cmd_table *ct;
- register char *p;
+ register char *p = NULL;
cmd->argc = 1;
-
- if (!readline(cmd_buf, cmd->timeout)) {
- cmd->cmd = cmd_table;
- p = NULL;
- } else {
+ if (cmd->cmd == NULL) {
/* command */
for (p = cmd_buf; *p && (*p == ' ' || *p == '\t'); p++)
;
+ if (*p == '#' || *p == '\0') { /* comment or empty string */
+#ifdef DEBUG
+ printf("rem\n");
+#endif
+ return 0;
+ }
ct = cmd_table;
cmd->argv[cmd->argc] = p; /* in case it's shortcut boot */
p = whatcmd(&ct, p);
@@ -192,12 +257,14 @@ readline(buf, to)
while (1) {
switch ((ch = getchar())) {
+ case CTRL('r'):
+ while (pe > buf)
+ putchar('\b');
+ printf(buf);
case CTRL('u'):
while (pe >= buf) {
pe--;
putchar('\b');
- putchar(' ');
- putchar('\b');
}
p = pe = buf;
continue;
@@ -207,8 +274,6 @@ readline(buf, to)
case '\b':
if (p > buf) {
putchar('\b');
- putchar(' ');
- putchar('\b');
p--;
pe--;
}
@@ -263,7 +328,7 @@ Xdebug(cmd)
static int
Xhelp(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register const struct cmd_table *ct;
@@ -278,7 +343,7 @@ Xhelp(cmd)
/* called only w/ no arguments */
static int
Xset(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register const struct cmd_table *ct;
@@ -291,7 +356,7 @@ Xset(cmd)
static int
Xdevice(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc != 2)
printf("device=%s\n", cmd->bootdev);
@@ -302,7 +367,7 @@ Xdevice(cmd)
static int
Ximage(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc != 2)
printf("image=%s\n", cmd->image);
@@ -313,7 +378,7 @@ Ximage(cmd)
static int
Xaddr(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register char *p;
@@ -336,19 +401,26 @@ Xaddr(cmd)
}
static int
+Xtty(cmd)
+ register struct cmd_state *cmd;
+{
+ if (cmd->argc == 1)
+ printf("tty=%s\n", ttyname(0));
+ else {
+ }
+
+ return 0;
+}
+
+static int
Xls(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
struct stat sb;
register char *p;
int fd;
- if (cmd->argv[1] != NULL)
- strncpy (cmd->path, cmd->argv[1], sizeof(cmd->path));
- else
- sprintf(cmd->path, "%s:%s/.", cmd->bootdev, cmd->cwd);
-
- if (stat(cmd->path, &sb) < 0) {
+ if (stat(qualify(cmd, (cmd->argv[1]? cmd->argv[1]: "/.")), &sb) < 0) {
printf("stat(%s): %s\n", cmd->path, strerror(errno));
return 0;
}
@@ -384,9 +456,9 @@ Xls(cmd)
putchar ((mode) & S_IWOTH? 'w' : '-'); \
putchar ((mode) & S_IXOTH? *(s): (s)[1]);
-void
+static void
ls(name, sb)
- char *name;
+ register char *name;
register struct stat *sb;
{
putchar("-fc-d-b---l-s-w-"[(sb->st_mode & S_IFMT) >> 12]);
@@ -401,7 +473,7 @@ ls(name, sb)
static int
Xhowto(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc < 2) {
printf("boothowto=");
@@ -426,23 +498,10 @@ Xhowto(cmd)
static int
Xboot(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
if (cmd->argc > 1 && cmd->argv[1][0] != '-') {
- register char *p;
-
- for (p = cmd->argv[1]; *p; p++)
- if (*p == ':')
- break;
- if (*p == ':')
- sprintf(cmd->path, "%s", cmd->argv[1]);
- else if (cmd->argv[1][0] == '/')
- sprintf(cmd->path, "%s:%s", cmd->bootdev,
- cmd->argv[1]);
- else
- sprintf(cmd->path, "%s:%s%s", cmd->bootdev,
- cmd->cwd, cmd->argv[1]);
-
+ qualify(cmd, (cmd->argv[1]? cmd->argv[1]: cmd->image));
if (bootparse(cmd, 2))
return 0;
} else {
@@ -455,9 +514,35 @@ Xboot(cmd)
return 1;
}
+/*
+ * Qualifies the path adding neccessary dev&|cwd
+ */
+
+static char *
+qualify(cmd, name)
+ register struct cmd_state *cmd;
+ char *name;
+{
+ register char *p;
+
+ for (p = name; *p; p++)
+ if (*p == ':')
+ break;
+ if (*p == ':')
+ if (p[1] == '/')
+ sprintf(cmd->path, "%s", name);
+ else
+ sprintf(cmd->path, "%s%s%s", name, cmd->cwd, name);
+ else if (name[0] == '/')
+ sprintf(cmd->path, "%s:%s", cmd->bootdev, name);
+ else
+ sprintf(cmd->path, "%s:%s%s", cmd->bootdev, cmd->cwd, name);
+ return cmd->path;
+}
+
static int
bootparse(cmd, i)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
int i;
{
register char *cp;
@@ -499,7 +584,7 @@ bootparse(cmd, i)
static int
Xcd(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
register char *p, *q;
struct stat sb;
@@ -552,7 +637,7 @@ Xcd(cmd)
static int
Xreboot(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
printf("Rebooting...\n");
exit();
@@ -561,7 +646,7 @@ Xreboot(cmd)
static int
Xregs(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
DUMP_REGS;
return 0;
@@ -569,14 +654,14 @@ Xregs(cmd)
static int
Xnope(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
return 0;
}
static int
Xcp(cmd)
- struct cmd_state *cmd;
+ register struct cmd_state *cmd;
{
printf("cp: no writable filesystems\n");
return 0;
diff --git a/sys/stand/boot/cmd.h b/sys/stand/boot/cmd.h
index a806e1c05f7..7682af1dd25 100644
--- a/sys/stand/boot/cmd.h
+++ b/sys/stand/boot/cmd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: cmd.h,v 1.4 1997/04/21 20:03:31 mickey Exp $ */
+/* $OpenBSD: cmd.h,v 1.5 1997/04/26 17:50:07 mickey Exp $ */
/*
* Copyright (c) 1997 Michael Shalayeff
@@ -36,14 +36,17 @@ struct cmd_table;
struct cmd_state {
char bootdev[16]; /* device */
char image[32]; /* image */
+ char *conf; /* /etc/boot.conf normally */
char cwd[MAXPATHLEN - 32 - 16];
void *addr; /* load here */
int timeout;
- char path[MAXPATHLEN]; /* buffer for pathname compose */
+ char path[MAXPATHLEN]; /* buffer for pathname compose */
const struct cmd_table *cmd;
int argc;
char *argv[8]; /* XXX i hope this is enough */
};
int getcmd __P((register struct cmd_state *));
+int read_conf __P((register struct cmd_state *));
+